繁体   English   中英

用户从应用程序登录数据库

[英]User login to database from application

这个人一直困扰着我,我一生都无法弄清楚:

我必须让我的应用程序收集用户的输入,作为登录数据库的一种方式。 我的问题是,根据代码,实际上仅允许第一个用户进入。 我究竟做错了什么?

for(int i=0;i<numRows;i++)
        {
            String Usernames = rs.getString("Username");
            String Password = rs.getString("Password");
            String getAcc = rs.getString("UserType");
            rs.next();
            if(Usernames.trim().equals(UsernameIn)&&Password.trim().equals(PasswordIn))
            {
                start.writeToFile("ConToDatabase Class|Username: "+UsernameIn+" and Password: "+PasswordIn+" Accepted");
                if(getAcc.trim().equals("admin"))
                {
                    start.writeToFile("ConToDatabase Class|Authenticated user identified as \"admin\", Entering AdminUser Class|UTypeAdmin Method");
                    clear();
                    AdminUser.UTypeAdmin(args, UsernameIn, rs, dbTable(), path);
                }
                if(getAcc.trim().equals("standard"))
                {
                    start.writeToFile("ConToDatabase Class|Authenticated user identified as \"standard\", Entering StandardUser Class|UTypeStandard Method");
                    clear();
                    StandardUser.UTypeStandard(args, UsernameIn, rs, dbTable(),path);
                }
            }
            else
            {
                start.writeToFile("ConToDatabase Class|User invalid, reset application");
                System.out.println("Invalid User, Resetting...");
                Thread.sleep(2000);
                ConToDatabase.clearandreset(args);
            }
        }

我认为问题出在ELSE块中的代码。

您要先测试所有用户,然后说该用户无效。

对于第一个用户,您不会遇到问题,因为您只到达了IF块代码,但是与所有其他用户一起,您将至少经过一次ELSE块。

您可以执行以下操作:

boolean founded = false;
for(int i=0;i<numRows;i++)
{
    String Usernames = rs.getString("Username");
    String Password = rs.getString("Password");
    String getAcc = rs.getString("UserType");
    rs.next();

    if(Usernames.trim().equals(UsernameIn)&&Password.trim().equals(PasswordIn))
    {
        founded = true;
        start.writeToFile("ConToDatabase Class|Username: "+UsernameIn+" and Password: "+PasswordIn+" Accepted");

        if(getAcc.trim().equals("admin"))
        {
            start.writeToFile("ConToDatabase Class|Authenticated user identified as \"admin\", Entering AdminUser Class|UTypeAdmin Method");
            clear();
            AdminUser.UTypeAdmin(args, UsernameIn, rs, dbTable(), path);
        }

        if(getAcc.trim().equals("standard"))
        {
            start.writeToFile("ConToDatabase Class|Authenticated user identified as \"standard\", Entering StandardUser Class|UTypeStandard Method");
            clear();
            StandardUser.UTypeStandard(args, UsernameIn, rs, dbTable(),path);
        }
    }
}

if(!founded)
{ 
  start.writeToFile("ConToDatabase Class|User invalid, reset application");
  System.out.println("Invalid User, Resetting...");
  Thread.sleep(2000);
  ConToDatabase.clearandreset(args);
}

您也要注意答案中的评论。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM