Eclipse+Java+Swing实现学生成绩管理系统的实例代码

 更新时间:2021年01月09日 15:08:04   作者:水坚石青  
这篇文章主要介绍了Eclipse+Java+Swing实现学生成绩管理系统,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

一、系统介绍

本系统实现了用户登录,实现了对学生成绩的增删改查,实现了用户修改密码功能,采用MD5加密算法,数据库使用Mysql8.0.13,界面良好。

二、系统展示

1.登录页

在这里插入图片描述

2.主页面

在这里插入图片描述

3.查询学生成绩

在这里插入图片描述

4.修改学生成绩

在这里插入图片描述

5.添加学生成绩

在这里插入图片描述

6.修改系统密码

在这里插入图片描述

三、系统实现 Student.java

package com.sjsq.model;

import java.util.ArrayList;
import java.util.List;

/**
 * 学生实体类
 * @author shuijianshiqing
 *
 */

public class Student {

	// 学号
	private String sId;
	// 姓名
	private String sName;
	// 性别
	private String sSex;
	// 学院
	private String sCollege;
	private String sC;
	private String sMath;
	private String sEnglish;
	private String sChinese;
	private String sJava;

	public Student() {
		super();
	}

	public Student(String sId, String sName, String sSex, String sCollege, String sC, String sMath,
			String sEnglish, String sChinese, String sJava) {
		super();
		this.sId = sId;
		this.sName = sName;
		this.sSex = sSex;
		this.sCollege = sCollege;
		this.sC = sC;
		this.sMath = sMath;
		this.sEnglish = sEnglish;
		this.sChinese = sChinese;
		this.sJava = sJava;
	}

	public static List<Student> students=new ArrayList<Student>();
	
	public String getsId() {
		return sId;
	}

	public void setsId(String sId) {
		this.sId = sId;
	}

	public String getsName() {
		return sName;
	}

	public void setsName(String sName) {
		this.sName = sName;
	}

	public String getsSex() {
		return sSex;
	}

	public void setsSex(String sSex) {
		this.sSex = sSex;
	}

	public String getsCollege() {
		return sCollege;
	}

	public void setsCollege(String sCollege) {
		this.sCollege = sCollege;
	}

	public String getsC() {
		return sC;
	}

	public void setsC(String sC) {
		this.sC = sC;
	}

	public String getsMath() {
		return sMath;
	}

	public void setsMath(String sMath) {
		this.sMath = sMath;
	}

	public String getsEnglish() {
		return sEnglish;
	}

	public void setsEnglish(String sEnglish) {
		this.sEnglish = sEnglish;
	}

	public String getsChinese() {
		return sChinese;
	}

	public void setsChinese(String sChinese) {
		this.sChinese = sChinese;
	}

	public String getsJava() {
		return sJava;
	}

	public void setsJava(String sJava) {
		this.sJava = sJava;
	}

	@Override
	public String toString() {
		return "Student [sId=" + sId + ", sName=" + sName + ", sSex=" + sSex + ", sCollege=" + sCollege + ", sC="
				+ sC + ", sMath=" + sMath + ", sEnglish=" + sEnglish + ", sChinese=" + sChinese + ", sJava="
				+ sJava + "]";
	}	

}

StudentDao.java

package com.sjsq.dao;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import com.sjsq.model.Student;
import com.sjsq.util.DBUtil;

public class StudentDao {
	public static int progress;

	// private final String FILE_PATH="d:\\student.xls";

	public static StudentDao getInstance() {
		StudentDao studentDao;
		return studentDao = new StudentDao();
	}

