目录
简介
本系统是基于SSM框架的图书管理系统,非常简单!!
实现功能:
1.实现通过访问数据库进行登录,错误则提示用户密码错误
2.实现用户注册功能,注册将会将新的用户加入数据库中,如果数据库中有相同的用户,则提示“该用户已存在”。登录注册功能都会判空;
3.登录成功之后将会进入目录,目录中选择注销用户,则会将回沪从数据库中删除,该用户无法再次登录,并跳转回登录界面;
4.进入管理界面将会进入图书管理界面,该界面实现分页展示,并对书籍总数进行统计
5.在管理界面实现了对书籍的增删查改。
先看看效果图
登录界面
注册界面
菜单界面
实现分页的管理界面
添加界面
删除
修改界面
文件目录
登录注册相关代码
登录,注册,菜单jsp页面
login.jsp界面
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<!DOCTYPE HTML>
<html>
<title>登录</title>
<script type="text/javascript">
//确定按钮
function su(){
document.forms[0].submit();
}
//取消按钮
function cancel(){
document.forms[0].action = "";
}
</script>
<body>
<form action="${pageContext.request.contextPath}/admin/login" modelAttribute="auser" method="post">
<table align="center">
<tr>
<td>用户名:</td>
<td><input type="text" name="aname" placeholder="请输入用户名"/><br></td>
</tr>
<tr>
<td>密 码:</td>
<td><input type="password" name="apwd" placeholder="请输入密码"/><br></td>
</tr>
<tr>
<td><input type="submit" value="登录" onclick="su()"/></td>
<td><input type="reset" value="取消" onclick="cancel()"/></td>
<td><a href="${pageContext.request.contextPath}/toregister">
<input type="button" value="注册" />
</a></td>
</tr>
</table>
</form>
${msg}
</body>
</html>
在此界面进行登录,点击登录将通过from表单action指定的路径进行提交至Controller(AdminController文件)
点击注册,将会通过超链接的路径访问对应的controller中的方法
regist.jsp 页面
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<title>注册</title>
<script type="text/javascript">
//确定按钮
function su(){
document.forms[0].submit();
}
//取消按钮
function cancel(){
document.forms[0].action = "";
}
</script>
<body>
<form action="${pageContext.request.contextPath}/admin/adduser" modelAttribute="auser" method="post">
<table align="center">
<tr>
<td>用户名:</td>
<td><input type="text" name="aname" placeholder="请输入用户名"/><br></td>
</tr>
<tr>
<td>密 码:</td>
<td><input type="password" name="apwd" placeholder="请输入密码"/><br></td>
</tr>
<tr>
<td><input type="submit" value="注册" onclick="su()"/></td>
<td><input type="reset" value="取消" onclick="cancel()"/></td>
</tr>
</table>
</form>
${msg}
</body>
</html>
into.jsp(菜单界面)
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>菜单</title>
</head>
<body>
<form >
<table align="center">
<tr>
<td><a href="${pageContext.request.contextPath}/books/selectbooks"
style="align-content: center">进入书城</a></td>
</tr>
<tr>
<td><a href="${pageContext.request.contextPath}/admin/cancel?aname=${auser.aname}"
style="align-content: center">注销用户</a></td>
</tr>
<tr>
<td><a href="${pageContext.request.contextPath}/quit"
style="align-content: center">退出登录</a></td>
</tr>
</table>
</form>
</body>
</html>
与登录,注册相关的controller代码
控制登录的controller
AdminController以及创建
package controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import po.Auser;
import service.AdminService;
import javax.annotation.Resource;
@Controller
public class AdminController {
@Resource
AdminService adminService;
// @RequestMapping("/admin")
// public String toLogin(@ModelAttribute("auser") Auser auser){
// return "login";//已配置视图解析器,在springmvc-servlet.xml文件中
// }
//@ModelAttribute("user") User user注释方法参数,参数user的值来源于addAccount()方法中的model属性。
// 此时如果方法体没有标注@SessionAttributes("user"),那么scope为request,如果标注了,那么scope为session
//Model会自动的把对象存到Request域中
@RequestMapping("/admin/login")
public String login(Auser auser, Model model){
boolean loginsucc = adminService.isLogin(auser);
boolean isnull = adminService.isnull(auser);
if (isnull){
if (loginsucc){
return "into";
}else {
model.addAttribute("msg", "用户名或密码错误!");
return "login";
}
}else {
model.addAttribute("msg" , "用户名和密码不能为空!!");
return "login";
}
}
@RequestMapping("/admin/cancel")
public String cancel(Auser auser, Model model){
adminService.Cancel(auser);
model.addAttribute("msg", "注销成功");//将后面的值传到前端相应名字的变量上面,就是后端向前端传值。
return "login";
}
@RequestMapping("/toregister")
public String toregister(){
return "register";
}
@RequestMapping("/admin/adduser")
public String addadmin(Auser auser, Model model){
//判断该用户是否存在,存在返回TRUE,跳转回login界面并提示用户存在
//不存在返回FALSE,对数据库进行增加操作,并返回登录界面提示注册成功
boolean regsucc = adminService.isLogin(auser);
boolean isnull = adminService.isnull(auser);
if (isnull){
if (regsucc){
model.addAttribute("msg", "该用户已存在!");
return "register";
}else {
adminService.addAuser(auser);
model.addAttribute("msg", "注册成功");
return "login";
}
}else {
model.addAttribute("msg", "用户名或密码不能为空!");
return "register";
}
}
@RequestMapping("/quit")
public String quit(){
return "login";
}
}
@Controller
是注明这是controller层的代码
@Resource
是将service进行依赖注入,既不指定name属性,也不指定type属性,则自动按byName方式进行查找。如果没有找到符合的bean,则回退为一个原始类型进行查找,如果找到就注入。
@RequestMapping
在Spring MVC 中使用 @RequestMapping 来映射请求,也就是通过它来指定控制器可以处理哪些URL请求,相当于Servlet中在web.xml中配置
Controller中的方法返回是都是视图信息,在这段代码中由于配置了视图解析器,所以可以直接写出jsp文件的名字,前缀后缀都在视图解析器中配置。
AdminService
这是AdminServiceImpl的接口
package service;
import po.Auser;
public interface AdminService {
boolean isLogin(Auser auser);//是否可以登录
Integer Cancel(Auser auser);//注销用户
int addAuser(Auser auser);//注册用户
boolean isnull(Auser auser);//判断用户名和密码是否为空
}
AdminServiceImpl
package service;
import dao.AdminDao;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import po.Auser;
@Service(value = "adminService")
public class AdminServiceImpl implements AdminService {
@Autowired
AdminDao adminDao;
@Override
public boolean isLogin(Auser auser) {
Integer rst = adminDao.findAUserCount(auser);//在数据库中查看有多少符合用户名和密码的用户,多于0个则可以登录,否则不行
if(rst>0){
return true;
}else {
return false;
}
}
@Override
public Integer Cancel(Auser auser) {
int cancel=adminDao.CancelAuser(auser);
return cancel;
}
@Override
public int addAuser(Auser auser) {
int addAuser=adminDao.addAuser(auser);
return addAuser;
}
@Override
public boolean isnull(Auser auser) {
if (auser.getAname()==""||auser.getApwd()==""){
return false;
}else {
return true;
}
}
}
AdminDao
//AdminDao也是一个接口,不要建成了Java类!!
package dao;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;
import po.Auser;
@Repository
//@Mapper注释用来表示该接口类的实现类对象交给mybatis底层创建,然后交由Spring框架管理。
@Mapper
public interface AdminDao {
//这里函数名需要和Mybatis文件中的id一一对应,必须一模一样
Integer findAUserCount(Auser auser);
Integer CancelAuser(Auser auser);
int addAuser(Auser auser);
}
AdminMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- com.dao.AdminDao对应Dao接口 -->
<mapper namespace="dao.AdminDao">
<!-- 查询用户信息 -->
<select id="findAUserCount" resultType="Integer" parameterType="auser">
select COUNT(*) from ausertable
where aname=#{aname} AND apwd=#{apwd}
</select>
<!-- 注销用户 -->
<delete id="CancelAuser" parameterType="auser" >
delete from ausertable
where aname=#{aname}
</delete>
<!-- 注册用户-->
<insert id="addAuser" parameterType="auser">
insert into ausertable (aname, apwd)
values (#{aname},#{apwd})
</insert>
</mapper>