243

从客户端发回页面时出现以下错误。我有在客户端修改 asp:ListBox 的 JavaScript 代码。

我们如何解决这个问题?

错误详情如下:

Server Error in '/XXX' Application.

--------------------------------------------------------------------------------
Invalid postback or callback argument.  Event validation is enabled using <pages enableEventValidation="true"/> in configuration or <%@ Page EnableEventValidation="true" %> in a page.  For security purposes, this feature verifies that arguments to postback or callback events originate from the server control that originally rendered them.  If the data is valid and expected, use the ClientScriptManager.RegisterForEventValidation method in order to register the postback or callback data for validation.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.ArgumentException: Invalid postback or callback argument.  Event validation is enabled using <pages enableEventValidation="true"/> in configuration or <%@ Page EnableEventValidation="true" %> in a page.  For security purposes, this feature verifies that arguments to postback or callback events originate from the server control that originally rendered them.  If the data is valid and expected, use the ClientScriptManager.RegisterForEventValidation method in order to register the postback or callback data for validation.

Source Error:

An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace:

[ArgumentException: Invalid postback or callback argument.  Event validation is enabled using <pages enableEventValidation="true"/> in configuration or <%@ Page EnableEventValidation="true" %> in a page.  For security purposes, this feature verifies that arguments to postback or callback events originate from the server control that originally rendered them.  If the data is valid and expected, use the ClientScriptManager.RegisterForEventValidation method in order to register the postback or callback data for validation.]
   System.Web.UI.ClientScriptManager.ValidateEvent(String uniqueId, String argument) +2132728
   System.Web.UI.Control.ValidateEvent(String uniqueID, String eventArgument) +108
   System.Web.UI.WebControls.ListBox.LoadPostData(String postDataKey, NameValueCollection postCollection) +274
   System.Web.UI.WebControls.ListBox.System.Web.UI.IPostBackDataHandler.LoadPostData(String postDataKey, NameValueCollection postCollection) +11
   System.Web.UI.Page.ProcessPostData(NameValueCollection postData, Boolean fBeforeLoad) +353
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +1194

--------------------------------------------------------------------------------
Version Information: Microsoft .NET Framework Version:2.0.50727.1433; ASP.NET Version:2.0.50727.1433
4

40 回答 40

189

您的 Page_Load 事件中有代码吗?如果是,那么添加以下内容可能会有所帮助。

if (!Page.IsPostBack)
{ //do something }

当您单击命令并且再次运行 Page_load 时会引发此错误,在正常的生命周期中,它将是 Page_Load -> 单击命令 -> Page_Load(再次)-> 处理 ItemCommand 事件

于 2010-09-21T09:30:42.230 回答
176

问题是 ASP.NET 不知道这个额外的或删除的列表项。您有许多选项(如下所列):

  • 禁用事件验证(坏主意,因为您会失去一点安全性,而代价很小)。
  • 使用 ASP.NET Ajax 更新面板。(如果您添加或删除列表框,请将列表框放在更新面板中并触发更新。这样视图状态和相关字段将获得更新并且事件验证将通过。)
  • 忘记客户端并使用经典的回发并在服务器端添加或删除列表项。

我希望这有帮助。

于 2008-10-23T09:03:28.427 回答
40

我有使用 DataGrid 的经验。其中一列是“选择”按钮。当我单击任何行的“选择”按钮时,我收到了此错误消息:

“无效的回发或回调参数。事件验证在配置中使用或在页面中启用 <%@ Page EnableEventValidation="true" %>。出于安全目的,此功能验证回发或回调事件的参数是否来自服务器控件“

改了几个代码,终于成功了。我的体验路线:

1)我将页面属性更改为EnableEventValidation="false". 但它没有用。 (这不仅出于安全原因很危险,而且我的事件处理程序没有被调用:void Grid_SelectedIndexChanged(object sender, EventArgs e)

2)我ClientScript.RegisterForEventValidation在 Render 方法中实现。但它没有用。

