Java实现简单登陆界面
作者:我爱园园 发布时间:2022-11-25 05:47:47
标签: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;
来源:https://blog.csdn.net/yang_shuai_/article/details/85338669


猜你喜欢
- 1.修改主站点的elasticsearch.yml添加一下行:xpack.security.enabled: true2.生成安全秘钥切到E
- 使用视图引擎可以完成一些需要定制化内容格式的问题,比如邮件模板。引用install-package RazorEngine使用public
- 这篇文章主要介绍了SpringBoot项目没有把依赖的jar包一起打包的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一
- 直接贴代码: public class OSInfoMation { public static string OSBit() { try
- 音乐播放需要调用service,在此,只是简单梳理播放流程。public class PlayMusicService extends Se
- WPF 如何实现简单放大镜框架使用.NET40;Visual Studio 2019;实现此功能需要用到 VisualBrush&
- 依赖的jar包:spring相关jar包版本:4.3.1.RELEASE<dependency> &l
- 今天,给大家分享一个Java后端利用Phantomjs实现生成图片的功能,同学们使用的时候,可以参考下!PhantomJS简介首先,什么是P
- 本文实例为大家分享了Android画笔屏幕锁小程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下1.如果使用GestureOverlay
- 核心思想:“分”与“合”。主体流程先将一个序列分成很多个不能再分割的子序列,将各个子序列分别排序后再将子序列合并。其实就是重复两个步骤:【1
- 前言对象关系映射(ORM)已经被使用了很长时间,以解决在编程过程中对象模型与数据模型在关系数据库中不匹配的问题。Dapper是由Stack
- Java调用接口获取json数据保存到数据库今天给大家带来一个调用接口,来获取数据解析后再保存到数据库中的业务,业务中的Mapper和实体类
- /// <summary>/// 固定长度的随机字符串/// </summary>/// <param nam
- 前言但是在实际业务场景中,数据量迅速增长,一个库一个表已经满足不了我们的需求的时候,我们就会考虑分库分表的操作,在springboot中如何
- 文件作为存储数据的单元,会根据数据类型产生很多分类,也就是所谓的文件类型。在对数据文件进行操作时,常常需要根据不同的文件类型来作不同的处理。
- 一、叙述当Spring的事件(Application Event)为Bean和Bean之间的消息同步提供了支持。当一个Bean处理完成一个任
- 简介本文用示例介绍SpringMVC如何通过JSON格式传递入参。JSON格式使用post方式来请求,即:对应的注解为:@PostMappi
- 本文实例讲述了Java泛型类与泛型方法的定义。分享给大家供大家参考,具体如下:Java泛型类的定义一 点睛泛型类定义的语法如下:[访问修饰符
- 省流/// <summary>/// 是否有效的文件,文件夹路径/// </summary>/// <para
- 我们有时用C#需要实现锁住文件的功能,该如何锁住文件呢?下面小编给大家介绍一下。首先大家需要到码云里面找到如下图所示的文件锁的项目,如下图所