	// 查询所有学生的信息
	public ResultSet queryAll() {
		ResultSet rs = null;
		String sql = "select * from Student";
		System.out.println("------查询所有学生信息------");
		System.out.println("sql语句:" + sql);
		DBUtil db = new DBUtil();
		try {
			rs = db.executeQuery(sql);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return rs;
	}

	// 查询所有学生信息,并且返回List
	public List<Student> queryAllStudent() {
		List<Student> listStudent = new ArrayList<Student>();
		String sql = "select * from student";
		System.out.println("------查询所有学生信息------");
		System.out.println("sql语句:" + sql);
		DBUtil db = new DBUtil();
		ResultSet rs = null;
		try {
			rs = db.executeQuery(sql);
			while (rs.next()) {
				Student studentTmp = new Student();
				studentTmp.setsId(rs.getString("sId"));
				studentTmp.setsName(rs.getString("sName"));
				studentTmp.setsSex(rs.getString("sSex"));
				studentTmp.setsCollege(rs.getString("sCollege"));
				studentTmp.setsC(rs.getString("sC"));
				studentTmp.setsMath(rs.getString("sMath"));
				studentTmp.setsEnglish(rs.getString("sEnglish"));
				studentTmp.setsChinese(rs.getString("sChinese"));
				studentTmp.setsJava(rs.getString("sJava"));
				listStudent.add(studentTmp);
			}
		} catch (SQLException e) {

			e.printStackTrace();
		} finally {
			try {
				if (rs != null) {
					rs.close();
				}
			} catch (SQLException e) {

				e.printStackTrace();
			}
			db.close();
		}
		return listStudent;
	}


	public static int getprogress() {
		return progress;
	}
	
	// 按照条件查询
	public ResultSet queryByCondition(String[] data) {
		ResultSet rs = null;
		String sql = "select * from student where 1=1";
		int i = 0;
		// 学号
		if (!(data[0].equals(""))) {
			sql += " and sid='" + data[0] + "' ";
		}
		// 姓名
		if (!(data[1].equals(""))) {
			sql += " and sname='" + data[1] + "' ";
		}
		// 省份
		if (!(data[2].equals(""))) {
			sql += " and senglish='" + data[2] + "' ";
		}
		// 性别
		if (!(data[3].equals(""))) {
			sql += " and ssex='" + data[3] + "' ";
		}
		
		System.out.println("------查询所有学生信息------");
		System.out.println("sql语句:" + sql);

		DBUtil db = new DBUtil();
		try {
			rs = db.executeQuery(sql);
		} catch (SQLException e) {

			e.printStackTrace();
		}

		return rs;
	}	
	
	// 插入学生信息,并且返回插入结果
	public boolean insertStudentInformation(Student student) {
		DBUtil DBUtil = new DBUtil();
		// 通过student对象设置sid的值
		String sid = student.getsId();
		String sname = student.getsName();
		String ssex = student.getsSex();
		String scollege = student.getsCollege();
		String sc = student.getsC();
		String smath = student.getsMath();
		String senglish = student.getsEnglish();
		String schinese = student.getsChinese();
		String sjava = student.getsJava();

		String sql = "insert into student(sid,sname,ssex,scollege,sc,smath,senglish,schinese,sjava)" + 
		"values('" + sid + "','" + sname + "','" + ssex + "','" + scollege+ "','" + sc+ "','" 
				+ smath + "','" + senglish + "','" + schinese + "','" + sjava + "')";
		
		System.out.println("------插入学生信息------");
		System.out.println("sql语句:" + sql);
		
		// 向数据库插入数据语句
		// 定义一个boolean型变量,用于判断插入数据是否成功
		boolean flag = false;
		try {
			// 更新数据库信息
			flag = DBUtil.executeUpdate(sql);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		DBUtil.close();
		// 返回执行结果
		return flag;

	}

	// 统计同一学号有多少人
	public int queryForsidinformation(String sid) {
		DBUtil db = new DBUtil();
		// 通过sid查询数据库中是否有相同sid数据
		String sql = "select * from student where sid=" + sid;
		System.out.println("------验证学生学号信息------");
		System.out.println("sql语句:" + sql);
		ResultSet rs = null;
		int count = 0;
		try {
			// 更新数据库保存到结果集里
			rs = (ResultSet) db.executeQuery(sql);
			// 找到相同的count++
			if (rs.next()) {
				count++;
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}
		// 关闭数据库连接
		db.close();
		// 返回count
		return count;
	}

	// 更新学生信息,这里学号不能更新
	public boolean updateStudentInformation(Student student) {
		DBUtil DBUtil = new DBUtil();
		// scollege,sc,smath,senglish,schinese,sjava
		String sql = "update student set sname=" + "'" + student.getsName() + "'" + " ," 
				+ " ssex=" + "'" + student.getsSex() + "'" + " ,"
				+ " scollege=" + "'" + student.getsCollege() + "' " + " ,"
				+ " sc=" + "'" + student.getsC() + "' " + " ,"
				+ " smath=" + "'" + student.getsMath() + "' " + " ,"
				+ " senglish=" + "'" + student.getsEnglish() + "'" + "," 
				+ " schinese=" + "'" + student.getsChinese() + "'" + " ," 
				+ " sjava=" + "'" + student.getsJava()+ "'" 
				+ " where" + " sid=" + "'"+ student.getsId() + "'";
		System.out.println("------更新学生信息------");
		System.out.println("sql语句:" + sql);
		
		boolean flag = false;
		try {
			flag = DBUtil.executeUpdate(sql);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return flag;
	}

	// 删除学生信息
	public boolean deleteStudentInfoBySid(String sid) {
		boolean flag = false;
		String sql = "delete from student where sid=" + "'" + sid + "'";
		
		System.out.println("------删除学生信息------");
		System.out.println("sql语句:" + sql);
		
		DBUtil DBUtil = new DBUtil();
		try {
			flag = DBUtil.executeUpdate(sql);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return flag;
	}
}

LoginFrame.java

package com.sjsq.view;

import org.jb2011.lnf.beautyeye.ch3_button.BEButtonUI;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.Rectangle;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;

import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JPasswordField;
import javax.swing.JTextField;
import javax.swing.Timer;
import javax.swing.UIManager;

import com.sjsq.model.User;
import com.sjsq.util.MD5Util;
import com.sjsq.dao.UserDao;

public class LoginFrame extends JFrame implements ActionListener {
	public static String uname = null;
	public static String pwd = null;
	String username, password, login, quit;

	// 登录标签
	private JLabel loginJLabel;
	private JPanel jContentPane = null;
	private JButton jButtonLogin = null;
	private JButton jButtonExit = null;
	private JTextField jTextFieldUserName = null;
	private JTextField jTextFieldPassWord = null;
	// 登录用户名
	static int storeUserId;
	// 图片
	public JLabel jLabel_Image = null;
	// 登录用户名
	public static String storeUserame = null;
	// 登录密码
	public static String storeUserPassword = null;
	// 重新登陆标记
	static boolean RELOAD = true;
	private JLabel jLabelUserName = null;
	private JLabel jLabelPassWord = null;

	int index;
	
	public LoginFrame() {
			// 设置背景
			setForeground(new Color(255, 255, 255));
			this.setResizable(false);
			this.setSize(800, 500);
			this.setTitle("学生成绩管理系统");
			
			this.setLocationRelativeTo(null);
			try {
				UIManager.setLookAndFeel("com.sun.java.swing.plaf.windows.WindowsLookAndFeel");// 使用windows外观
			} catch (Exception e) {
				e.printStackTrace();
			}
			
			loginJLabel = new JLabel("学生成绩管理系统");
			Font font = new Font("微软雅黑",Font.BOLD,40);
			loginJLabel.setFont(font);
			loginJLabel.setBounds(220,100,650, 50);
			loginJLabel.setForeground(Color.DARK_GRAY);
			getContentPane().add(loginJLabel);

			Font font2 = new Font("微软雅黑",Font.BOLD,15);
			jLabelPassWord = new JLabel();
			jLabelPassWord.setFont(font2);
			jLabelPassWord.setBounds(new Rectangle(300, 250, 71, 29));
			jLabelPassWord.setText("用户名:");
			jLabelUserName = new JLabel();
			jLabelUserName.setBounds(new Rectangle(300, 300, 71, 29));
			jLabelUserName.setFont(font2);
			jLabelUserName.setText("密码:");
			
			// 账号输入框
			jTextFieldUserName = new JTextField(20);
			jTextFieldUserName.setBounds(new Rectangle(360, 250, 154, 33));
			// 密码输入框
			jTextFieldPassWord = new JPasswordField();
			jTextFieldPassWord.setBounds(new Rectangle(360, 300, 154, 33));
			
			// 登录
			jButtonLogin = new JButton();
			jButtonLogin.setBounds(new Rectangle(320, 380, 78, 26));
			jButtonLogin.setText("登录");
			jButtonLogin.setUI(new BEButtonUI()
					.setNormalColor(BEButtonUI.NormalColor.green));
			// 回车登录
			getRootPane().setDefaultButton(jButtonLogin);

			// 退出
			jButtonExit = new JButton();
			jButtonExit.setUI(new BEButtonUI()
					.setNormalColor(BEButtonUI.NormalColor.lightBlue));
			jButtonExit.setBounds(new Rectangle(420, 380, 78, 26));
			jButtonExit.setText("退出");
			
			// 包含所有的元素
			jContentPane = new JPanel();
			jContentPane.setLayout(null);
			jContentPane.add(jLabelUserName, null);
			jContentPane.add(jLabelPassWord, null);
			jContentPane.add(jButtonLogin, null);
			jContentPane.add(jButtonExit, null);
			jContentPane.add(jTextFieldUserName, null);
			jContentPane.add(jTextFieldPassWord, null);
			getContentPane().add(jContentPane);
			
			jTextFieldUserName.addKeyListener(new KeyListener() {
				@Override
				public void keyPressed(KeyEvent e) {

				}
				@Override
				public void keyReleased(KeyEvent e) {

				}
				@Override
				public void keyTyped(KeyEvent e) {
					if(e.getKeyChar() == KeyEvent.VK_ENTER){
						jTextFieldPassWord.requestFocus();
					}
				}
			});

			jTextFieldPassWord.addKeyListener(new KeyListener() {
				@Override
				public void keyTyped(KeyEvent e) {

				}
				@Override
				public void keyReleased(KeyEvent e) {

				}
				@Override
				public void keyPressed(KeyEvent e) {
					if(e.getKeyChar() == KeyEvent.VK_ENTER){
						username = jTextFieldUserName.getText();
						password = MD5Util.string2MD5(jTextFieldPassWord.getText());

						User user = new User();
						user.setUsername(username);
						user.setPassword(password);
						String s=user.getUsername();
						String p=jTextFieldPassWord.getText();
						UserDao userDao = new UserDao();
						int choice = 0;
						if(!userDao.checkUser(user)) {
							JOptionPane.showMessageDialog(null, "用户名和密码错误","消息提示",JOptionPane.WARNING_MESSAGE);
						}else {
							setVisible(false);
							MainMenuFrame MM = new MainMenuFrame();
							uname = s;
							pwd=p;
						}
					}
				}
			});

			this.setDefaultCloseOperation(EXIT_ON_CLOSE);
			this.setVisible(true);

			// 添加监控
			jTextFieldUserName.addActionListener(this);
			jTextFieldPassWord.addActionListener(this);
			jButtonLogin.addActionListener(this);
			jButtonExit.addActionListener(this);
		}


	@Override
	public void actionPerformed(ActionEvent e) {

		// 获取账号和密码
		username = jTextFieldUserName.getText();
		password = MD5Util.string2MD5(jTextFieldPassWord.getText());

		User user = new User();
		user.setUsername(username);
		user.setPassword(password);
		String s = user.getUsername();
		String p = jTextFieldPassWord.getText();
		UserDao userDao = new UserDao();
		int choice = 0;

		if (e.getSource() == jButtonLogin) {
			if (!userDao.checkUser(user)) {
				JOptionPane.showMessageDialog(null, "用户名和密码错误", "消息提示", JOptionPane.WARNING_MESSAGE);
			} else {
				setVisible(false);
				MainMenuFrame MM = new MainMenuFrame();
				uname = s;
				pwd = p;
			}
		} else if (e.getSource() == jButtonExit) {
			System.exit(0);
		}
	}
	
	// 测试
	public static void main(String[] args) {
		new LoginFrame();
	}
}

MainMenuFrame.java

package com.sjsq.view;

import java.awt.Font;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;

import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;

import org.jb2011.lnf.beautyeye.ch3_button.BEButtonUI;

/*
 * 登陆成功后主界面
 */
public class MainMenuFrame extends JFrame implements ActionListener {
	private JFrame mainmenu;
	private JTextArea text;
	// 标题栏(关于)
	private JMenuBar menuBar1;
	private JMenuItem aboutSystem;

	public MainMenuFrame() {

		mainmenu();
	}

	public void mainmenu() {
		mainmenu = new JFrame("极客大学学生管理系统");
		setLocationRelativeTo(null);// 将容器显示在屏幕中央
		mainmenu.setSize(850, 650);

		mainmenu.getContentPane().add(new JScrollPane(text));

		JPanel jContentPane = new JPanel();
		jContentPane.setLayout(null);

		// 查询学生按钮
		JButton jButtonSelect = new JButton();
		jButtonSelect.setBounds(new Rectangle(320, 100, 100, 52));
		jButtonSelect.setText("查询学生");
		jButtonSelect.setUI(new BEButtonUI().setNormalColor(BEButtonUI.NormalColor.lightBlue));
		getRootPane().setDefaultButton(jButtonSelect);// 回车登录

		// 添加学生按钮
		JButton jButtonAdd = new JButton();
		jButtonAdd.setUI(new BEButtonUI().setNormalColor(BEButtonUI.NormalColor.lightBlue));
		jButtonAdd.setBounds(new Rectangle(320, 200, 100, 52));
		jButtonAdd.setText("添加学生");

		// 修改密码按钮
		JButton jButtonAlterPwd = new JButton();
		jButtonAlterPwd.setUI(new BEButtonUI().setNormalColor(BEButtonUI.NormalColor.lightBlue));
		jButtonAlterPwd.setBounds(new Rectangle(320, 300, 100, 52));
		jButtonAlterPwd.setText("密码修改");

		// 退出系统按钮
		JButton jButtonExit = new JButton();
		jButtonExit.setUI(new BEButtonUI().setNormalColor(BEButtonUI.NormalColor.lightBlue));
		jButtonExit.setBounds(new Rectangle(320, 400, 100, 52));
		jButtonExit.setText("退出系统");

		jContentPane.add(jButtonSelect, null);
		jContentPane.add(jButtonAdd, null);
		jContentPane.add(jButtonAlterPwd, null);
		jContentPane.add(jButtonExit, null);

		// 添加Label到Frame
		mainmenu.getContentPane().add(jContentPane);
		// 设置字体
		Font font = new Font("微软雅黑", Font.BOLD, 16);
		// 标题栏
		menuBar1 = new JMenuBar();

		// aboutSystem = new JMenuItem("关于本系统",new
		// ImageIcon("src/images/icons/about.png"));
		aboutSystem = new JMenuItem("关于本系统");
		aboutSystem.setMnemonic('H');

		menuBar1.add(aboutSystem);

		// 查询学生
		jButtonSelect.addActionListener(new ActionListener() {

			@Override
			public void actionPerformed(ActionEvent e) {
				System.out.println("------查询学生-----");
				QueryStudentInfo queryStudentInfo = new QueryStudentInfo();
			}
		});

		// 添加学生
		jButtonAdd.addActionListener(new ActionListener() {

			@Override
			public void actionPerformed(ActionEvent e) {
				System.out.println("------添加学生-----");
				AddStudentInfo addStudentInfo = new AddStudentInfo();
			}
		});

		// 修改密码
		jButtonAlterPwd.addActionListener(new ActionListener() {

			@Override
			public void actionPerformed(ActionEvent e) {
				System.out.println("------修改密码-----");
				ModifyPasswordInfo modifyPasswordInfo = new ModifyPasswordInfo();
			}
		});

		// 退出系统
		jButtonExit.addActionListener(new ActionListener() {

			@Override
			public void actionPerformed(ActionEvent e) {
				System.out.println("------退出系统-----");
				System.exit(1);
			}
		});

		// 关于系统
		aboutSystem.addActionListener(new ActionListener() {

			@Override
			public void actionPerformed(ActionEvent e) {
				System.out.println("------关于系统------");
				AboutSystem aboutSystem = new AboutSystem();
			}
		});

		// 关闭窗口监控
		mainmenu.addWindowListener(new WindowAdapter() {
			public void windowClosing(WindowEvent arg0) {
				System.exit(1);
			}
		});

		mainmenu.setJMenuBar(menuBar1);
		mainmenu.setVisible(true);
		// mainmenu.setLocation(250, 50);
		mainmenu.setLocationRelativeTo(null);
		aboutSystem.addActionListener(this);
	}

	// 主函数测试
	public static void main(String[] args) {
		new MainMenuFrame();

	}

	@Override
	public void actionPerformed(ActionEvent arg0) {
	}

}

到此这篇关于Eclipse+Java+Swing实现学生成绩管理系统的文章就介绍到这了,更多相关Eclipse+Java+Swing实现学生成绩管理系统内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java中java.lang.ClassCastException异常原因及解决方法

    Java中java.lang.ClassCastException异常原因及解决方法

    大家好,本篇文章主要讲的是Java中java.lang.ClassCastException异常原因及解决方法,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • JavaMailSender实现邮箱验证功能

    JavaMailSender实现邮箱验证功能

    本篇文章主要给大家介绍了JavaMailSender实现邮箱注册验证的功能实现原理以及其中遇到的问题,一起跟着学习探讨下吧。
    2017-12-12
  • springboot集成Swagger的方法(让你拥有属于自己的api管理器)

    springboot集成Swagger的方法(让你拥有属于自己的api管理器)

    在大型的项目中,如果你有非常多的接口需要统一管理,或者需要进行接口测试,那么我们通常会在繁杂地api中找到需要进行测试或者管理的接口,接下来通过本文给大家介绍springboot集成Swagger的方法让你拥有属于自己的api管理器,感兴趣的朋友一起看看吧
    2021-11-11
  • Java volatile的几种使用场景分析

    Java volatile的几种使用场景分析

    volatile 是一种轻量级的同步机制,它能保证共享变量的可见性,同时禁止重排序保证了操作的有序性,但是它无法保证原子性,本文给大家总结了Java olatile的使用场景有哪些,并通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-03-03
  • 浅谈SpringBoot是如何实现日志的

    浅谈SpringBoot是如何实现日志的

    这篇文章主要介绍了浅谈SpringBoot是如何实现日志的,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • Java命令行运行错误之找不到或无法加载主类问题的解决方法

    Java命令行运行错误之找不到或无法加载主类问题的解决方法

    这篇文章主要给大家介绍了关于Java命令行运行错误之找不到或无法加载主类问题的解决方法,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-01-01
  • java条件语句示例详解

    java条件语句示例详解

    本文给大家介绍java条件语句,Java 中的条件语句允许程序根据条件的不同执行不同的代码块,一个 if 语句包含一个布尔表达式和一条或多条语句,本文结合示例代码给大家讲解的非常详细,需要的朋友可以参考下
    2023-05-05
  • Spring框架web项目实战全代码分享

    Spring框架web项目实战全代码分享

    这篇文章主要介绍了Spring框架web项目实战全代码分享,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • 解决springboot遇到autowire注入为null的问题

    解决springboot遇到autowire注入为null的问题

    这篇文章主要介绍了解决springboot遇到autowire注入为null的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • Java中使用开源库JSoup解析HTML文件实例

    Java中使用开源库JSoup解析HTML文件实例

    这篇文章主要介绍了Java中使用开源库JSoup解析HTML文件实例,Jsoup是一个开源的Java库,它可以用于处理实际应用中的HTML,比如常见的HTML格式化就可以用它来实现,需要的朋友可以参考下
    2014-09-09

最新评论