这是一个高校机房失物招领系统的项目需求,使用了Java、SpringBoot、MyBatis、JQuery、HTML和JSP等技术,并连接了MySQL数据库。
以下是一个简化的解决方案,包括用户登录功能的代码示例:
// UserController.java
@Controller
public class UserController {
@Autowired
private UserService userService;
@RequestMapping(value = "/login", method = RequestMethod.POST)
public String login(@RequestParam String username, @RequestParam String password,
Model model, HttpSession session) {
User user = userService.login(username, password);
if (user != null) {
session.setAttribute("user", user);
return "redirect:/home";
} else {
model.addAttribute("error", "用户名或密码错误");
return "login";
}
}
// 其他控制器方法...
}
// UserService.java
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public User login(String username, String password) {
return userMapper.login(username, password);
}
// 其他服务方法...
}
// UserMapper.java
@Mapper
public interface UserMapper {
@Select("SELECT * FROM user WHERE username = #{username} AND password = #{password}")
User login(@Param("username") String username, @Param("password") String password);
// 其他MyBatis方法...
}
在这个示例中,我们定义了一个UserController,其中包含了一个处理登录请求的方法。该方法将调用UserService中的login方法,然后UserService将调用UserMapper中的login方法来查询数据库。如果用户存在,则在会话中设置用户,并重定向到主页;如果用户不存在,则向模型添加错误消息,并返回登录页面。
请注意,这只是一个简化的示例,实际的项目需求可能需要更复杂的功能,如权限校验、失物登记、认领管理等。