<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
        主站蜘蛛池模板: 亚洲精品成人片在线播放| 亚洲欧美日韩中文二区| 久久青青草原亚洲av无码app| 亚洲国产精品成人综合久久久| 老牛精品亚洲成av人片| 99久久免费观看| 亚洲日韩国产精品乱| 亚洲乱码一二三四区乱码| 9久热这里只有精品免费| 国产成人精品免费视频大全五级| 亚洲国产精品婷婷久久| 国产成人1024精品免费| 国产三级电影免费观看| 亚洲精品亚洲人成在线播放| A在线观看免费网站大全| 亚洲免费视频网站| 99久久精品日本一区二区免费| 国产亚洲真人做受在线观看| 成人毛片100免费观看| 久久99亚洲综合精品首页| 狠狠综合亚洲综合亚洲色| 免费永久在线观看黄网站| 中文字幕免费播放| 亚洲欧洲校园自拍都市| 在线播放高清国语自产拍免费| 亚洲另类春色校园小说| 最近免费中文字幕高清大全| 亚洲VA中文字幕无码一二三区| 精品一区二区三区免费观看| 亚洲电影中文字幕| 久久aⅴ免费观看| 久久综合图区亚洲综合图区| 成人免费午夜无码视频| 性生大片视频免费观看一级| 亚洲精品亚洲人成在线观看下载| 在线观看亚洲免费| 亚洲欧美aⅴ在线资源| 亚洲国产乱码最新视频| 国产在线播放免费| 久久精品国产69国产精品亚洲| 亚洲国产成人精品91久久久|