亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

一個有趣的 ”Validation of viewstate MAC failed” 錯誤的發現和解決

2019-11-17 01:53:57
字體:
來源:轉載
供稿:網友

一個有趣的 ”Validation of viewstate MAC failed” 錯誤的發現和解決

asp.net里面,View State使用較為廣泛。它作為一個隱藏字段,可以幫助服務端”記住“客戶端的改變,這樣客戶端 收到服務器對PostBack的響應后,仍然可以展現在PostBack之前設定的值 (具體參見http://msdn.microsoft.com/en-us/library/bb386448(v=vs.100).aspx )

<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value="..." />

為了防止惡意客戶端的PostBack里的ViewState被解讀,ASP.NET會用消息驗證碼(MAC)來檢查每個ViewState。可是一旦服務器無法正確解釋正??蛻舳薖ostBack回來的ViewState時,整個應用都會停止工作。比如出現 ”Validation of viewstate MAC failed” 的錯誤。

通常來說,一旦這樣的錯誤出現,首先會考慮以下幾種情況:

1. 是不是有多臺Web Server在負載均衡情況下運行。如果是的話,需要各臺服務器使用相同的MAC進行ViewState的加密和解密工作。否則如果這個負載均衡環境沒有完全做的session Affinity,這種錯誤就會出現。

2. 測試本機訪問是否也有這種錯誤。如果是的話,除了嘗試重新產生新的MachineKey (參見http://blogs.msdn.com/b/amb/archive/2012/07/31/easiest-way-to-generate-machinekey.aspx ),也可以用PRocess Monitor在復現問題的時候跟蹤文件和注冊表的訪問,看看是不是因為W3WP.exe缺少權限而不能獲取和MachineKey相關的信息。

3. 在客戶端和服務器端抓取網絡包,比較ViewState是否被中間設備改動。這種情況不多見,但是也遇到過。算是復雜的一種情況。如果連接是SSL的,抓包沒有辦法查看,客戶端就要使用Fiddler,而服務端需要采取額外診斷日志或者Debug的方法。

4. 和具體代碼相關,尤其是對ViewStateUserKey有特殊設置。

這里談到的是一個在一個大型的生產應用環境里遇到的實際問題,和上面的情況有關,但有些有趣的變化。

這個環境里面有多臺Web 服務器,采用了負載均衡方式。在客戶試圖登錄時(login.aspx),總是會遇到”Validation of viewstate MAC failed”的錯誤。

起初,懷疑是不同機器上WebAppication的MachineKey不一樣引起的。檢查了Web.Config里的配置,各個機器都是一樣:

<system.web><machineKey decryptionKey="6284D74F8D9745C38712047622FFA047B02CA5C4049FB74E,IsolateApps" validationKey="137B974DC38A910D946AAF3ADF1D0386072170236F39C8165098035126FE7DFDF68C7BD3646052CE1769A47A45F098A65CEC3089523543370DD37830A5B2D13,IsolateApps" /></system.web>

而且負載均衡也設置了Class C的Session Affinity

后來發現這個問題即使本機訪問也會出現。把應用程序池身份改為Admin后,問題同樣。表明和權限無關。重新創建MachineKey,也沒有變化。

這時需要關注代碼。獲取了頁面代碼做Review. 在Login頁面的Page_Init里面, 看到ViewStateUserKey

protected void Page_Init(object sender, EventArgs e){        this.ViewStateUserKey = this.Session.SessionID; }

表面上看這樣的寫法也沒有什么問題。

在IE上啟用了Fiddler (連接是SSL) 后,發現客戶端的PostBack里面沒有Cookie的信息。這就是問題出現的直接原因:

a. 在第一次訪問Login頁面時,用一個隨機的SessionID A被嵌入了ViewState里面

b. 在PostBack時,由于沒有Cookie傳回來(ASP.NET SessionID缺省存放在Cookie里),服務器就判斷道客戶端沒有SessionID, 于是又使用一個新的SessionID B做ViewStateUserKey. 這樣,從ViewState里面解出的是上次的SessionID A, 和新的不匹配。錯誤就出現了。

可是客戶端為什么不發送Cookie呢?

原來這個服務器第一次回復時,對客戶端的HTTP Header里面根本沒有Set-Cookie字段。

這是沒有賦予Session 變量時ASP.NET的缺省行為 ( SessionID每次請求都會形成,但是未必會發送Set-Cookie 來讓客戶端保留這個SessioID,除非有賦予Session變量的行為)

于是解決這個問題的直接方法就是在這個Page_Init里面第一時間加一個語句:

protected void Page_Init(object sender, EventArgs e){    this.ViewStateUserKey = this.Session.SessionID;    session("forViewSate")="value"  }

這樣服務器把SessionID在”Set-Cookie”里發送回去,客戶端也可以用Cookie保留SessionID。問題就立刻解決了。

更多參考:

微軟技術文章討論如何處理” ”Validation of viewstate MAC failed”:

http://support.microsoft.com/kb/2915218


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩精品在线视频| 久久精品一本久久99精品| 国产成人免费av| 中文字幕欧美日韩va免费视频| 国产精品久久久久久搜索| 亚洲国产免费av| 91九色国产社区在线观看| 日韩成人在线视频网站| 成人免费视频a| 91精品国产色综合久久不卡98| 日本精品久久电影| 97超级碰碰人国产在线观看| 日韩精品欧美国产精品忘忧草| 日韩人体视频一二区| 日韩有码在线视频| 久久精视频免费在线久久完整在线看| 国产一区二区美女视频| www.亚洲人.com| 精品久久久久人成| 欧美在线亚洲一区| 日韩电影中文字幕在线| 欧美大片大片在线播放| 国产精品久久久999| 国语自产在线不卡| 日韩av在线免费观看一区| 中文字幕精品av| 美女撒尿一区二区三区| 久久影视电视剧免费网站清宫辞电视| 日韩av在线免费| 欧美亚洲激情在线| 亚洲欧美精品伊人久久| 中文字幕九色91在线| 欧美精品久久一区二区| 精品久久久久国产| 日韩av成人在线| 欧美中文字幕视频在线观看| 日韩欧美成人免费视频| 亚洲丝袜在线视频| 成人网在线免费观看| 亚洲性日韩精品一区二区| 粉嫩av一区二区三区免费野| 深夜成人在线观看| 久久久久久久久91| 国产精品自在线| 国产精品第七影院| 色婷婷成人综合| 中文字幕不卡av| 国产日韩欧美中文在线播放| 欧美性猛交xxxx乱大交3| 成人黄色免费在线观看| 久久亚洲精品国产亚洲老地址| 97在线视频一区| 亚洲欧美在线免费| www.欧美精品一二三区| 久久人人爽人人爽爽久久| 国产精品偷伦一区二区| 全色精品综合影院| 日韩精品视频免费专区在线播放| 中文字幕精品网| 国内揄拍国内精品| 欧美日韩国产成人| 韩国v欧美v日本v亚洲| 欧美国产在线视频| 亚洲欧洲国产精品| 丝袜情趣国产精品| 亚洲精品一区二区三区不| 日本中文字幕久久看| 国产69精品久久久久99| 欧美日韩在线视频一区二区| 日韩国产精品视频| 中文字幕成人精品久久不卡| 久久久久五月天| 97精品一区二区视频在线观看| 亚洲欧美精品伊人久久| 69av在线视频| 亚洲免费av电影| 国产91在线播放精品91| 欧美黄色三级网站| 欧美精品久久一区二区| 国产成人精品电影| 久久在精品线影院精品国产| 欧美精品亚州精品| 91啪国产在线| 国产精品久久av| 91久久久久久久一区二区| 午夜欧美不卡精品aaaaa| 国产亚洲成精品久久| 久久国产精品偷| 久久99国产精品久久久久久久久| 最新91在线视频| 久久成年人视频| 欧美性猛xxx| 午夜精品一区二区三区av| 国产精品久久久久久久午夜| 日韩一区二区三区在线播放| 疯狂蹂躏欧美一区二区精品| 亚洲欧美三级在线| 国产精品视频不卡| 亚洲高清久久久久久| 92版电视剧仙鹤神针在线观看| 国产亚洲欧洲在线| 欧美精品久久久久久久| 少妇av一区二区三区| 久久五月情影视| 久久精品在线视频| 国产精品久久综合av爱欲tv| 精品一区二区三区电影| 中文字幕av一区二区三区谷原希美| 国产日产久久高清欧美一区| 日韩美女毛茸茸| 欧洲s码亚洲m码精品一区| 不卡av在线播放| 国内精品一区二区三区| 欧美激情网友自拍| 国产精品高清在线观看| 久久99国产精品久久久久久久久| 成人黄色av免费在线观看| 欧美电影院免费观看| 精品成人乱色一区二区| 亚洲国产欧美一区二区丝袜黑人| 国产丝袜一区视频在线观看| 国产成人啪精品视频免费网| 精品国产自在精品国产浪潮| 欧美午夜美女看片| 国产精品中文在线| 日韩成人av在线播放| 国产欧美在线看| 国内免费久久久久久久久久久| 欧美精品久久久久| 理论片在线不卡免费观看| 7m第一福利500精品视频| 久久99久国产精品黄毛片入口| 日本久久久久久久| 最近更新的2019中文字幕| 国内精品美女av在线播放| 欧美大尺度激情区在线播放| 国产盗摄xxxx视频xxx69| 91亚洲精品在线观看| 亚洲精品资源美女情侣酒店| 国产亚洲精品久久久久久牛牛| 欧美国产日韩一区二区在线观看| 国产精品美腿一区在线看| 日韩av电影院| 久久久久久久久久久网站| 国产精品久久久久久久av电影| 国产精品成人一区二区| 亚洲电影免费观看| 日韩电视剧免费观看网站| 亚洲伊人久久大香线蕉av| 91网站在线看| 日韩高清电影好看的电视剧电影| 在线观看视频99| 国产精品嫩草视频| 欧美性黄网官网| 欧美一区视频在线| 国产精品久久久久77777| 91精品国产综合久久香蕉| 黄色成人av网| 91av在线国产| 国产成人综合一区二区三区| 成人久久精品视频| 国产亚洲人成网站在线观看| 亚洲一区二区中文字幕| 久久夜色精品亚洲噜噜国产mv|