基于java学生签到考勤系统
创始人
2024-04-21 01:36:49
0

开发工具eclipse,jdk1.8 

技术:java swing

数据库:mysql5.7

学生选课系统功能:管理员、教师、学生三个角色

一、管理员功能:

1.登录、修改密码、退出系统

2.学生管理:添加、修改、删除、查询

3.班级管理:添加、修改、删除、查询

4.教师管理:添加、修改、删除、查询

5.课程管理:添加、修改、删除、查询

6.选课管理:修改选课、推选课程

7.签到管理和签到统计

签到管理:确认签到、添加缺席

签到统计:列表显示、柱状图显示、饼状图显示

8.帮助、关于

二、教师功能:

1.登录、修改密码、退出系统

2.学生管理:添加、修改、删除、查询

3.班级管理:添加、修改、删除、查询

4.教师管理:修改个人信息

5.课程管理:添加、修改、删除、查询

6.选课管理:修改选课、推选课程

7.签到管理和签到统计

签到管理:确认签到、添加缺席

签到统计:列表显示、柱状图显示、饼状图显示

8.帮助、关于

三、学生功能:

1.登录、修改密码、退出系统

2.学生管理:修改个人信息

3.选课管理:修改选课、推选课程

4.确认签到

5.帮助、关于

管理员截图:

 

 

 

 

 

 

 

 

 

 

教师截图:

 

 

 

 

 

 

 

 

 

 

学生截图:

 

 

 

 

 

package com.artisan.view;import java.awt.EventQueue;
import java.awt.Font;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.List;import javax.swing.ButtonGroup;
import javax.swing.DefaultComboBoxModel;
import javax.swing.GroupLayout;
import javax.swing.GroupLayout.Alignment;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPasswordField;
import javax.swing.JRadioButton;
import javax.swing.JTextField;
import javax.swing.LayoutStyle.ComponentPlacement;import com.artisan.dao.ClassDao;
import com.artisan.dao.StudentDao;
import com.artisan.model.Student;
import com.artisan.model.StudentClass;
import com.artisan.util.StringUtil;public class AddStudentFrm extends JInternalFrame {private JTextField studentNameTextField;private JPasswordField studentPasswordField;private JComboBox studentClassComboBox;private ButtonGroup sexButtonGroup;private JRadioButton studentSexManRadioButton;private JRadioButton studentSexFemalRadioButton;private JRadioButton studentSexUnkonwRadioButton;/*** Launch the application.*/public static void main(String[] args) {EventQueue.invokeLater(new Runnable() {public void run() {try {AddStudentFrm frame = new AddStudentFrm();frame.setVisible(true);} catch (Exception e) {e.printStackTrace();}}});}/*** Create the frame.*/public AddStudentFrm() {setClosable(true);setIconifiable(true);setTitle("\u6DFB\u52A0\u5B66\u751F");setBounds(100, 100, 450, 300);JLabel label = new JLabel("\u5B66\u751F\u59D3\u540D\uFF1A");label.setIcon(new ImageIcon(AddStudentFrm.class.getResource("/images/\u5B66\u751F\u7BA1\u7406.png")));label.setFont(new Font("微软雅黑", Font.PLAIN, 14));studentNameTextField = new JTextField();studentNameTextField.setColumns(10);JLabel label_1 = new JLabel("\u6240\u5C5E\u73ED\u7EA7\uFF1A");label_1.setIcon(new ImageIcon(AddStudentFrm.class.getResource("/images/\u73ED\u7EA7\u540D\u79F0.png")));label_1.setFont(new Font("微软雅黑", Font.PLAIN, 14));studentClassComboBox = new JComboBox();studentClassComboBox.setModel(new DefaultComboBoxModel(new String[] {}));JLabel label_2 = new JLabel("\u767B\u5F55\u5BC6\u7801\uFF1A");label_2.setIcon(new ImageIcon(AddStudentFrm.class.getResource("/images/password.png")));label_2.setFont(new Font("微软雅黑", Font.PLAIN, 14));studentPasswordField = new JPasswordField();JLabel label_3 = new JLabel("\u5B66\u751F\u6027\u522B\uFF1A");label_3.setIcon(new ImageIcon(AddStudentFrm.class.getResource("/images/\u6027\u522B.png")));label_3.setFont(new Font("微软雅黑", Font.PLAIN, 14));studentSexManRadioButton = new JRadioButton("\u7537");studentSexManRadioButton.setSelected(true);studentSexFemalRadioButton = new JRadioButton("\u5973");studentSexUnkonwRadioButton = new JRadioButton("\u4FDD\u5BC6");sexButtonGroup = new ButtonGroup();sexButtonGroup.add(studentSexManRadioButton);sexButtonGroup.add(studentSexFemalRadioButton);sexButtonGroup.add(studentSexUnkonwRadioButton);JButton submitButton = new JButton("\u786E\u8BA4");submitButton.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent ae) {studentAddAct(ae);}});submitButton.setIcon(new ImageIcon(AddStudentFrm.class.getResource("/images/\u786E\u8BA4.png")));submitButton.setFont(new Font("微软雅黑", Font.PLAIN, 14));JButton resetButton = new JButton("\u91CD\u7F6E");resetButton.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent ae) {resetValue(ae);}});resetButton.setIcon(new ImageIcon(AddStudentFrm.class.getResource("/images/\u91CD\u7F6E.png")));resetButton.setFont(new Font("微软雅黑", Font.PLAIN, 14));GroupLayout groupLayout = new GroupLayout(getContentPane());groupLayout.setHorizontalGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGap(91).addGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addComponent(label_2).addPreferredGap(ComponentPlacement.UNRELATED).addComponent(studentPasswordField, GroupLayout.DEFAULT_SIZE, 151, Short.MAX_VALUE)).addGroup(groupLayout.createSequentialGroup().addComponent(label_1).addPreferredGap(ComponentPlacement.UNRELATED).addComponent(studentClassComboBox, 0, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)).addGroup(groupLayout.createSequentialGroup().addComponent(label).addPreferredGap(ComponentPlacement.UNRELATED).addComponent(studentNameTextField, GroupLayout.PREFERRED_SIZE, 151, GroupLayout.PREFERRED_SIZE))).addGap(92)).addGroup(groupLayout.createSequentialGroup().addGroup(groupLayout.createParallelGroup(Alignment.TRAILING).addComponent(resetButton).addGroup(groupLayout.createSequentialGroup().addComponent(label_3).addPreferredGap(ComponentPlacement.UNRELATED).addComponent(studentSexManRadioButton).addGap(10).addComponent(studentSexFemalRadioButton).addGap(10).addComponent(studentSexUnkonwRadioButton))).addContainerGap()))).addGroup(groupLayout.createSequentialGroup().addGap(132).addComponent(submitButton).addContainerGap(221, Short.MAX_VALUE)));groupLayout.setVerticalGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGap(30).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(label).addComponent(studentNameTextField, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addGap(26).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(label_1).addComponent(studentClassComboBox, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addGap(32).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(label_2).addComponent(studentPasswordField, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addGap(29).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(label_3).addComponent(studentSexManRadioButton).addComponent(studentSexUnkonwRadioButton).addComponent(studentSexFemalRadioButton)).addPreferredGap(ComponentPlacement.RELATED, 30, Short.MAX_VALUE).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(submitButton).addComponent(resetButton)).addContainerGap()));getContentPane().setLayout(groupLayout);setStudentClassInfo();}protected void resetValue(ActionEvent ae) {// TODO Auto-generated method stubstudentNameTextField.setText("");studentPasswordField.setText("");studentClassComboBox.setSelectedIndex(0);sexButtonGroup.clearSelection();studentSexManRadioButton.setSelected(true);}protected void studentAddAct(ActionEvent ae) {// TODO Auto-generated method stubString studentName = studentNameTextField.getText().toString();String studentPassword = studentPasswordField.getText().toString();if(StringUtil.isEmpty(studentName)){JOptionPane.showMessageDialog(this, "请填写学生姓名!");return;}if(StringUtil.isEmpty(studentPassword)){JOptionPane.showMessageDialog(this, "请填写密码!");return;}StudentClass sc = (StudentClass)studentClassComboBox.getSelectedItem();String sex = studentSexManRadioButton.isSelected() ? studentSexManRadioButton.getText() : (studentSexFemalRadioButton.isSelected() ? studentSexFemalRadioButton.getText() : studentSexUnkonwRadioButton.getText());Student student = new Student();student.setName(studentName);student.setClassId(sc.getId());student.setPassword(studentPassword);student.setSex(sex);StudentDao studentDao = new StudentDao();if(studentDao.addStudent(student)){JOptionPane.showMessageDialog(this, "添加成功!");}else{JOptionPane.showMessageDialog(this, "添加失败!");}resetValue(ae);}private void setStudentClassInfo(){ClassDao classDao = new ClassDao();List classList = classDao.getClassList(new StudentClass());for (StudentClass sc : classList) {studentClassComboBox.addItem(sc);}classDao.closeDao();}
}

 