protected override void Render(HtmlTextWriter writer)
{
    foreach (DataGridItem item in this.Grid.Items)
    {
        Page.ClientScript.RegisterForEventValidation(item.UniqueID);
        foreach (TableCell cell in (item as TableRow).Cells)
        {
            Page.ClientScript.RegisterForEventValidation(cell.UniqueID);
            foreach (System.Web.UI.Control control in cell.Controls)
            {
                if (control is Button)
                    Page.ClientScript.RegisterForEventValidation(control.UniqueID);
            }
        }
    }
}

3)我将网格列中的按钮类型从PushButton更改为LinkButton有效!("ButtonType="LinkBut​​ton")。我认为如果您可以在其他情况下将按钮更改为其他控件,例如“LinkBut​​ton”,它将正常工作。

于 2008-11-09T07:57:56.263 回答
28

你真的想做 2 或 3,不要禁用事件验证。

向 asp:listbox 客户端添加项目有两个主要问题。

  • 首先是它会干扰事件验证。返回到服务器的不是它发送下来的。

  • 第二个是即使您禁用事件验证,当您的页面被回发时,列表框中的项目将从视图状态中重建,因此您在客户端上所做的任何更改都将丢失。这样做的原因是 asp.net 不希望在客户端上修改列表框的内容,它只希望进行选择,因此它会丢弃您可能所做的任何更改。

最好的选择是最有可能使用推荐的更新面板。如果您确实需要在客户端执行此操作,另一种选择是使用普通的 old<select>而不是<asp:ListBox>,并将您的项目列表保存在隐藏字段中。当页面在客户端上呈现时,您可以从文本字段内容的拆分中填充它。

然后,当您准备好发布它时,您从修改后的 .xml 文件中重新填充隐藏字段的内容<select>。然后,当然,你必须在服务器上再次拆分它并对你的项目做一些事情,因为你的选择现在是空的,现在它又回到了服务器上。

总而言之,这是一个非常麻烦的解决方案,我不会真正推荐,但如果您真的必须对 listBox 进行客户端修改,它确实有效。但是,我真的建议您在走这条路线之前先查看 updatePanel。

于 2008-10-29T01:35:13.610 回答
19

以上都不适合我。经过更多挖掘后,我意识到我忽略了导致问题的页面上应用的 2 个表单。

<body>
<form id="form1" runat="server">
<div>
        <form action="#" method="post" class="form" role="form">
        <div>
        ...
        <asp:Button ID="submitButton" runat="server"
        </div>
</div>
</body>

请注意,最近 ASP.NET 已开始考虑在表单标记中包含 iframe 文档中的表单标记的 iframe 本身就是一个嵌套框架。我不得不将 iframe 移出表单标签以避免此错误。

于 2016-04-19T16:39:49.527 回答
16

我在使用Repeater 时遇到了同样的问题,因为我在启用了EnableEventValidation 的网站中有一个带有Repeater 控件的网页。这不好。我收到了无效的回发相关异常。

对我有用的是为中继器设置 EnableViewState="false"。优点是使用起来更简单,就像关闭网站或网页的事件验证一样简单,但范围远小于关闭任何一个的事件验证。

于 2009-11-19T12:25:25.553 回答
13

在客户端上使用 JavaScript 修改 ListBox 时,我遇到了同样的问题。当您从客户端向 ListBox 添加在呈现页面时不存在的新项目时,会发生这种情况。

我找到的解决方法是通知事件验证系统所有可以从客户端添加的有效项目。您可以通过覆盖 Page.Render 并为您的 JavaScript 可以添加到列表框中的每个值调用 Page.ClientScript.RegisterForEventValidation 来执行此操作:

protected override void Render(HtmlTextWriter writer)
{
    foreach (string val in allPossibleListBoxValues)
    {
        Page.ClientScript.RegisterForEventValidation(myListBox.UniqueID, val);
    }
    base.Render(writer);
}

如果列表框有大量潜在的有效值,这可能会有点痛苦。在我的例子中,我在两个 ListBox 之间移动项目——一个具有所有可能的值,另一个最初是空的,但当用户单击按钮时,会用 JavaScript 中第一个值的子集填充。在这种情况下,您只需要遍历第一个 ListBox 中的项目并将每个项目注册到第二个列表框中:

protected override void Render(HtmlTextWriter writer)
{
    foreach (ListItem i in listBoxAll.Items)
    {
        Page.ClientScript.RegisterForEventValidation(listBoxSelected.UniqueID, i.Value);
    }
    base.Render(writer);
}
于 2011-10-13T06:25:29.507 回答
9

这里没有提到的另一种方法是继承 ListBox

IE。

public class ListBoxNoEventValidation : ListBox 
{
}

ClientEventValidation 关闭属性 System.Web.UI.SupportsEventValidation 如果您将其子类化,除非您明确将其重新添加,否则它将永远不会调用验证例程。这适用于任何控件,并且是我发现在逐个控件的基础上“禁用”它的唯一方法(即,不是页面级别)。

于 2011-02-28T15:56:41.163 回答
9

您在 .aspx 页面中尝试类似的操作

添加

EnableEventValidation="假"

您可以随时提出任何问题!

于 2015-08-18T05:46:01.653 回答
8

如果您通过客户端脚本填写 DropdownList,则在将表单提交回服务器之前清除列表;然后 ASP.NET 不会抱怨,安全性仍然存在。

要从 DDL 中选择数据,您可以将“OnChange”事件附加到 DDL 以在隐藏的 Input 或 Style="display: none;" 的文本框中收集值

于 2008-12-11T20:43:00.507 回答
7

3:我将网格列中的按钮类型从“PushButton”更改为“LinkBut​​ton”。有效!("ButtonType="LinkBut​​ton") 我认为如果您可以在其他情况下将按钮更改为其他控件,例如“LinkBut​​ton”,它将正常工作。

我希望我能投票给你,阿米尔(唉,我的代表太低了。)我只是遇到了这个问题,改变它就像我的 gridview 上的冠军一样。顺便说一句,我认为有效的代码是: ButtonType="Link"

我怀疑这是因为当您单击“编辑”时,您的编辑更改为“更新”和“取消”,然后在提交时又变回“编辑”。而这些不断变化的控制让 .net 感到不安。

于 2009-02-19T00:39:34.150 回答
7

(1) EnableEventValidation="false".......它对我不起作用。

(2) ClientScript.RegisterForEventValidation....它对我不起作用。

解决方案1:

在 GridView 中将 Button/ImageButton 更改为 LinkBut​​ton。有用。(但我喜欢 ImageButton)

研究:Button/ImageButton 和 LinkBut​​ton 使用不同的方法来回发

来源文章:

http://geekswithblogs.net/mahesh/archive/2006/06/27/83264.aspx

解决方案2:

在 OnInit() 中,输入类似这样的代码来设置 Button/ImageButton 的唯一 ID:

protected override void OnInit(EventArgs e) {
  foreach (GridViewRow grdRw in gvEvent.Rows) {

  Button deleteButton = (Button)grdRw.Cells[2].Controls[1];

  deleteButton.ID = "btnDelete_" + grdRw.RowIndex.ToString();           
  }
}

来源文章:

http://www.c-sharpcorner.com/Forums/Thread/35301/

于 2013-03-30T02:58:11.807 回答
6

我实现了一个嵌套的网格视图,我遇到了同样的问题。我使用了 LinkBut​​ton 而不是像这样的图像按钮:

在我有这样的专栏之前:

<asp:TemplateField ItemStyle-Width="9">
  <ItemTemplate>
 <asp:ImageButton ID="ImgBtn" ImageUrl="Include/images/gridplus.gif" CommandName="Expand"
                        runat="server" />
  </ItemTemplate>
</asp:TemplateField>

我已经换成这样了。

<asp:TemplateField>
<ItemTemplate>
     <asp:LinkButton  CommandName="Expand" ID="lnkBtn"  runat="server" ><asp:Image  ID="Img"  runat="server" ImageUrl="~/Images/app/plus.gif" /></asp:LinkButton>
      </ItemTemplate>
</asp:TemplateField> 
于 2011-04-21T12:34:03.750 回答
5

我有一个类似的问题,但我没有使用 ASP.Net 1.1,也没有通过 javascript 更新控件。我的问题只发生在 Firefox 上,而不是 IE(!)。

我在 PreRender 事件的 DropDownList 中添加了选项,如下所示:

DropDownList DD = (DropDownList)F.FindControl("DDlista");
HiddenField HF = (HiddenField)F.FindControl("HFlista");
string[] opcoes = HF.value.Split('\n');
foreach (string opcao in opcoes) DD.Items.Add(opcao);

我的“HF”(隐藏字段)的选项由换行符分隔,如下所示:

HF.value = "option 1\n\roption 2\n\roption 3";

问题是 HTML 页面在代表 DropDown 的“选择”选项上被破坏(我的意思是有换行符)。

所以我解决了我的问题,添加了一行:

DropDownList DD = (DropDownList)F.FindControl("DDlista");
HiddenField HF = (HiddenField)F.FindControl("HFlista");
string dados = HF.Value.Replace("\r", "");
string[] opcoes = dados.Split('\n');
foreach (string opcao in opcoes) DD.Items.Add(opcao);

希望这对某人有所帮助。

于 2010-11-14T16:05:19.640 回答
4

如果你改变UseSubmitBehavior="True"UseSubmitBehavior="False"的问题将得到解决

<asp:Button ID="BtnDis" runat="server" CommandName="BtnDis" CommandArgument='<%#Eval("Id")%>' Text="Discription" CausesValidation="True" UseSubmitBehavior="False" />
于 2011-02-20T07:37:17.533 回答
3

我遇到了同样的问题,我做了什么:

刚刚添加了一个条件if(!IsPostBack),它工作正常:)

于 2011-08-05T08:55:28.647 回答
3

此错误将在没有回发的情况下显示

添加代码:

If(!IsPostBack){

 //do something

}
于 2013-12-26T15:03:03.527 回答
2

Ajax UpdatePanel做到了,我认为这是最简单的方法,忽略了Ajax 回发开销。

于 2008-12-21T14:16:02.213 回答
2

在这种情况下,将 id 添加到网格的 RowDataBound 中的按钮。它会解决你的问题。

于 2009-05-05T12:55:11.183 回答
2

此问题的一个简单解决方案是在页面加载时使用IsPostBack检查。这将解决这个问题。

于 2010-01-13T04:58:10.597 回答
2

当我们将常规 ASPX 页面转换为内容页面时,我们遇到了同样的问题。

存在此问题的页面</form>在其中一个内容部分中有一个标签,因此在运行时呈现了两个表单结束标签,这导致了此问题。从页面中删除额外的表单结束标记解决了这个问题。

于 2011-02-17T18:56:26.710 回答
2

我知道这是一个超级古老的帖子。假设您正在调用您的应用程序,这是一个对我有用的想法:

  1. 在您的页面上实现 ICallbackEventHandler
  2. 调用 ClientScriptManager.GetCallbackEventReference 来调用你的服务器端代码
  3. 如错误消息所述,您可以调用 ClientScriptManager.RegisterForEventValidation

如果您不需要完全控制,您可以使用更新面板来为您执行此操作。

于 2011-10-21T18:50:37.267 回答
2

如果您使用的是 gridview 并且没有在 !ispostback 内的页面加载中绑定 gridview ,那么当您单击 gridview 中的编辑和删除行时会发生此错误。

 protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
        bindGridview();
        }
