首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使多用户登录页面代码更简单?

如何使多用户登录页面代码更简单?
EN

Stack Overflow用户
提问于 2014-03-17 18:19:28
回答 2查看 7.7K关注 0票数 1

在VB.NET项目中,我正在尝试创建一个用户可以使用表单登录的登录页面。我使用一个数组来保存登录信息。但是,在验证时它很复杂,因此我不能简单地通过向数组添加项来添加用户。我需要在代码中添加一个else if,所以这非常不方便。

代码如下:

代码语言:javascript
复制
Private Sub OK_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles OK.Click
    Dim UserNameAvailable As Integer = 0
    Dim UsernameList(2) As String
    Dim PasswordList(2) As String
    UsernameList(0) = "jamiechoi"
    PasswordList(0) = "198237645"
    UsernameList(1) = "marcoyeung"
    PasswordList(1) = "infotalkong"
    UsernameList(2) = "user"
    PasswordList(2) = "toolbox"
    Dim InputUsername As String
    InputUsername = UsernameTextBox.Text
    Dim InputPassword As String
    InputPassword = PasswordTextBox.Text
    If InputUsername = UsernameList(0) Then
        If InputPassword = PasswordList(0) Then
            Me.Hide()
            AdminArea.Show()
            UserNameAvailable = 1
        Else
            MsgBox("Wrong Password!")
            UserNameAvailable = 1
        End If
    ElseIf InputUsername = UsernameList(1) Then
        If InputPassword = PasswordList(1) Then
            Me.Hide()
            AdminArea.Show()
            UserNameAvailable = 1
        Else
            MsgBox("Wrong Password!")
            UserNameAvailable = 1
        End If
    ElseIf InputUsername = UsernameList(2) Then
        If InputPassword = PasswordList(2) Then
            Me.Hide()
            AdminArea.Show()
            UserNameAvailable = 1
        Else
            MsgBox("Wrong Password!")
            UserNameAvailable = 1
        End If
    End If

    If UserNameAvailable = 0 Then
        MsgBox("Wrong Username!")
    End If
End Sub

我希望我可以使用for循环来完成验证任务。我能做什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-04-13 11:45:51

很抱歉这么晚才回复(并且没有接受答案),因为答案的结果出乎意料。

这是我期望的解决方案:

(类似于)

代码语言:javascript
复制
For i As Integer = 1 To UsernameList.Length
    If InputUsername = UsernameList(i) AndAlso InputPassword = PasswordList(i) Then
        Me.Hide()
        AdminArea.Show()
    End If
Next

这就是我的解决方案。

票数 1
EN

Stack Overflow用户

发布于 2019-01-04 06:47:25

下面是我对代码的一点修改:

代码语言:javascript
复制
For i As Integer = 0 To UsernameList.Length - 1
    If InputUsername = UsernameList(i) AndAlso InputPassword = PasswordList(i) Then
        Me.Hide()
        AdminArea.Show()
    End If
Next
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22451723

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档