Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/316.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 创建多用户访问登录表单_Java_Forms_Swing_Login_Jframe - Fatal编程技术网

Java 创建多用户访问登录表单

Java 创建多用户访问登录表单,java,forms,swing,login,jframe,Java,Forms,Swing,Login,Jframe,我已经为我创建的系统创建了一个登录表单。目前我只有一个用户访问登录,这意味着整个系统只有一个登录。 这是我想做的,我想有多个用户登录,如医生,护士,管理员。还应该有一些限制,例如,如果用户以医生或护士身份登录,用户只能查看其详细信息,如果用户以管理员身份登录,则用户可以访问系统中的任何部分 以下是我迄今为止所做的工作:- private void btnenterActionPerformed(java.awt.event.ActionEvent evt) {

我已经为我创建的系统创建了一个登录表单。目前我只有一个用户访问登录,这意味着整个系统只有一个登录。 这是我想做的,我想有多个用户登录,如医生,护士,管理员。还应该有一些限制,例如,如果用户以医生或护士身份登录,用户只能查看其详细信息,如果用户以管理员身份登录,则用户可以访问系统中的任何部分

以下是我迄今为止所做的工作:-

private void btnenterActionPerformed(java.awt.event.ActionEvent evt) {                                         

    String password=new String (txtpassword.getPassword()); //method to get the password from password field
    String username=txtusername.getText();
    if(username.equals("admin") && password.equals("admin123"))
    {

        JOptionPane.showMessageDialog(frame,"Welcome to the System","WELCOME",JOptionPane.INFORMATION_MESSAGE);
    Main_menu enter=new Main_menu();

    enter.setVisible(true);
    close();
    }
    else
    {
        JOptionPane.showMessageDialog(frame,"Wrong username/password","Invalid username or password",JOptionPane.ERROR_MESSAGE);
    }


} 
我可以使用相同的方法提供不同的访问登录,但我不能为用户设置访问级别,除非转到系统中的每个表单,使用“如果”条件并限制用户访问级别。 但这对我来说还不够有效,所以有没有其他更简单的方法呢


感谢您抽出时间

我相信通常您会创建一个身份验证功能,然后您只需在用户需要进行身份验证的任何地方调用该功能。或者,将所有受限制的函数分组到一组受限制的页面中,并在加载页面时调用身份验证是相当常见的,这样您就不必在每个表单上验证它。常用的方法之一是通过cookies。当用户登录时,您为他们设置cookie。受限制的页面调用检查以确保用户拥有该cookie,如果没有,则会重定向到登录页面


我不是Java开发人员,所以我无法告诉您这将是什么代码,但我相信这是PHP中的标准MO,而且我知道许多网站都喜欢使用Javascript设置cookie(这让我很失望)。

答案是thx,但我不确定cookie部分,因为在Java中,我不知道这样的方法。无论如何,谢谢。那么这似乎是一个本地应用程序?我假设这是一个web应用程序,或者至少有一些服务器通信。如果这是一个本地应用程序(请原谅,如果这在Java中不起作用,但我假设它会起作用),您应该能够创建一个包含“authenticatedLevel”变量的变量,该变量可能只是一个数字,并为每个用户级别分配一个数字。这样的硬编码密码通常被认为是不好的,比将用户名和密码存储在文件中要好,可能类似于Unix passwd文件(用户:hashedPass)