<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级毛片免费观看AV网站| 亚洲人成电影在线观看青青| 国产一卡2卡3卡4卡无卡免费视频| 久久精品国产亚洲AV无码麻豆| 最近中文字幕完整版免费高清| 91在线亚洲精品专区| 麻花传媒剧在线mv免费观看| 亚洲国产AV无码一区二区三区| 成在人线AV无码免费| 国产v亚洲v天堂无码网站| 成全在线观看免费观看大全| 久久亚洲精品人成综合网| 青青在线久青草免费观看| 亚洲高清毛片一区二区| 亚洲A∨午夜成人片精品网站| 国产在线精品一区免费香蕉| 久久亚洲精品人成综合网| 免费无码AV片在线观看软件| 美女视频黄视大全视频免费的| 亚洲人成人一区二区三区| 亚洲成人免费在线观看| 国产成人人综合亚洲欧美丁香花 | 亚洲永久在线观看| 韩国免费三片在线视频| 日韩在线观看免费| 久久亚洲AV无码精品色午夜麻豆| 永久免费的网站在线观看| 美女被吸屁股免费网站| 亚洲va无码手机在线电影| 黄瓜视频高清在线看免费下载| 黄色三级三级免费看| 五月天网站亚洲小说| 日韩免费一区二区三区在线播放| 野花视频在线官网免费1| 久久亚洲美女精品国产精品| 国产又粗又长又硬免费视频| 日韩中文字幕免费视频|