package com.artisan.dao;

import com.artisan.model.Admin;

import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class AdminDao extends BaseDao {
    /**
     * 管理员登陆
     */
    public Admin login(Admin admin){
        String sql = "select * from s_admin where name=? and password=?";
        Admin adminRst = null;
        try {
            PreparedStatement prst = con.prepareStatement(sql);//把sql语句传给数据库操作对象
            prst.setString(1, admin.getName());
            prst.setString(2, admin.getPassword());
            ResultSet executeQuery = prst.executeQuery();
            if(executeQuery.next()){
                adminRst = new Admin();
                adminRst.setId(executeQuery.getInt("id"));
                adminRst.setName(executeQuery.getString("name"));
                adminRst.setPassword(executeQuery.getString("password"));
                adminRst.setCreateDate(executeQuery.getString("createDate"));
            }
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return adminRst;
    }
    public String editPassword(Admin admin,String newPassword){
        String sql = "select * from s_admin where id=? and password=?";
        PreparedStatement prst = null;
        int id = 0;
        try {
            prst = con.prepareStatement(sql);
            prst.setInt(1, admin.getId());
            prst.setString(2, admin.getPassword());
            ResultSet executeQuery = prst.executeQuery();
            if(!executeQuery.next()){
                String retString = "旧密码错误!";
                return retString;
            }
            id = executeQuery.getInt("id");
        } catch (SQLException e1) {
            // TODO Auto-generated catch block
            e1.printStackTrace();
        }//把sql语句传给数据库操作对象
        String retString = "修改失败";
        String sqlString = "update s_admin set password = ? where id = ?";
        try {
            prst = con.prepareStatement(sqlString);
            prst.setString(1, newPassword);
            prst.setInt(2, id);
            int rst = prst.executeUpdate();
            if(rst > 0){
                retString = "密码修改成功!";
            }
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }//把sql语句传给数据库操作对象
        return retString;
    }
}
 

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...
苏州离哪个飞机场近(苏州离哪个... 本篇文章极速百科小编给大家谈谈苏州离哪个飞机场近,以及苏州离哪个飞机场近点对应的知识点,希望对各位有...