日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

beanutils.copyproperties属性值丢失_[ASP.NET Core 3.1]浏览器嗅探解决部分浏览器丢失Cookie问...

發布時間:2024/7/23 asp.net 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 beanutils.copyproperties属性值丢失_[ASP.NET Core 3.1]浏览器嗅探解决部分浏览器丢失Cookie问... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天的干貨長驅直入,直奔主題

看了前文的同學們應該都知道,搜狗、360等瀏覽器在單點登錄中反復重定向,最終失敗報錯。

原因在于,非Chrome80+瀏覽器不識別Cookie上的SameSite=none屬性值,導致認證Cookie在后續請求中被拋棄。

截至2020/3/30號,非Chrome瀏覽器測試包含兩種結果:

  • case1:可設置cookie的samesite=none, 瀏覽器可讀取該cookie
  • case2:對cookie設置samesite=none, 瀏覽器不能讀取該cookie
瀏覽器最新版本號結果備注
IE11case1win10
Edge44.18362.449.0case12020/2/15開始使用chrome內核/70.0.3538.102
Firefox74case1
360急速瀏覽器12.0.1190.0case1基于chromium78
搜狗瀏覽器8.6.1.31812case2User-Agent:Chrome/65.0.3314.0
獵豹安全瀏覽器6.5.115case2User-Agent:Chrome/57.0.2987.98
QQ瀏覽器10.5.3case1chromium 70
華為手機瀏覽器10.0.6.304case1
魅族手機瀏覽器8.5.1case2

嗯,我之前報的360急速瀏覽器在新版已經更新了Chrome內核,作為主流的搜狗和獵豹瀏覽器還是使用舊版本Chrome內核,這是要鬧哪樣?

如果Web應用程序打算支持舊內核瀏覽器,則需要實現瀏覽器嗅探。ASP.NET Core不會幫你實現瀏覽器嗅探,因為User-Agents值易變且經常更改。

但是Microsoft.AspNetCore.CookiePolicy中的擴展點允許插入瀏覽器嗅探邏輯。

在Startup.Configure中,在調用UseAuthentication或任何寫入cookie的方法之前添加調用UseCookiePolicy的代碼

public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}

app.UseHttpsRedirection();
app.UseStaticFiles();

app.UseRouting();
// 表示ASP.NET Core 啟動Cookie策略
app.UseCookiePolicy();
app.UseAuthentication();
app.UseAuthorization();

app.UseEndpoints(endpoints =>
{
endpoints.MapRazorPages();
});
}

在Startup.ConfigureServices, 添加Cookie的策略配置代碼:

public void ConfigureServices(IServiceCollection services)
{
services.Configure(options =>
{
options.MinimumSameSitePolicy = (SameSiteMode)(-1);
options.OnAppendCookie = cookieContext =>
CheckSameSite(cookieContext.Context, cookieContext.CookieOptions);
options.OnDeleteCookie = cookieContext =>
CheckSameSite(cookieContext.Context, cookieContext.CookieOptions);
});
services.AddRazorPages();
}
private void CheckSameSite(HttpContext httpContext, CookieOptions options)
{
if (options.SameSite == SameSiteMode.None)
{
var userAgent = httpContext.Request.Headers["User-Agent"].ToString();
if (MyUserAgentDetectionLib.DisallowsSameSiteNone(userAgent))
{
options.SameSite = SameSiteMode.Unspecified;
}
}
}

上面的例子中,MyUserAgentDetectionLib.DisallowsSameSiteNone 是一個自定義的庫文件,偵測不支持SameSite=None的UserAgent。

ASP.NET Core3.1 對與SameSiteMode新增了一個 Unspecified枚舉值,表示服務端不會對Cookie設置SameSite屬性值, 后面的攜帶Cookie的事情交給瀏覽器默認配置。

具體的偵測代碼如下:

public static bool DisallowsSameSiteNone(string userAgent)
{
// Check if a null or empty string has been passed in, since this
// will cause further interrogation of the useragent to fail.
if (String.IsNullOrWhiteSpace(userAgent))
return false;

// Cover all iOS based browsers here. This includes:
// - Safari on iOS 12 for iPhone, iPod Touch, iPad
// - WkWebview on iOS 12 for iPhone, iPod Touch, iPad
// - Chrome on iOS 12 for iPhone, iPod Touch, iPad
// All of which are broken by SameSite=None, because they use the iOS networking
// stack.
if (userAgent.Contains("CPU iPhone OS 12") ||
userAgent.Contains("iPad; CPU OS 12"))
{
return true;
}

// Cover Mac OS X based browsers that use the Mac OS networking stack.
// This includes:
// - Safari on Mac OS X.
// This does not include:
// - Chrome on Mac OS X
// Because they do not use the Mac OS networking stack.
if (userAgent.Contains("Macintosh; Intel Mac OS X 10_14") &&
userAgent.Contains("Version/") && userAgent.Contains("Safari"))
{
return true;
}

// Cover Chrome 50-69, because some versions are broken by SameSite=None,
// and none in this range require it.
// Note: this covers some pre-Chromium Edge versions,
// but pre-Chromium Edge does not require SameSite=None.
if (userAgent.Contains("Chrome/5") || userAgent.Contains("Chrome/6"))
{
return true;
}

return false;
}

