现在的位置: 首页 > 综合 > 正文

验证视图状态 MAC 失败。如果此应用程序由网络场或群集承…

2012年10月20日 ⁄ 综合 ⁄ 共 4872字 ⁄ 字号 评论关闭

这个问题困扰我很久了,终于解决了,你们要是在我这里得到了答案,可要请吃饭哦!

“/”应用程序中的服务器错误。


验证视图状态 MAC 失败。如果此应用程序由网络场或群集承载,请确保 <machineKey> 配置指定了相同的 validationKey 和验证算法。不能在群集中使用 AutoGenerate。

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.Web.HttpException: 验证视图状态 MAC 失败。如果此应用程序由网络场或群集承载,请确保 <machineKey> 配置指定了相同的 validationKey 和验证算法。不能在群集中使用 AutoGenerate。

源错误:

[没有相关的源行]

源文件: c:\windows\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files\root\f8067725\e4ea7afb\App_Web_ny2ucv3x.6.cs      行: 0

堆栈跟踪:

[HttpException (0x80004005): 无法验证数据。]
        System.Web.Configuration.MachineKeySection.GetDecodedData(Byte[] buf, Byte[] modifier, Int32 start, Int32 length, Int32& dataLength) +2549660
        System.Web.UI.ObjectStateFormatter.Deserialize(String inputString) +214

[ViewStateException: 无效的视图状态。
 Client IP: 60.212.12.99
 Port: 2017
 User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)
 ViewState: /wEPDwULLTEyMzI2MTA1NTcPZBYCAgMPZBYCAgEPPCsADQEADxYGHgtfIURhdGFCb3VuZGceCVBhZ2VDb3VudAIBHgtfIUl0ZW1Db3VudAIJZBYCZg9kFhYCAQ9kFghmDw8WAh4EVGV4dAUDMjA5ZGQCAQ9kFgICAQ8PFgQeC05hdmlnYXRlVXJsBR0vV2ViQXBwL1Nob3dTY3JhcC5hc3B4P2lkPTIwOR8DBZ4BMyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOy5kZAICDw8WAh8DBRIyMDA3LTEwLTEyIDA6MDA6MDBkZAIDD2QWAmYPDxYCHwQFF1VwZGF0ZVNjcmFwLmFzcHg/aWQ9MjA5ZGQCAg9kFghmDw8WAh8DBQMyMDhkZAIBD2QWAgIBDw8WBB8EBR0vV2ViQXBwL1Nob3dTY3JhcC5hc3B4P2lkPTIwOB8DBYkBMTExMSZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOyZuYnNwOy5kZAICDw8WAh8DBRIyMDA3LTEwLTEyIDA6MDA6MDBkZAIDD2QWAmYPDxYCHwQFF1VwZGF0ZVNjcmFwLmFzcH...]

[HttpException (0x80004005): 验证视图状态 MAC 失败。如果此应用程序由网络场或群集承载,请确保 <machineKey> 配置指定了相同的 validationKey 和验证算法。不能在群集中使用 AutoGenerate。]
        System.Web.UI.ViewStateException.ThrowError(Exception inner, String persistedState, String errorPageMessage, Boolean macValidationError) +116
        System.Web.UI.ObjectStateFormatter.Deserialize(String inputString) +251
        System.Web.UI.ObjectStateFormatter.System.Web.UI.IStateFormatter.Deserialize(String serializedState) +4
        System.Web.UI.Util.DeserializeWithAssert(IStateFormatter formatter, String serializedState) +37
        System.Web.UI.HiddenFieldPageStatePersister.Load() +220
        System.Web.UI.Page.LoadPageStateFromPersistenceMedium() +83
        System.Web.UI.Page.LoadAllState() +35
        System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +6953
        System.Web.UI.Page.ProcessRequest(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +154
        System.Web.UI.Page.ProcessRequest() +86
        System.Web.UI.Page.ProcessRequestWithNoAssert(HttpContext context) +18
        System.Web.UI.Page.ProcessRequest(HttpContext context) +49
        ASP.webapp_admin_affiche_gridviewshowdata_aspx.ProcessRequest(HttpContext context) in c:\windows\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files\root\f8067725\e4ea7afb\App_Web_ny2ucv3x.6.cs:0
        System.Web.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +154
        System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +64

 

 


 

版本信息: Microsoft .NET Framework 版本:2.0.50727.42; ASP.NET 版

如果你的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>

如果用GridView,并且指定了DataKeyNames属性,则出于安全的理由(因为DataKeyNames指定的字段代表数据的主键,且该主键值需要保存在视图状态中发送到客户端,用户如果篡改主键值,会导致安全问题),GridView会要求加密视图状态。为此会自动在页面表单</forms>之前添加一个<input type="hidden" name="__VIEWSTATEENCRYPTED" id="__VIEWSTATEENCRYPTED" value="" /> 。然而,Atlas的UpdatePanel要求放置在<form></form>内部,也就是</form>之前。

<pages validateRequest="false"/>改为:

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

抱歉!评论已关闭.