博主介绍:
🩵✌程序员Leaf哥,拥有7年开发经验,粉丝量超过11万,作为优质Java创作者,专注于Java技术、小程序开发以及毕业项目实战。✌🩵
2025-2026年最值得选择的Java毕业设计选题大全:1000个热门选题推荐✅✅✅
💫文章末尾获取源码+数据库💫
感兴趣可以先收藏起来。另外,在毕业设计选题、项目开发、以及论文编写等相关问题上,大家都可以随时留言咨询我,希望能够帮助到更多的同学。
目录:
完整视频演示:
请联系博主本人获取项目的完整演示视频
技术栈介绍:
- 开发语言:Java
- 后端框架:springboot
- 前端:html,css,js,vue
- 数据库:mysql
- 系统架构:B/S
- 开发工具:idea
需求分析:
需求分析是软件开发过程中至关重要的环节,旨在明确项目的功能和性能需求,确保最终的系统能够满足用户的预期,对于系统的操作,不需要专业人员都可以直接进行功能模块的操作管理,所以在系统的可操作性是完全可以的。本系统的操作使用的也是界面窗口进行登录,所以操作人员只要会简单的电脑操作就完全可以的。
具体系统功能实现截图:
用户端:
管理员端:
部分代码参考:
实体类:UserEntity:
package com.entity;
import javax.persistence.*;
import java.io.Serializable;
import java.util.Date;
/**
* 用户
*/
@Entity
@Table(name = "users")
public class UserEntity implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
/**
* 用户账号
*/
@Column(nullable = false, unique = true)
private String username;
/**
* 密码
*/
@Column(nullable = false)
private String password;
/**
* 用户类型
*/
@Column(nullable = false)
private String role;
@Temporal(TemporalType.TIMESTAMP)
private Date addtime;
// Getters and Setters
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getRole() {
return role;
}
public void setRole(String role) {
this.role = role;
}
public Date getAddtime() {
return addtime;
}
public void setAddtime(Date addtime) {
this.addtime = addtime;
}
}
控制器类:UserController
package com.controller;
import com.entity.UserEntity;
import com.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.util.Optional;
@RestController
@RequestMapping("users")
public class UserController {
@Autowired
private UserService userService;
@Autowired
private PasswordEncoder passwordEncoder;
/**
* 登录
*/
@PostMapping(value = "/login")
public ResponseEntity<?> login(@RequestParam String username, @RequestParam String password) {
Optional<UserEntity> userOptional = userService.findByUsername(username);
if (userOptional.isEmpty() || !passwordEncoder.matches(password, userOptional.get().getPassword())) {
return ResponseEntity.badRequest().body("账号或密码不正确");
}
// 通过Spring Security生成JWT Token
String token = userService.generateToken(userOptional.get());
return ResponseEntity.ok().body("token: " + token);
}
/**
* 注册
*/
@PostMapping(value = "/register")
public ResponseEntity<?> register(@RequestBody UserEntity user) {
if (userService.findByUsername(user.getUsername()).isPresent()) {
return ResponseEntity.badRequest().body("用户已存在");
}
user.setPassword(passwordEncoder.encode(user.getPassword()));
userService.save(user);
return ResponseEntity.ok("注册成功");
}
/**
* 退出
*/
@GetMapping(value = "/logout")
public ResponseEntity<?> logout(HttpServletRequest request) {
request.getSession().invalidate();
return ResponseEntity.ok("退出成功");
}
/**
* 密码重置
*/
@PostMapping(value = "/resetPass")
public ResponseEntity<?> resetPass(@RequestParam String username) {
Optional<UserEntity> userOptional = userService.findByUsername(username);
if (userOptional.isEmpty()) {
return ResponseEntity.badRequest().body("账号不存在");
}
UserEntity user = userOptional.get();
user.setPassword(passwordEncoder.encode("123456"));
userService.save(user);
return ResponseEntity.ok("密码已重置为:123456");
}
}
服务类:UserService
package com.service;
import com.entity.UserEntity;
import com.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.stereotype.Service;
import java.util.Optional;
@Service
public class UserService implements UserDetailsService {
@Autowired
private UserRepository userRepository;
@Autowired
private PasswordEncoder passwordEncoder;
public Optional<UserEntity> findByUsername(String username) {
return userRepository.findByUsername(username);
}
public void save(UserEntity user) {
userRepository.save(user);
}
public String generateToken(UserEntity user) {
// 使用Spring Security或其他库生成JWT令牌
// 这里只是伪代码,实际需根据项目的配置实现
return "dummy-jwt-token";
}
@Override
public UserEntity loadUserByUsername(String username) throws UsernameNotFoundException {
return userRepository.findByUsername(username)
.orElseThrow(() -> new UsernameNotFoundException("用户不存在"));
}
}
数据库访问层:UserRepository
package com.repository;
import com.entity.UserEntity;
import org.springframework.data.jpa.repository.JpaRepository;
import java.util.Optional;
public interface UserRepository extends JpaRepository<UserEntity, Long> {
Optional<UserEntity> findByUsername(String username);
}
Spring Security 配置
package com.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.csrf().disable()
.authorizeRequests()
.antMatchers("/users/login", "/users/register", "/users/resetPass").permitAll()
.anyRequest().authenticated();
}
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
项目论文:
我的优点:
作为一名拥有多年软件开发经验的程序员,我亲自参与和负责每一个项目的开发与辅导,避免中介的介入,确保了高效的直接对接。同时博主与高校紧密合作,积累了丰富的经验,开发和辅导了多名学生的项目。在博主这里通过一对一指导,为学生提供最专业和实用的技术支持。
自己开发的网站:为了方便同学们选题和定制,博主开发了自己的网站。网站为博主自己搭建上线,可以在上面选题参考,大家有任何技术问题都欢迎来提问,博主来免费解答。
源码获取:
2025-2026年最值得选择的Java毕业设计选题大全:1000个热门选题推荐✅✅✅
Java精品实战案例《1000套》
下方名片联系我即可~
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