• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答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進行跨域數(shù)據(jù)交互時Cookies數(shù)據(jù)的傳遞

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

    ASP.Net WebAPI與Ajax進行跨域數(shù)據(jù)交互時Cookies數(shù)據(jù)的傳遞

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

    前言

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

    最開始通過頭部(Header)將Cookies傳輸?shù)狡鋀ebAPI,也能解決問題。

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

    解決過程:

    步驟一:將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 關聯(lián)的域(如:“.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數(shù)據(jù)類型解決跨域問題(c.wbl.com域名下)

    前后端需要定義統(tǒng)一的回調(diào)(Callback)函數(shù)名。

    前端Ajax代碼:

    // 設置Cookies
     function set() {
     var url = "http://a.wbl.com/api/setvalue/888888";
     $.ajax({
     type: "get",
     url: url,
     dataType: "jsonp",
     jsonp: "callbackparam", //服務端用于接收callback調(diào)用的function名的參數(shù)
     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調(diào)用的function名的參數(shù)
     jsonpCallback: "success_jsonpCallback", //callback的function名稱
     success: function (json) {
     console.log(json);
     alert(json);
     },
     error: function () {
     alert('fail');
     }
     });
     }

    步驟三:WebAPI中返回jsonp數(shù)據(jù)類型

    Jsonp格式:

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

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

    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)來處理的,后續(xù)在進行實驗。各位路過的大神如有更好的方法,望不要吝嗇,請賜教!菜鳥感激不盡!

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

    文檔

    ASP.Net WebAPI與Ajax進行跨域數(shù)據(jù)交互時Cookies數(shù)據(jù)的傳遞

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 日韩人妻无码精品久久久不卡| 欧美jizzhd精品欧美| 欧美国产成人久久精品| 2022精品天堂在线视频| 亚洲精品一级无码中文字幕| 国产成人精品久久一区二区三区av | 精品爆乳一区二区三区无码av| 国内精品伊人久久久久网站| 国产精品爱啪在线线免费观看| 无码国产69精品久久久久网站| 污污网站国产精品白丝袜| 国产精品最新国产精品第十页| 九九热这里只有在线精品视| 国产精品无码无片在线观看| 无码国产精品一区二区免费模式| 欧美XXXX黑人又粗又长精品| 国产精品免费视频观看拍拍| 四虎成人精品免费影院| 精品久久久久久亚洲| 国产精品久久久天天影视| 国产AV午夜精品一区二区入口 | 国产精品久久久久天天影视| 潮喷大喷水系列无码久久精品| 久久精品九九亚洲精品| 人妻少妇精品视频一区二区三区 | 合区精品中文字幕| 欧洲精品码一区二区三区免费看 | 国产精品久久久久久影院| 98视频精品全部国产| 国产精品视频第一区二区三区| 无码日韩精品一区二区三区免费| 综合人妻久久一区二区精品| 亚洲国产成人乱码精品女人久久久不卡 | 久久e热在这里只有国产中文精品99| 丁香色婷婷国产精品视频| 亚洲精品私拍国产福利在线| 亚洲国产精品久久久久婷婷软件| 久久免费精品视频| 尤物国产在线精品福利一区| 国产999精品久久久久久| 精品国产91久久久久久久a|