作者主页:源码空间站2022
简介:Java领域优质创作者、Java项目、学习资料、技术互助
文末获取源码
项目介绍
管理员角色包含以下功能:
管理员登录,管理员首页,基础信息维护,教师信息管理,职称管理,审核论文等功能。
教师角色包含以下功能:
教师登录,教师首页,修改密码,论文查询,上传论文等功能。
由于本程序规模不大,可供课程设计,毕业设计学习演示之用
环境需要
1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.数据库:MySql 5.7版本;
技术栈
HTML+CSS+JavaScript+jsp+mysql
使用说明
1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中application.yml配置文件中的数据库配置改为自己的配置;
4. 运行项目,输入localhost:8080/login.jsp 登录
运行截图
相关代码
登录管理控制器
@Controller
public class LoginController {
@Autowired
UserService userService;
//登录跳转
@RequestMapping(value = "/login", method = {RequestMethod.GET})
public String loginUI() throws Exception {
return "../../login";
}
//登录表单处理
@RequestMapping(value = "/login", method = {RequestMethod.POST})
public String login(Model model,User user, HttpServletRequest request) throws Exception {
//Shiro实现登录
UsernamePasswordToken token = new UsernamePasswordToken(user.getId(),user.getPassword());
Subject subject = SecurityUtils.getSubject();
//如果获取不到用户名就是登录失败,但登录失败的话,会直接抛出异常
try {
subject.login(token);
} catch (Exception e) {
// return "/login";
model.addAttribute("message","用户名或密码错误");
return "/error";
}
if (subject.hasRole("admin")) {
request.getSession().setAttribute("admin", user.getId());
request.getSession().setAttribute("usersession", userService.findUserById(user.getId()));
return "redirect:/admin/showRoom";
} else if (subject.hasRole("ordinary")) {
request.getSession().setAttribute("user", user.getId());
request.getSession().setAttribute("usersession", userService.findUserById(user.getId()));
return "redirect:/ordinary/showRoom";
}
model.addAttribute("message","登录异常,请联系管理员");
return "/error";
}
// 注册跳转
@RequestMapping(value = "/register",method = {RequestMethod.GET})
public String registerUI() throws Exception{
return "/register";
}
//注册表单处理
@RequestMapping(value = "/register", method = {RequestMethod.POST})
public String register(Model model,User user, HttpServletRequest request) throws Exception {
// 获取用户输入的验证码
String checkCode = request.getParameter("checkCode");
// 比对验证码,若不对,则返回
String checkCodeGen = request.getSession().getAttribute("checkCodeGen").toString();
if (!checkCodeGen.equalsIgnoreCase(checkCode)){
model.addAttribute("message","验证码输入有误");
return "redirect:/register";
}
if(user.getUsername()!=null && user.getUsername()!="" && user.getPassword()!=null && user.getPassword()!=""){
user.setId(user.getUsername());
// 查看用户id是否存在
User userById = userService.findUserById(user.getId());
if (userById !=null){
model.addAttribute("message","用户名已存在");
return "redirect:/register";
}
userService.addNewUser(user);
model.addAttribute("message","用户注册成功,请登录");
return "redirect:/login";
}else {
model.addAttribute("message","用户名密码不能为空");
return "redirect:/register";
}
}
// 生成验证码
@RequestMapping(value = "/checkcode",method = {RequestMethod.GET})
public void checkcode(Model model,HttpServletRequest request, HttpServletResponse response) throws Exception{
// 生成验证码
ServletOutputStream outputStream = response.getOutputStream();
String checkcode = CheckCodeUtil.outputVerifyImage(100, 50, outputStream, 4);
// 存储验证码
request.getSession().setAttribute("checkCodeGen",checkcode);
// model.addAttribute("checkCodeGen",checkcode);
}
}
如果也想学习本系统,下面领取。关注并回复:050jsp