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

目录

简介

先看看效果图

文件目录

​ ​

登录注册相关代码

登录,注册,菜单jsp页面

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


简介

        本系统是基于SSM框架的图书管理系统,非常简单!!

        实现功能:

        1.实现通过访问数据库进行登录,错误则提示用户密码错误

        2.实现用户注册功能,注册将会将新的用户加入数据库中,如果数据库中有相同的用户,则提示“该用户已存在”。登录注册功能都会判空;

        3.登录成功之后将会进入目录,目录中选择注销用户,则会将回沪从数据库中删除,该用户无法再次登录,并跳转回登录界面;

        4.进入管理界面将会进入图书管理界面,该界面实现分页展示,并对书籍总数进行统计

        5.在管理界面实现了对书籍的增删查改。

先看看效果图

登录界面

基于SSM框架的简单图书管理系统_第1张图片

注册界面

基于SSM框架的简单图书管理系统_第2张图片

菜单界面

基于SSM框架的简单图书管理系统_第3张图片

实现分页的管理界面

基于SSM框架的简单图书管理系统_第4张图片

 

添加界面

基于SSM框架的简单图书管理系统_第5张图片

删除基于SSM框架的简单图书管理系统_第6张图片 

修改界面

基于SSM框架的简单图书管理系统_第7张图片 

文件目录

基于SSM框架的简单图书管理系统_第8张图片 基于SSM框架的简单图书管理系统_第9张图片

 

 

登录注册相关代码

登录,注册,菜单jsp页面

login.jsp界面

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>


登录



用户名:
密   码:
${msg}

 在此界面进行登录,点击登录将通过from表单action指定的路径进行提交至Controller(AdminController文件)

点击注册,将会通过超链接的路径访问对应的controller中的方法

regist.jsp 页面

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>


注册


用户名:
密   码:
${msg}

into.jsp(菜单界面)


<%@ page contentType="text/html;charset=UTF-8" language="java" %>


    菜单



进入书城
注销用户
退出登录

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

控制登录的controller

AdminController以及创建

基于SSM框架的简单图书管理系统_第10张图片 

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





    
    

    
    
	    delete from ausertable
		where aname=#{aname}
    

	
	
		insert into ausertable (aname, apwd)
		values (#{aname},#{apwd})
	

你可能感兴趣的:(java,spring,maven,intellij-idea,java-ee)