国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答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
主站蜘蛛池模板: 伊人久久中文字幕 | 国产精品系列在线观看 | 久久成人国产 | 精品一区二区三区三区 | 日韩欧美高清视频 | 国产最新视频 | 精品一区二区三区免费视频 | 波多野的店 | 成人国产一区二区 | 成人精品一区二区三区 | 国产国拍亚洲精品午夜不卡17 | 一区二区在线观看视频 | 日韩欧美精品一区二区 | 国产精品久久久久aaaa | 亚洲欧洲免费 | 欧美成人精品第一区二区三区 | 伊人网影院 | 免费一级毛片 | 亚欧乱色视频网站大全 | 在线观看网站国产 | 精品一区二区三区免费毛片爱 | 国产一区二区免费播放 | 国产情侣91 | 日产精品一区二区三区免费 | 国产精品久久久久999 | 久国产精品视频 | 日韩精品第二页 | 亚洲国产精品免费视频 | 高清精品一区二区三区一区 | 国产日韩欧美亚洲综合首页 | 国产浴室偷窥在线播放 | 免费看黄视频网站 | 91精品国产91久久久久久 | 国产香蕉视频 | 欧美一区二区三区视频 | 日韩精品不卡 | 四虎影院永久免费观看 | 日本久久网 | 亚洲 欧美 中文 日韩欧美 | 手机看片91精品一区 | 日本欧美国产精品第一页久久 |