Java实现简单登陆界面

利用Java连接MySQL做登陆界面,供大家参考,具体内容如下

1、首先需要建立一个类,在这里,我命名为newLogin

newLogin类的代码如下

package p4;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.swing.ButtonGroup;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPasswordField;
import javax.swing.JRadioButton;
import javax.swing.JTextField;
public class newLogin extends JFrame implements ActionListener{
    private static final long serialVersionUID = 1L;
    private Connection con = null;
    private Statement statement = null;
    private ResultSet res = null;
    private ButtonGroup buttongroup = new ButtonGroup();
    private MyPanel jp = new MyPanel();
    private JLabel ul = new JLabel("用户名:");
    private JLabel pl = new JLabel("密    码:");
    private JLabel ts = new JLabel("");
    private JTextField uname = new JTextField();
    private JPasswordField pword = new JPasswordField();
    private JRadioButton[] butArray = {
            new JRadioButton("学生",true),
            new JRadioButton("教师")
    };
    private JButton login = new JButton("登陆");
    private JButton reset = new JButton("重置");
    public newLogin() {
        addListener();
        initialFrame();
    }
    private void initialFrame() {
        Font font = new Font("宋体",Font.BOLD,12);
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setTitle("登陆");
        jp.setLayout(null);
        ul.setBounds(100, 30, 60, 30);
        jp.add(ul);
        uname.setBounds(170, 30, 140, 30);
        jp.add(uname);
        pl.setBounds(100, 80, 60, 30);
        pword.setBounds(170, 80, 140, 30);
        jp.add(pl);
        jp.add(pword);
        ts.setBounds(100, 160, 200, 50);
        jp.add(ts);
        ts.setFont(font);
        login.setBounds(100, 220, 70, 30);
        jp.add(login);
        login.setFont(font);
        reset.setBounds(220, 220, 70, 30);
        jp.add(reset);
        reset.setFont(font);
        add(jp);
        setResizable(false);
        buttongroup.add(butArray[0]);
        buttongroup.add(butArray[1]);
        butArray[0].setBounds(120, 130, 100, 50);
        jp.add(butArray[0]);
        butArray[1].setBounds(220, 130, 100, 50);
        jp.add(butArray[1]);
        butArray[0].setContentAreaFilled(false);
        butArray[1].setContentAreaFilled(false);
        Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
        int centerX = screenSize.width/2;
        int centerY = screenSize.height/2;
        int w = 427;
        int h = 331;
        setBounds(centerX-w/2, centerY-h/2, w, h);
        setVisible(true);
        uname.requestFocus(true);
        getContentPane().add(jp);
        jp.getRootPane().setDefaultButton(login);
    }
    private void addListener() {
        this.login.addActionListener(this);
        this.uname.addActionListener(this);
        this.pword.addActionListener(this);
    }
    @Override
    public void actionPerformed(ActionEvent e) {
        if(e.getSource() == uname) {
            pword.requestFocus();
        }
        if(e.getSource() == pword) {
            butArray[0].requestFocus();
        }
        if(e.getSource() == butArray[0]||e.getSource() == butArray[1]||e.getSource() == login) {
//            this.ts.setText("正在为您努力加载,请稍等......");
            
            int type = this.butArray[0].isSelected()?0:1;
            String username = this.uname.getText().trim();
            char[] p = this.pword.getPassword();
            String password = String.valueOf(p).trim();
            if(username.equals("")) {
                JOptionPane.showMessageDialog(this, "请输入用户名!","错误",JOptionPane.ERROR_MESSAGE);
                ts.setText("");
                return ;
            }
            if(password.equals("")) {
                JOptionPane.showMessageDialog(this, "请输入密码!","错误",JOptionPane.ERROR_MESSAGE);
                ts.setText("");
                return ;
            }
            try {
                con = new connection().getConnection();  //调用自己写的一个数据库连接类
                statement = con.createStatement();
                if(type == 0) {
                    String sql = "select * from stuuser where "+
                        "username_stu='"+username+"'and password_stu='"+password+"'";
                    res = statement.executeQuery(sql);
                    if(res.next()) {
                        JOptionPane.showMessageDialog(this, "登录成功!","提示",JOptionPane.INFORMATION_MESSAGE);
                        this.dispose();
                    }
                    else {
                        JOptionPane.showMessageDialog(this, "用户名或密码错误!","错误",JOptionPane.ERROR_MESSAGE);
                        ts.setText("");
                        uname.setText("");
                        pword.setText("");
                    }
                    //关闭数据库连接
                    if(res != null) {
                        res.close();
                    }
                    if(statement != null) {
                        statement.close();
                    }
                    if(con != null) {
                        con.close();
                    }
                }
                else {
                    String sql = "select * from teauser where "+
                            "username_tea='"+username+"'and password_tea='"+password+"'";
                        res = statement.executeQuery(sql);
                        if(res.next()) {
                            String spec_name = res.getString(1);
                            JOptionPane.showMessageDialog(this, "登录成功!","提示",JOptionPane.INFORMATION_MESSAGE);
                            this.dispose();
                        }
                        else {
                            JOptionPane.showMessageDialog(this, "用户名或密码错误!","错误",JOptionPane.ERROR_MESSAGE);
                            ts.setText("");
                            uname.setText("");
                            pword.setText("");
                        }
                        //关闭数据库连接
                        if(res != null) {
                            res.close();
                        }
                        if(statement != null) {
                            statement.close();
                        }
                        if(con != null) {
                            con.close();
                        }
                }
            }catch(SQLException ea) {
                ea.printStackTrace();
            }
        }
        else if(e.getSource() == reset) {
            uname.setText("");
            pword.setText("");
        }
    }
}

