| showModalDialog | |
|
如果你的Asp.Net程序执行时碰到这种错误:“验证视图状态 MAC 失败。如果此应用程序由网络场或群集承载,请确保 <machineKey> 配置指定了相同的 validationKey 和验证算法。不能在群集中使用 AutoGenerate。”那么说明你没有让你的应用程序使用统一的machineKey,那么machineKey的作用是什么呢?按照MSDN的标准说法:“对密钥进行配置,以便将其用于对 Forms 身份验证 Cookie 数据和视图状态数据进行加密和解密,并将其用于对进程外会话状态标识进行验证。”也就是说Asp.Net的很多加密,都是依赖于machineKey里面的值,例如Forms 身份验证 Cookie、ViewState的加密。默认情况下,Asp.Net的配置是自己动态生成,如果单台服务器当然没问题,但是如果多台服务器负载均衡,machineKey还采用动态生成的方式,每台服务器上的machinekey值不一致,就导致加密出来的结果也不一致,不能共享验证和ViewState,所以对于多台服务器负载均衡的情况,一定要在每台站点配置相同的machineKey。
machineKey生成的算法:
validationKey = CreateKey(20);
decryptionKey = CreateKey(24);
protected string CreateKey(int len)
{
byte[] bytes = new byte[len];
new RNGCryptoServiceProvider().GetBytes(bytes);
StringBuilder sb = new StringBuilder();
for(int i = 0; i < bytes.Length; i++)
{
sb.Append(string.Format("{0:X2}",bytes[i]));
}
return sb.ToString();
}
附参考的matchineKey配置:
<?xml version="1.0"?>
<configuration>
<system.web>
<machineKey validationKey="3FF1E929BC0534950B0920A7B59FA698BD02DFE8" decryptionKey="280450BB36319B474C996B506A95AEDF9B51211B1D2B7A77" decryption="3DES" validation="SHA1"/>
</system.web>
</configuration>
——————————————————————–
这个错误的根源就是asp.net2.0 的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" />
这些日子一直在茫然的放任自己,损耗这自己青春,今天突然有种一觉醒来的感觉。应当告别昨日碌碌无为,重新的,实实在在的,脚踏实地的做点事情。我就好像是一个一直在下坠的球体,不停的向下坠落,而今天,此时此刻,像是一个平面,我坠落在上面,然后弹起,转而向上。
83年出生的我,今年已经24岁,应当在有限的生命里,做更多实实在在的事情。
神舟电脑,让老百姓用的起的电脑。我个人一直很关注这个国产品牌。以其超低的价格优势,pc及nb行业占有他自己的一席之地。在低价的前提下,神舟仍然对自己的产品很负责任,售后也做得不错。因此神舟才得以生存。
神舟发展的很快,也一直在进步,从黄色标贴的改变,从logo的改变,到今天网站的改版http://www.hasee.com/cn,神舟确实做得很不错,一直在努力树立着自己的品牌形象,朝着国际化方向发展。目前神舟电脑已经在国外很多地区销售,前段时间还拿下了联合国15000台nb的单子,希望神舟,我们中国的品牌会越来越好。
只是那个半男不女的形象代言人,让很多人失去了购买欲