總結

本文實戰講解在ASP.NET Core CookiePolicy擴展點插入瀏覽器嗅探邏輯,解決設備不支持cookie SameSite=none而導致的cookie丟失問題。

  • https://www.chromium.org/updates/same-site/incompatible-clients
推薦閱讀

●?這么香的Chrome插件,你都安裝了嗎?

●?一文掌握Cookies前世今生

●?ASP.NET Core跨平臺技術內幕

●?TPL Dataflow組件應對高并發,低延遲要求

●?實例解讀Docker Swarm

●?基于docker-compose的Gitlab CI/CD實踐&排坑指南

總結

以上是生活随笔為你收集整理的beanutils.copyproperties属性值丢失_[ASP.NET Core 3.1]浏览器嗅探解决部分浏览器丢失Cookie问...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品久久久久一区二区三区 | 亚洲一区二区三区高清在线 | 我的丝袜美腿尤物麻麻 | 中文幕无线码中文字蜜桃 | 韩国精品一区二区三区 | 国产极品美女高潮无套在线观看 | 欧美第九页 | 国产清纯白嫩初高中在线观看性色 | 亚洲永久免费 | 欧美韩一区二区 | 天天色影| 国产亚洲精品熟女国产成人 | 国产资源在线视频 | 久久久久久久久久久网 | 久久久精品蜜桃 | 国产一级一级 | 天天插日日插 | 亚洲性图av | 久久久久久久伊人 | 一区二区高清在线观看 | 无码精品一区二区三区在线播放 | 日韩一区二区三区精品 | 综合在线一区 | 亚洲欧美自偷自拍 | 国产三区av | 亚洲激情小视频 | 色视频导航 | 亚洲无码精品一区二区三区 | 国产高清露脸 | 国产91精品一区二区绿帽 | 不许穿内裤随时挨c调教h苏绵 | 欧美日韩一区二区电影 | 福利免费观看 | 国产理论片 | 一女二男一黄一片 | 九九久久综合 | 午夜在线视频免费观看 | www视频在线观看免费 | 中国女人特级毛片 | 日韩免费视频一区二区 | 欧美一区 | 女儿的朋友4在线观看 | 成人免费观看网站 | 女人被灌满精子 | jlzzzjlzzz国产免费观看 | 国产一级视频在线播放 | 五月婷婷在线观看 | 国产人妖ts重口系列网站观看 | 99夜色 | 瑟瑟久久 | 91成人毛片 | 韩国黄色视屏 | 在线播放色 | 熟女少妇精品一区二区 | 玉女心经是什么意思 | 天天看天天摸天天操 | 成年视频在线观看 | 国产69精品一区二区 | 久久国产精品久久久久久 | 国产婷婷色综合av蜜臀av | 精产国品一区二区三区 | 色天堂视频 | 在线观看欧美一区二区三区 | 蜜臀久久99精品久久久久久 | 黄色一级大片在线免费看国产一 | 欧美精品一区二区三区久久久竹菊 | 久久不射影院 | 欧美日韩午夜 | 欧美成人精品一区二区 | 日韩激情在线 | 国产天堂一区 | 蜜桃精品视频在线 | 亚洲影院一区二区三区 | 国产爱搞 | 正在播放老肥熟妇露脸 | 男人的天堂中文字幕 | 18被视频免费观看视频 | 香蕉福利 | 99热在线免费观看 | 国产视频久久久久久 | 日本在线加勒比 | free国产hd露脸性开放 | 久久久精品国产sm调教网站 | 一区二区播放 | 福利小视频在线播放 | 男人天堂怡红院 | 亚洲国产日韩一区 | 欧美极品少妇xxxxⅹ猛交 | 亚洲熟妇无码乱子av电影 | 波多野av在线 | 黄色一机片 | 欧美福利在线视频 | 国产一区二区播放 | 饥渴的少妇和男按摩师 | www夜片内射视频日韩精品成人 | 亚洲欧美另类一区 | 久久久999国产精品 天堂av中文在线 | 国产在线观看你懂的 | 怡红院成人影院 |