2、编写数据库连接类,在这里命名为connection,然后在类里写一个获取连接的放回,并返回一个连接。

connection类的代码如下:

package p4;

import java.sql.Connection;
import java.sql.DriverManager;
//import java.sql.ResultSet;
import java.sql.SQLException;
//import java.sql.Statement;

public class connection {
    private Connection con = null;
//    private Statement statement = null;
//    private ResultSet res = null;
    String driver = "com.mysql.cj.jdbc.Driver";
    String url  = "jdbc:mysql://localhost:3306/Stu_manager?serverTimezone=Asia/Shanghai";
    String name = "root";
    String passwd = "123456";
    public connection() {
        
    }
    public Connection getConnection() {
        try{
            Class.forName(driver).newInstance();
            con = DriverManager.getConnection(url,name,passwd);
            }catch(ClassNotFoundException e){
                System.out.println("对不起,找不到这个Driver");
                e.printStackTrace();
            }catch(SQLException e){
                
                e.printStackTrace();
            }catch(Exception e){
                e.printStackTrace();
            }
        return con;
    }
}

3、在MySQL数据库中需建立两个用户表,分别用来存储不同用户的登陆账号和密码,这里学生用户表为stuuser,教师用户表为teauser,建表的SQL语句如下:

stuuser表:

