基于SSM框架的简单图书管理系统

     阅读:66

目录

简介

先看看效果图

文件目录

​ ​

登录注册相关代码

登录,注册,菜单jsp页面

与登录,注册相关的controller代码


简介

        本系统是基于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>密&nbsp;&nbsp;&nbsp;码:</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>密&nbsp;&nbsp;&nbsp;码:</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>