于 2018-03-22T11:46:25.517 回答
1

我正在使用 datalist,但我的按钮也出现了同样的错误。我只是使用 IsPostBack 检查并填写我的控件,问题就解决了!伟大的!!!

于 2010-03-08T13:49:03.900 回答
1

四分钟前我收到了同样的错误。然后我和你一样研究了一个半小时。在所有论坛中,他们通常说“添加页面 enableEvent..=false 或 true”。任何提出的解决方案都没有解决我的问题,直到我找到它。不幸的是,问题是一个 ASP.NET 按钮。我在两秒钟前删除了它。我试图用“imagebutton”替换,但这也是不可接受的(因为它给出了同样的错误)。

最后我换成了LinkButton. 它似乎正在工作!

于 2010-07-27T18:59:39.437 回答
1

对我有用的是将以下代码从 page_load 移动到 page_prerender:

lstMain.DataBind();
Image img = (Image)lstMain.Items[0].FindControl("imgMain");

// Define the name and type of the client scripts on the page.
String csname1 = "PopupScript";
Type cstype = this.GetType();

// Get a ClientScriptManager reference from the Page class.
ClientScriptManager cs = Page.ClientScript;

// Check to see if the startup script is already registered.
if (!cs.IsStartupScriptRegistered(cstype, csname1))
{
    cs.RegisterStartupScript(cstype, csname1, "<script language=javascript> p=\"" + img.ClientID + "\"</script>");
}
于 2010-10-14T21:35:27.863 回答
1

