配置指定了相同的validationKey和驗證算法。不能在群集中使用AutoGenerate發生錯誤的環境:ASP.NET2.0,使用Atlas的UpdatePanel,在UpdatePanel中動態加載用戶控件,以達到動態更新頁面的效果。其中有一個用戶控件中使用" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

驗證視圖MAC失敗 Validation of ViewState MAC

系統 1773 0

今天在調試Atlas時遇到錯誤:

驗證視圖MAC失敗。如果此引用程序由網絡場或群集承載,請確保<machineKey>配置指定了相同的 validationKey 和驗證算法。不能在群集中使用 AutoGenerate

發生錯誤的環境:

ASP.NET 2.0,使用Atlas的UpdatePanel,在UpdatePanel中動態加載用戶控件,以達到動態更新頁面的效果。其中有一個用戶控件中使用了GridView。當動態切換頁面時,出現上述錯誤。

問題分析:

經過一番搜索,找到以下的文章:

http://aspadvice.com/blogs/joteke/archive/2006/02/02/15011.aspx

http://forums.asp.net/1173230/ShowPost.aspx

分析后找到了問題的根源。首先,文章中提到,如果用GridView,并且指定了DataKeyNames屬性,則出于安全的理由(因為DataKeyNames指定的字段代表數據的主鍵,且該主鍵值需要保存在視圖狀態中發送到客戶端,用戶如果篡改主鍵值,會導致安全問題),GridView會要求加密視圖狀態。為此會自動在頁面表單</forms>之前添加一個<input type="hidden" name="__VIEWSTATEENCRYPTED" id="__VIEWSTATEENCRYPTED" value="" /> 。

然而,Atlas的UpdatePanel要求放置在<form></form>內部,也就是</form>之前。這就意味著添加的隱藏input控件沒有被放置在UpdatePanel內,而是放置在UpdatePanel和</form>之間。

當UpdatePanel更新時,UpdatePanel內部的控件被提交到服務器進行處理(Patrial Rendering),而整個頁面并沒有被提交。也就是說隱藏的input控件沒有隨著一起提交。因此服務器并不知道提交的ViewState被加密了,從而導致MAC驗證錯誤。

解決方法:

通過在Web.config里邊添加

<pages enableEventValidation="false" viewStateEncryptionMode ="Never" />

可以解決該問題。

ASP.NET 2.0 and "Validation of ViewState Mac failed" exception

If you get this?Exception

[HttpException (0x80004005): Validation of viewstate MAC failed. If this application is hosted by a Web Farm or cluster, ensure that <machineKey> configuration specifies the same validationKey and validation algorithm. AutoGenerate cannot be used in a cluster.]

and

  • you know *for sure*?that you aren't using a web farm
  • it seems that it appears when using built-in databound controls such as GridView, DetailsView or FormView which utilize DataKeyNames.
  • it appears if you have a large page which?loads slowly for any reason

If following preconditions are true and you click a postbacking control/link while the Page hasn't loaded completely, you might get?the "Validation of ViewState MAC failed"??exception. In this case be sure to check following post on ASP.NET Forums where this has been discussed quite thoroughly : http://forums.asp.net/1173230/ShowPost.aspx

It?appears because GridView using DataKeyNames requires ViewState to be encrypted. And when ViewState is encrypted, Page adds??<input type="hidden" name="__VIEWSTATEENCRYPTED" id="__VIEWSTATEENCRYPTED" value="" /> field just before?closing of the <form> tag. But this hidden field might not bet yet rendered to the browser with long-running pages, and if you make a postback before it "gets down", browser?initiates postback without this field (in form post collection)

End result is that if this field is omitted on postback, Page doesn't "know" that?viewstate is encrypted and causes the prementioned Exception. E.g Page expects to be fully-loaded before you can make a postback. And by the way similar problem is with event validation since __EVENTVALIDATION field is also rendered on the end of the form.

A?way to overcome the problem is to set in web.config pages enableEventValidation="false" viewStateEncryptionMode ="Never" />Just note the security implications of these!
在預設狀況ASP.NET會隨機建立manchineKey當作驗證碼,
<configuration>
<system.web >
<machineKey validationKey = "AutoGenerate,IsolateApps"
decryptionKey = "AutoGenerate,IsolateApps" validation = "SHA1"/>
</system.web>
</configuration
若你有兩臺Web Server,當另一臺要驗證ViewState時,
validationKey或decryptionKey必須是相同的,所以必須自行產生validationKey後,
才能以相同的驗證碼來處理ViewState甚至cookie等。

產生驗證碼的方法如下:

string validationKey = GetKey(30); //20~64均可
string decryptionKey = GetKey(30); //20~64均可

protected string GetKey(int Keylen)
{
byte[] bytes = new byte[Keylen];
new RNGCryptoServiceProvider().GetBytes(bytes);
StringBuilder Builder = new StringBuilder();
for (int i = 0; i < bytes.Length; i++)
{
Builder.Append(string.Format("{0:X2}", bytes[i]));
}
return Builder.ToString();
}

產生後即可在每臺Web Server網站的Web.Config加上<machineKey>即可,如下
<configuration>
<system.web>
<machineKey validationKey="3FF1E929BC0534950B0920A7B59FA698BD02DFE8"
decryptionKey="280450BB36319B474C996B506A95AEDF9B51211B1D2B7A77"
decryption="3DES" validation="SHA1"/>
</system.web>
</configuration>

驗證視圖MAC失敗 Validation of ViewState MAC Failed


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久综合一个色综合网 | 草草视频在线 | 欧美二区在线 | 99爱在线精品视频免费观看9 | 国产色综合一区二区三区 | 在线不卡视频 | 狠久久| 五月天婷婷久久 | 久草在线新免久费观看视频 | 中文字幕亚洲一区 | 久久久蜜桃 | 91久久精品一区二区二区 | 日韩a无v码在线播放免费 | 天天澡天天碰天天狠伊人五月 | 欧美午夜精品一区二区蜜桃 | 91婷婷 | 无码AV免费一区二区三区A片 | 久久亚洲精品国产精品黑人 | 国产综合久久 | 狠狠躁夜夜躁人人爽天天高潮 | 欧美在线 | 亚洲 | 日韩亚洲欧美在线爱色 | 九九精品免费 | 国产欧美一级二级三级在线视频 | 三级黄色免费观看 | 视频一区二区三区四区五区 | 欧美aⅴ片 | 午夜羞羞影院 | 精品卡1卡二卡3卡 | 久久久久无码国产精品一区 | 国产真实乱freesex | 特级毛片免费 | 一级毛片在线完整免费观看 | 免费级毛片 | 日韩精品一区二区三区 | 亚洲欧美视频在线播放 | 亚洲欧美国产一区二区三区 | 日日骚视频| 魔法骑士在线观看免费完整版高清 | 一级高清毛片 | 日本黄色片免费看 |