我有一个文本框,用户输入连接到其帐户的代码。然后,它将显示欢迎消息,代替他们输入信息的文本框。它曾经工作,直到我为它添加更多代码来查询另一个数据库。这最终弄乱了我的页面,因为我删除了那些代码,我一定忘记了某些东西,或者我的代码可能一开始就很麻烦....但现在我的欢迎信息总是错误的人的名字。事实上,无论您输入什么代码,它都会显示相同的人名。这个人甚至没有数据库中的代码。我尝试添加IS NOT NULL
和IS LIKE 'B%'
,以便它不显示该人的姓名,但它没有帮助。
当我在SQL Server中执行查询时,我得到了我想要的结果。有人可以帮我找出我的页面不允许显示名称的问题吗?当我调试时,GetAccountName显示它已经获取了正确的用户名并将其放入Session变量中。
当它返回自定义验证器时,lblIB.Text永远不会获取显示欢迎消息的信息,因此它只抓取数据库中的第一件事,这总是错误的。
<%@ Master Language="VB" CodeFile="MasterPage.master.vb" Inherits="MasterPage" %>
<div id="ib">
<asp:Label ID="IBText" runat="server" Text="Enter your IB code here:"></asp:Label>
<asp:TextBox ID="IBTextBox" runat="server"></asp:TextBox>
<asp:Button ID="IBTextBoxButton" runat="server" Text="Submit" />
<asp:CustomValidator ID="CustomValidator1" runat="server" ControlToValidate="IBTextBox" ForeColor="Red" OnServerValidate="CustomValidator1_ServerValidate"></asp:CustomValidator>
<asp:Label ID="lblIB" runat="server" Text=""></asp:Label>
</div><!-- end ib div -->
Imports System.Data
Imports System.Data.SqlClient
Partial Class MasterPage
Inherits System.Web.UI.MasterPage
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
Dim ib As String = String.Empty
If Not IsPostBack Then
If Request.QueryString("IB") IsNot Nothing Then
ib = Request.QueryString("IB")
Session("IB") = True
End If
If Session("IB") Is Nothing Then
'show textbox
IBText.Visible = True
IBTextBox.Visible = True
IBTextBoxButton.Visible = True
Else
'call function
GetSessionValues(ib)
End If
End If
End Sub
Protected Function GetSessionValues(ByVal Code As String) As Boolean
Dim FirstName As String = String.Empty
Dim LastName As String = String.Empty
If GetAccountName(Code, FirstName, LastName) Then
'set session variables
Session("First_Name") = FirstName
Session("Last_Name") = LastName
'hide textbox
IBText.Visible = False
IBTextBox.Visible = False
IBTextBoxButton.Visible = False
'args.IsValid = True
'show welcome message to user if IB code exists in database
lblIB.Visible = True
lblIB.Text = "Welcome, " + Session("First_Name") + " " + Session("Last_Name") + "."
Return True
Else
'IB code not found
'args.IsValid = False
'shows error message in red
lblIB.ForeColor = Drawing.Color.Red
lblIB.Text = "Account not found, please try again."
Return False
End If
End Function
Private Function GetAccountName(ByVal BAccount As String, ByRef FirstName As String, ByRef LastName As String) As Boolean
'sql statement for baccount information
Dim sql As String = "SELECT BAccount, First_Name, Last_Name
FROM IB
INNER JOIN IB_BUISNESS_INFORMATION ON (IB.IB_ID = IB_BUISNESS_INFORMATION.IB_ID)
WHERE BAccount = @BAccount"
Using conn As New SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings("IBConnectionString").ConnectionString)
Using cmd As New SqlCommand(sql, conn)
cmd.Parameters.AddWithValue("@BAccount", BAccount)
conn.Open()
Using rdr As SqlDataReader = cmd.ExecuteReader
If (rdr.Read) Then
FirstName = rdr("First_Name").ToString()
LastName = rdr("Last_Name").ToString()
Return True
Else
Return False
End If
End Using
End Using
End Using
End Function
Protected Sub CustomValidator1_ServerValidate(ByVal source As Object, ByVal args As System.Web.UI.WebControls.ServerValidateEventArgs) Handles CustomValidator1.ServerValidate
'declare variables
Dim FirstName As String = String.Empty
Dim LastName As String = String.Empty
If (Not GetSessionValues(args.Value)) Then
args.IsValid = False
Else
args.IsValid = True
End If
If GetAccountName(args.Value, FirstName, LastName) Then
'set session variables
Session("First_Name") = FirstName
Session("Last_Name") = LastName
'hide textbox
IBText.Visible = False
IBTextBox.Visible = False
IBTextBoxButton.Visible = False
args.IsValid = True
'show welcome message to user if IB code exists in database
lblIB.Visible = True
lblIB.Text = "Welcome, " + Session("First_Name") + " " + Session("Last_Name") + "."
Else
'IB code not found
args.IsValid = False
'shows error message in red
lblIB.ForeColor = Drawing.Color.Red
lblIB.Text = "Account not found, please try again."
End If
End Sub
Protected Sub IBTextBoxButton_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles IBTextBoxButton.Click
If Page.IsValid Then
'declare variables
Dim LSD As String = String.Empty
Dim LSC As String = String.Empty
Session("IB") = IBTextBox.Text
Dim IB As String = Session("IB")
'add session variable
If GetCompanyName(LSD) Then
Session("LSD") = LSD
Else
'no data found
End If
'add session variable
If GetWebsite(LSC) Then
Session("LSC") = LSC
Else
'no data found
End If
Response.Redirect(Request.RawUrl)
End If
End Sub
答案 0 :(得分:1)
删除以下代码行。如果GetAccountName像你说的那样工作,它将解决你的问题。
Response.Redirect(Request.RawUrl)
答案 1 :(得分:0)
在所有页面的IsPostBack
事件中使用pageload
方法,并在页面加载事件结束时关闭在每个页面上创建的所有会话变量。