zoukankan      html  css  js  c++  java
  • 验证视图状态 MAC 失败。如果此应用程序由网络场或群集承...

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

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

    验证视图状态 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" />

  • 相关阅读:
    31天重构学习笔记28. 为布尔方法命名
    .NET 技术社区之我见(中文篇)
    31天重构学习笔记26. 避免双重否定
    31天重构学习笔记25. 引入契约式设计
    31天重构学习笔记20. 提取子类
    31天重构学习笔记18. 使用条件判断代替异常
    31天重构学习笔记19. 提取工厂类
    31天重构学习笔记24. 分解复杂判断
    31天重构学习笔记23. 引入参数对象
    31天重构学习笔记17. 提取父类
  • 原文地址:https://www.cnblogs.com/guanjie20/p/1592859.html
Copyright © 2011-2022 走看看