如果您使用的是 Ajax 更新面板。添加<Triggers>标签并在其中触发 Button 或控件导致 postBack 使用<asp:PostBackTrigger .../>

于 2011-05-04T12:50:57.253 回答
1

最好的选择是使用隐藏字段并且不禁用事件验证,还要更改每个列表框、下拉列表以使用 runat 服务器属性进行选择

于 2011-06-14T13:12:44.373 回答
1

如果您事先知道可以填充的数据,则可以使用 ClientScriptManager 来解决此问题。在以前的用户选择中使用 javascript 动态填充下拉框时,我遇到了这个问题。

下面是一些示例代码,用于覆盖渲染方法(在 VB 和 C# 中)并声明下拉列表 ddCar 的潜在值。

在 VB 中:

Protected Overrides Sub Render(ByVal writer As System.Web.UI.HtmlTextWriter)

    Dim ClientScript As ClientScriptManager = Page.ClientScript

    ClientScript.RegisterForEventValidation("ddCar", "Mercedes")

    MyBase.Render(writer)
End Sub

或 C# 中的细微变化可能是:

protected override void Render(HtmlTextWriter writer)
{
    Page.ClientScript.RegisterForEventValidation("ddCar", "Mercedes");
    base.Render(writer);
}

对于新手:这应该放在文件后面的代码中(.vb 或 .cs),或者如果在 aspx 文件中使用,您可以用<script>标签包装。

于 2012-12-19T09:50:41.753 回答
1

这就是我得到它的原因:

我有一个 ASP:ListBox。最初它是隐藏的。在客户端,我将通过 AJAX 使用选项填充它。用户选择了一个选项。然后,当单击提交按钮时,服务器会对 ListBox 感到很有趣,因为它不记得它有任何选项。

所以我所做的是确保在将表单提交回服务器之前清除所有列表选项。这样服务器就不会抱怨,因为列表到客户端是空的,然后又是空的。

排序!!!

于 2013-10-11T13:56:52.437 回答
1

正如尼克 B 所说,这对我有用,在某些情况下你必须删除换行符。看一下代码:

-错误的方法:

<asp:DropDownList ID="DropDownList1" runat="server">
    <asp:ListItem Selected="True">
            Item 1</asp:ListItem>
    <asp:ListItem>
            Item 2</asp:ListItem>
    <asp:ListItem>
            Item 3</asp:ListItem>
</asp:DropDownList>

-正确的方法:

<asp:DropDownList ID="DropDownList1" runat="server">
    <asp:ListItem Selected="True">Item 1</asp:ListItem>
    <asp:ListItem>Item 2</asp:ListItem>
    <asp:ListItem>Item 3</asp:ListItem>
</asp:DropDownList>

它只发生在 IE10+ 中

于 2015-07-02T14:48:44.513 回答
1

在远程服务器(生产、测试​​、qa、登台等)上出现此问题后,但在本地开发工作站上没有出现此问题后,我发现应用程序池配置的 RequestLimit 不是 0。

这导致应用程序池放弃并回复问题中提到的异常。

于 2016-03-23T15:07:28.690 回答
1

对我们来说,问题只是在生产环境中随机发生。RegisterForEventValidation 对我们没有任何帮助。

最后,我们发现在运行 asp.net 应用程序的网络场中,两台 IIS 服务器安装了不同的 .net 版本。所以看起来他们有不同的加密 asp.net 验证哈希的规则。更新它们解决了大部分问题。

另外,我们在两台服务器的 web.config 中配置了 machineKey(compatibilityMode)(两台服务器相同)、httpRuntime(targetFramework)、ValidationSettings:UnobtrusiveValidationMode、pages(renderAllHiddenFieldsAtTopOfForm)。

我们使用此站点生成密钥https://www.allkeysgenerator.com/Random/ASP-Net-MachineKey-Generator.aspx

我们花了很多时间解决这个问题,我希望这对某人有所帮助。

<appSettings>
   <add key="ValidationSettings:UnobtrusiveValidationMode" value="None" />
...
</appSettings>
<system.web>
   <machineKey compatibilityMode="Framework45" decryptionKey="somekey" validationKey="otherkey" validation="SHA1" decryption="AES />
   <pages [...] controlRenderingCompatibilityVersion="4.0" enableEventValidation="true" renderAllHiddenFieldsAtTopOfForm="true" />
   <httpRuntime [...] requestValidationMode="2.0" targetFramework="4.5" />
...
</system.web>
于 2019-06-19T13:35:02.520 回答
0

我通过不将 ListBox 添加到父 Page/Control Controls 集合来解决这个确切的错误。因为我真的不需要任何服务器端功能。我只是想用它来输出自定义服务器控件的 HTML,这是我自己在 OnRender 事件处理程序中完成的。我希望使用该控件可以使我免于将自己的 html 写入响应。

此解决方案可能对大多数人不起作用,但它使 ASP.NET 无法对控件执行 ValidateEvent,因为控件在回发之间不会保留在内存中。

此外,我的错误特别是由于所选列表项是上一次回发时不在列表框中的项目。万一这对任何人都有帮助。

于 2009-04-23T22:22:51.670 回答
0

当我在 ItemDataBound 上添加 id 时,它没有给我错误,但它没有给我命令名称。它返回的命令名称为空。然后我在 ItemDataBound 时也添加了命令名称。然后它解决了同样的问题。谢谢尼莱什,很好的建议。有效 :)