create table stuuser(
    username_stu varchar(20) primary key,
    password_stu char(20) not null,
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

teauser表:

create table teauser(
    username_tea varchar(20) primary key,
    password_tea char(20) not null,
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • java图形化界面实现登录窗口

    登录窗口一般很常见,现在让我们自己也来写一个吧! PS:很多import是重复的,是因为我是分了几个类写的,必须单独导入 //模拟qq登录窗口 import java.awt.*; import java.io.*; import java.awt.event.*; import javax.swing.*; public class QQGUI extends JFrame implements ActionListener{ private JLabel userLa; private JL

  • Java web过滤器验证登录防止未登录进入界面

    今天用ssh2写了个简单的系统,发现了一个问题,我这系统必须先登录成功才能进入主页,但我在浏览器里直接输入主页地址,发现也能进入,这个肯定不好,毫无安全性可言,后经查资料发现需要登录过滤器,就试了下,发现果然可以避免未经登录即可进入主页的危险,下面是我整理出的详细步骤: 1.首先写一个权限过滤filter类,实现Filter接口 import java.io.IOException; import javax.servlet.Filter; import javax.servlet.Filter

  • 使用java swing实现qq登录界面示例分享

    用Java Swing做的一个QQ登录界面 复制代码 代码如下: import java.awt.Container;import java.awt.Image;import java.awt.event.ActionEvent;import java.awt.event.ActionListener; import javax.swing.ImageIcon;import javax.swing.JButton;import javax.swing.JCheckBox;import javax

  • java实现简单QQ登录界面

    本文实例为大家分享了java实现简单QQ登录界面的具体代码,供大家参考,具体内容如下 java在图形界面,不是太强项,但不是不可以做,它的开源是very nice! 实现代码如下(想实现完美的界面,可能要更多coding的支持): package com.ts.x.swing; import java.awt.Color; import java.awt.Container; import java.awt.Cursor; import java.awt.Font; import java.aw

  • java模仿实现QQ登录界面

    本文实例为大家分享了java模仿实现qq登录界面的具体代码,供大家参考,具体内容如下 这是我模仿QQ2015版界面,实现的基本功能有登陆验证,重置等,当然直接复制代码运行是不一样的,还要注意自己插入自己的图片. 结果截图如下所示: 代码: import java.awt.BorderLayout; import java.awt.Color; import java.awt.FlowLayout; import java.awt.GridLayout; import java.awt.Image

  • Java Swing仿QQ登录界面效果

    本文实例为大家分享了Java Swing仿QQ登录界面展示的具体代码,供大家参考,具体内容如下 闲来无事将早些时候已实现的QQ登录界面再实现了一遍,纯手工打造(意思是没有用NetBeans.MyEclipse的拖动功能). 源代码如下: package ibees.qq; import java.awt.BorderLayout; import java.net.URL; import javax.swing.ImageIcon; import javax.swing.JButton; impo

  • java代码块之简易qq登录界面及按钮颜色设置代码

    本文主要分享了关于简洁版qq登录界面及按钮颜色设置的相关代码,供参考. java代码块 公共包(初始化窗口位置) package util; import java.awt.Dimension; import java.awt.Toolkit; import javax.swing.JFrame; //图形化界面的工具类 public class FrameUtil { //设置窗体出现在中间位置 public static void initFrame(JFrame frame,int wid

  • java通过JFrame做一个登录系统的界面完整代码示例

    在java的JFrame内通过创建匿名对象的方式做登录界面 package com.sxt; import java.awt.Container; import java.awt.GridLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.J

  • java语言图形用户登录界面代码

    本文实例为大家分享了java登录界面的具体实现代码,供大家参考,具体内容如下 1. Login.java package wzb; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.Panel; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.e

  • Java实现简单登陆界面

    利用Java连接MySQL做登陆界面,供大家参考,具体内容如下 1.首先需要建立一个类,在这里,我命名为newLogin newLogin类的代码如下 package p4; import java.awt.Dimension; import java.awt.Font; import java.awt.Toolkit; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql

  • java实现简单登录界面的实战过程

    目录 一.概要 二.分类部分 三.代码实现 总结 一.概要 我们可以用java实现简单的登录界面. 如上效果,直观但也需要一步一步来完成,从界面弹窗的设置,图片的插入,文本框的设置,到登录的按钮,全由代码来实现. 二.分类部分 LoginUI类:实现界面的设置,构建方法,封装好所有的界面开发代码 ①initUI方法 :1.创建窗体对象: 2.设置窗体的相关属性(标题.尺寸.大小.关闭.可视化): 3.创建组件对象,按钮,输入框: 4.界面窗口添加按钮: 5.按钮添加监听器. ②main方法 :用

  • Java实现简单图形界面计算器

    前言 因为这两天我们的Java实验课程需要做两个小的图形化界面,其中就有一个图形界面的计算器,所以稍微花了点时间做了一个,同时复习了一下Java的基础内容和GUI编程.因为代码中的注释特别详细,所以这里就不讲解怎么实现的了. 代码 package zuoye; import javax.swing.*; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; impor

  • Java实现简单无界面五子棋

    本文项目为大家分享了Java实现无界面五子棋的具体代码,供大家参考,具体内容如下 项目介绍: 本次设计是基于知识点Java类和对象以及数组开发的一个小型五子棋游戏程序.游戏开始时,选择黑棋.白棋开局,将一枚棋子落在棋盘一坐标上,然后轮番落子,如此轮流下子,直到某一方首先在棋盘的竖.横或两斜四方向上的五子连成线,则该方该局获胜. 项目实现思路: 1.棋盘设计为10*10格,棋盘类型Chess[][] 二维数组,所含属性String chessType; 棋盘首先chessType值是””.2.初始

  • Java实现简单的日历界面

    本文实例为大家分享了Java实现简单日历界面的具体代码,供大家参考,具体内容如下 请使用JFrame.JPanel.JButton.JLabel和不同的布局管理器,实现如下日历视图. import java.awt.*; import javax.swing.*; public class Main {     public static void main(String[] args) {         JFrame frame = new JFrame("calendar");

  • Java实现简单GUI登录和注册界面

    本文实例为大家分享了Java实现简单GUI登录和注册界面的具体代码,供大家参考,具体内容如下 先看效果图: 登陆界面: 注册界面: 实现代码如下: 一.登陆界面 package cn.bms.view; import java.awt.Color; import java.awt.Dimension; import java.awt.Font; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; imp

  • Java 模拟cookie登陆简单操作示例

    本文实例讲述了Java 模拟cookie登陆简单操作.分享给大家供大家参考,具体如下: 最近在做将禅道上的功能接口做到手机端,在做登陆的时候,看了禅道的源码,是由cookie来登陆,所以要做一个模拟cookie登陆的接口,将拿到的cookie放到每次接口请求的头部中去,就可以正常访问了. import java.io.OutputStreamWriter; import java.net.HttpURLConnection; import java.net.URL; /** * @Author:

  • Java实现简单抽奖功能界面

    本文实例为大家分享了Java实现简单抽奖功能的具体代码,供大家参考,具体内容如下 要求:定义文本框添加姓名,将姓名存储并且在界面中可见,点击抽奖按钮进行抽奖并输出最后的中奖得主. 关于抽奖当然需要用到随机数的生成函数,在Java中Random 的使用合适比较简单的: 有两种不同的Random方法的使用,其中一种是Math中的random. 该方法生成的是0-1之间的浮点数,如果要生成整数类型的数字,可以乘一个整数,强制转换为整数类型. int n = (int)(Math.random()*x)

  • java的GUI实现简单切换界面

    本文实例为大家分享了java GUI实现简单切换界面的具体代码,供大家参考,具体内容如下 1.关于java的GUI简单切换界面 在刚开始学习java的gui界面设计的时候因为课本上没有相关切换界面的介绍,所以如何进行简单的一个界面切换困扰了我很久.因此我上网看了一些代码,却发现网上的大多数代码都很繁琐,仔细看下去感觉有许多冗余,虽然那些代码达到了切换界面的目的,但也有其它一些我暂时用不上的功能.简而言之,就是网上这部分的代码不够精简.于是我开始单单把这一简单的功能剥离出来.废话不多说还是先上代码

随机推荐