目录
1.系统运行环境
运行环境:Java8 + MySQL8
开发工具:eclipse/idea
2.系统功能介绍
(下面介绍的功能肯定都有,没有介绍的功能肯定没有!)
系统采用模拟MVC三层进行开发,这样方便项目进行修改或者二次开发!
数据库:四张表
功能:两种角色管理员和学生
普通学生登录:学生基本信息进行查询
成绩基本信息进行查询
课程基本信息进行查询
管理员登录:管理学生、成绩、课程等基本信息:
学生模块的添加、修改、删除、查询
成绩模块的添加、修改、删除、查询
课程模块的添加、修改、删除、查询
3.项目结构略讲
3.1乱码问题
系统开发时的编码为UTF-8,因此导入eclipse时,也需要eclipse工作空间的编码为UTF-8
修改编码:点击Window->Preference->General->workplace,然后选择默认编码方式 UTF-8。
错误做法:开始将系统导入,出现乱码的问题,然后去修改eclipse的编码,这样有的 时候并不能修乱码的问题!需要将项目删除掉,然后修改eclipse的工作空 间编码,再次导入系统才能修改掉乱码!
3.2 如何将UTF-8编码系统修改为GBK编码的系统?
需要靠我们勤劳的双手,嘿嘿嘿......
将系统文件复制一份,然后将eclipse的工作空间编码修改为GBK,导入系统;eclipse里面文件与原来文件进行一一比对,修改
Ctrl +c 和ctrl + v
除此之外,我目前还不知道如何一步修改,嘿嘿嘿......
3.3 项目结构
com.system.bean包:实体包,在有些情况下也写成entity或者pojo,相当于model持 久层
com.system.dao包:操作数据库的JDBC包,相当于model持久层
com.system.util包:工具包
com.system.view包:swing类包,相当于view视图层
mvc设计模式中:m是指业务模型,v是指用户界面,c则是控制器
你想问:这不是没有控制器层?
我:阿巴阿巴......确实没有
3.4 项目修改
在com.system.util包下面的DB类中,里面包含的一些数据库连接的基本信息,PASS变量需要修改成自己的数据库密码
3.5 项目运行
在com.system.view包下面的Login类,main函数就在这个类里面,然后点击右键就可以运行
3.6项目代码片段
public class Login extends JFrame {
private JPanel contentPane;
private JTextField usernameField;
private JPasswordField passwordField;
private JComboBox comboBox;
/**
* Launch the application.
* 开发者:码不停手
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
Login frame = new Login();
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
/**
* Create the frame.
*/
public Login() {
setTitle("学生信息管理系统");
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 689, 428);
contentPane = new JPanel();
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
setContentPane(contentPane);
contentPane.setLayout(null);
JPanel panel = new JPanel();
panel.setBounds(0, 0, 673, 389);
contentPane.add(panel);
panel.setLayout(null);
JLabel lblNewLabel = new JLabel("学生信息管理系统");
lblNewLabel.setHorizontalAlignment(SwingConstants.CENTER);
lblNewLabel.setFont(new Font("微软雅黑", Font.BOLD, 18));
lblNewLabel.setBounds(114, 36, 393, 55);
panel.add(lblNewLabel);
JLabel lblNewLabel_1 = new JLabel("用户名:");
lblNewLabel_1.setHorizontalAlignment(SwingConstants.CENTER);
lblNewLabel_1.setFont(new Font("微软雅黑", Font.BOLD, 16));
lblNewLabel_1.setBounds(106, 112, 145, 31);
panel.add(lblNewLabel_1);
JLabel lblNewLabel_1_1 = new JLabel("密码:");
lblNewLabel_1_1.setHorizontalAlignment(SwingConstants.CENTER);
lblNewLabel_1_1.setFont(new Font("微软雅黑", Font.BOLD, 16));
lblNewLabel_1_1.setBounds(106, 173, 145, 31);
panel.add(lblNewLabel_1_1);
JLabel lblNewLabel_1_2 = new JLabel("身份:");
lblNewLabel_1_2.setHorizontalAlignment(SwingConstants.CENTER);
lblNewLabel_1_2.setFont(new Font("微软雅黑", Font.BOLD, 16));
lblNewLabel_1_2.setBounds(106, 242, 145, 31);
panel.add(lblNewLabel_1_2);
usernameField = new JTextField();
usernameField.setBounds(227, 112, 249, 37);
panel.add(usernameField);
usernameField.setColumns(10);
passwordField = new JPasswordField();
passwordField.setBounds(227, 170, 249, 37);
panel.add(passwordField);
String[] a = new String[] { "管理员", "学生" };
comboBox = new JComboBox(a);
comboBox.setBounds(227, 237, 249, 42);
panel.add(comboBox);
JButton btnNewButton = new JButton("登录");
btnNewButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent arg0) {
// 获取文本框数据
String username = usernameField.getText();
String password = passwordField.getText();
String type = (String) comboBox.getSelectedItem();
// 判断是否为空
if (username.equals("") || password.equals("")) {
JOptionPane.showMessageDialog(null, "用户名或密码不能为空!");
} else {
if ("管理员".equals(type)) {
// 管理员登录
try {
UserDao log = new UserDao();
boolean istrue = log.LoginCheck(username, password);
if (istrue) {
JOptionPane.showMessageDialog(null, "登录成功!");
String a = "admin";
setVisible(false);
new Bg(a).setVisible(true);
} else {
JOptionPane.showMessageDialog(null, "用户名或密码错误!");
}
} catch (SQLException e1) {
e1.printStackTrace();
}
} else {
// 学生登录
try {
StudentDao log = new StudentDao();
boolean istrue = log.LoginCheck(username, password);
if (istrue) {
JOptionPane.showMessageDialog(null, "登录成功!");
String a = "学生"; // 不可修改,控制权限!
setVisible(false);
new Bg(a).setVisible(true);
} else {
JOptionPane.showMessageDialog(null, "用户名或密码错误!");
}
} catch (SQLException e1) {
e1.printStackTrace();
}
}
}
}
});
btnNewButton.setFont(new Font("微软雅黑", Font.BOLD, 14));
btnNewButton.setBounds(132, 308, 108, 37);
panel.add(btnNewButton);
JButton btnNewButton_1 = new JButton("重置");
btnNewButton_1.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent arg0) {
usernameField.setText("");
passwordField.setText("");
}
});
btnNewButton_1.setFont(new Font("微软雅黑", Font.BOLD, 14));
btnNewButton_1.setBounds(399, 308, 108, 37);
panel.add(btnNewButton_1);
}
}
4.下载地址
点击下载