于 2009-10-01T20:56:13.677 回答
0

我有同样的问题,两个列表框和两个按钮。

列表框中的数据是从数据库中加载的,您可以通过单击按钮在框之间移动项目。

我收到了无效的回发。

结果是数据中有回车换行符,当显示在列表框中时您看不到。

在除 IE 10 和 IE 11 之外的所有浏览器中都能正常工作。

删除回车换行符,一切正常。

于 2013-11-06T16:04:03.643 回答
0

仅供参考,我对该错误消息有同样的问题,那就是我在同一页面上有 2 个表单标签。母版页中有一个,页面本身中有一个。当我删除第二个表单标签对后,问题就消失了。

于 2015-03-11T17:12:10.173 回答
0

下面的示例演示如何在加载页面时测试 IsPostBack 属性的值,以确定页面是第一次呈现还是响应回发。如果页面是第一次呈现,代码将调用 Page.Validate 方法。页面标记(未显示)包含RequiredFieldValidator 控件,如果没有为必填输入字段输入任何条目,这些控件会显示星号。调用 Page.Validate 会导致在呈现页面时立即显示星号,而不是等到用户单击“提交”按钮。回发后,您不必调用 Page.Validate,因为该方法是作为 Page 生命周期的一部分调用的。

 private void Page_Load()
    {
        if (!IsPostBack)
        {      
        }
    }
于 2017-02-21T00:40:55.077 回答
0

在服务器端的网格事件结束时取消事件时,我的问题得到了解决。

protected void grdEducation_RowEditing(object sender, GridViewEditEventArgs e)
{
  // do your processing ...

  // at end<br />
  e.Cancel = true;
}
于 2018-08-21T14:49:23.167 回答
-1

检查您绑定控件的数据。一些无效数据损坏了 ValidateEvent。

于 2010-09-23T08:32:02.173 回答