<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        ASP.Net WebAPI與Ajax進行跨域數據交互時Cookies數據的傳遞

        來源:懂視網 責編:小采 時間:2020-11-27 22:35:46
        文檔

        ASP.Net WebAPI與Ajax進行跨域數據交互時Cookies數據的傳遞

        ASP.Net WebAPI與Ajax進行跨域數據交互時Cookies數據的傳遞:前言 最近公司項目進行架構調整,由原來的三層架構改進升級到微服務架構(準確的說是服務化,還沒完全做到微的程度,顆粒度沒那么細),遵循RESTFull規范,使前后端完全分離,實現大前端思想。由于是初次嘗試,中途也遇到了不少問題。今天就來討論一下其中之
        推薦度:
        導讀ASP.Net WebAPI與Ajax進行跨域數據交互時Cookies數據的傳遞:前言 最近公司項目進行架構調整,由原來的三層架構改進升級到微服務架構(準確的說是服務化,還沒完全做到微的程度,顆粒度沒那么細),遵循RESTFull規范,使前后端完全分離,實現大前端思想。由于是初次嘗試,中途也遇到了不少問題。今天就來討論一下其中之

        前言

        最近公司項目進行架構調整,由原來的三層架構改進升級到微服務架構(準確的說是服務化,還沒完全做到微的程度,顆粒度沒那么細),遵循RESTFull規范,使前后端完全分離,實現大前端思想。由于是初次嘗試,中途也遇到了不少問題。今天就來討論一下其中之一的問題,WebAPI與前端Ajax 進行跨域數據交互時,由于都在不同的二級域名下(一級域名相同),導致Cookies數據無法獲取。

        最開始通過頭部(Header)將Cookies傳輸到其WebAPI,也能解決問題。

        下面講述另外一種解決方案。

        解決過程:

        步驟一:將Cookies的Domain(域)設置成一級域名,例如:“.wbl.com”(a.wbl.com域名下)

        這是前提,此時在其中一個WebAPI中設置了Cookies后,用瀏覽器直接訪問其它的WebAPI是可以獲取到Cookies的。例如:a.wbl.com域名下設置的Cookies,用瀏覽器直接訪問b.wbl.com域名的WebAPI是可以獲取到Cookies的。但是用c.web.com域名下的Ajax訪問b.wbl.com時,就無法獲取到Cookies了,這是由于瀏覽器中Ajax的權限相對較低,Ajax無法跨域問題導致。

        寫入Cookies代碼:

        /// <summary>
         /// 給指定的 Cookies 賦值
         /// </summary>
         /// <param name="cookKey">Cookies 名稱</param>
         /// <param name="value">Cookies 值</param>
         /// <param name="domain">設置與此 Cookies 關聯的域(如:“.tpy100.com”)(可以使該域名下的二級域名訪問)</param>
         public static void SetCookiesValue(string cookKey, string value, string domain)
         {
         HttpCookie cookie = new HttpCookie(cookKey);
         cookie.Value = value;
         cookie.HttpOnly = true;
         if (!string.IsNullOrEmpty(domain) && domain.Length > 0)
         cookie.Domain = domain;
         HttpContext.Current.Response.Cookies.Add(cookie);
         }

        步驟二:JQuery中Ajax使用Jsonp數據類型解決跨域問題(c.wbl.com域名下)

        前后端需要定義統一的回調(Callback)函數名。

        前端Ajax代碼:

        // 設置Cookies
         function set() {
         var url = "http://a.wbl.com/api/setvalue/888888";
         $.ajax({
         type: "get",
         url: url,
         dataType: "jsonp",
         jsonp: "callbackparam", //服務端用于接收callback調用的function名的參數
         jsonpCallback: "success_jsonpCallback", //callback的function名稱
         success: function (json) {
         console.log(json);
         alert(json);
         },
         error: function () {
         alert('fail');
         }
         });
         }
         // 獲取Cookies
         function get() {
         var url = "http://b.wbl.com/api/getvalue";
         $.ajax({
         type: "get",
         url: url,
         dataType: "jsonp",
         jsonp: "callbackparam", //服務端用于接收callback調用的function名的參數
         jsonpCallback: "success_jsonpCallback", //callback的function名稱
         success: function (json) {
         console.log(json);
         alert(json);
         },
         error: function () {
         alert('fail');
         }
         });
         }

        步驟三:WebAPI中返回jsonp數據類型

        Jsonp格式:

        success_jsonpCallback({“Cookies”:”888888”})

        由于這種格式與json格式有所不同,只用WebAPI里的返回IHttpActionResult或HttpRequestMessage類型不行,最后通過流的方式輸出才實現了這個格式。

        WebAPI代碼:

        [Route("api/GetValue")]
         [HttpGet]
         public void GetValue()
         {
         string ccc = MyTools.Request.GetString("callbackparam");
         var a = new { name = "Cookies", value = MyTools.Cookies.GetCookiesValue("name") };
         string result = ccc + "({\"Cookies\":\"" + MyTools.Cookies.GetCookiesValue("name") + "\"})";
         //var response = Request.CreateResponse(HttpStatusCode.OK);
         //response.Content = new StringContent(result, Encoding.UTF8);
        
         HttpContext.Current.Response.Write(result);
         HttpContext.Current.Response.End();
         // return response;
         }
         [Route("api/SetValue/{id}")]
         [HttpGet]
         public void SetValue(int id)
         {
         //string domain = "";
         string domain = ".wbl.com";
         MyTools.Cookies.ClearCookies("name", domain);
         MyTools.Cookies.SetCookiesValue("name", id.ToString(), domain);
        
         string ccc = MyTools.Request.GetString("callbackparam");
         string result = ccc + "({\"result\":\"設置成功\"})";
        
         HttpContext.Current.Response.Write(result);
         HttpContext.Current.Response.End();
         }
        

        最終效果:

        后言:

        這只是解決這個問題的一種方法。百度后還有一種通過第三方插件(Cross-Origin、Help Page)來處理的,后續在進行實驗。各位路過的大神如有更好的方法,望不要吝嗇,請賜教!菜鳥感激不盡!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        ASP.Net WebAPI與Ajax進行跨域數據交互時Cookies數據的傳遞

        ASP.Net WebAPI與Ajax進行跨域數據交互時Cookies數據的傳遞:前言 最近公司項目進行架構調整,由原來的三層架構改進升級到微服務架構(準確的說是服務化,還沒完全做到微的程度,顆粒度沒那么細),遵循RESTFull規范,使前后端完全分離,實現大前端思想。由于是初次嘗試,中途也遇到了不少問題。今天就來討論一下其中之
        推薦度:
        標簽: 數據 cookie co
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲免费视频观看| 在线看片人成视频免费无遮挡| 中国在线观看免费的www| 亚洲黄色免费在线观看| 免费在线观看a级毛片| 中文字幕亚洲精品| 一级做a爱过程免费视| 国产精品视频免费一区二区 | 亚洲国产精品免费观看| 亚洲一区二区精品视频| 亚洲国产精品无码久久98 | 中文字幕亚洲激情| 亚洲爆乳大丰满无码专区| 国产成人免费a在线视频色戒| 亚洲最大黄色网站| 久久免费精品一区二区| 国外亚洲成AV人片在线观看| 亚洲精品人成网线在线播放va| 午夜免费福利网站| 天天爽亚洲中文字幕| 日韩精品无码专区免费播放| 久久精品夜色噜噜亚洲A∨| 成人无码精品1区2区3区免费看| 亚洲成Av人片乱码色午夜| 黄色视屏在线免费播放| 日韩视频在线免费观看| 亚洲中文字幕久久久一区| 日韩欧毛片免费视频| 欧洲亚洲国产精华液| 日韩毛片免费在线观看| 久久九九免费高清视频| 亚洲精品国产成人| 四虎在线免费视频| 看Aⅴ免费毛片手机播放| 日韩a级毛片免费视频| 中文字幕成人免费高清在线视频 | 亚洲日韩中文字幕无码一区| 曰批视频免费30分钟成人| 老妇激情毛片免费| 久久精品国产亚洲5555| 亚洲成年人免费网站|