将无效的QueryStringParameter重定向到LinqDataSource

本文关键字:LinqDataSource 重定向 QueryStringParameter 无效 | 更新日期: 2023-09-27 17:59:29

我有以下LinqDataSource:

<asp:LinqDataSource ID = "agreementDs"
                    ContextTypeName = "AdministrationDataContext"
                    TableName = "Agreements"
                    runat = "server"
                    EnableUpdate = "true"                        
                    Where = "AgreementId=@AgreementId">
    <WhereParameters>
        <asp:QueryStringParameter QueryStringField = "AgreementId" 
                                  Name = "AgreementId"
                                  Type = "Int32"
                                  DefaultValue = "-1" />
    </WhereParameters>                        
</asp:LinqDataSource>    

它应该从协议数据库表中获取一行。我如何检测参数AgreementId是否为-1,如果是,则提供404页面或将用户重定向到我网站的首页?我不知道在后面的代码中插入这个逻辑的正确位置是什么。

更新:只有当AgreementId参数为-1时,才应该重定向用户。当数据源不包含任何行时,应该总是发生这种情况。

将无效的QueryStringParameter重定向到LinqDataSource

在LINQ数据源中添加一个"OnSelecting"方法名,然后从该方法中检查您需要的任何内容:

<asp:LinqDataSource runat="server" OnSelecting="ldsSelecting" .... />
protected void ldsSelecting(object o, LinqDataSourceSelectEventArgs e)
{
     // check for query string or other stuff here, redirect if needed
}