目录
简介
先看看效果图
文件目录
登录注册相关代码
登录,注册,菜单jsp页面
与登录,注册相关的controller代码
本系统是基于SSM框架的图书管理系统,非常简单!!
实现功能:
1.实现通过访问数据库进行登录,错误则提示用户密码错误
2.实现用户注册功能,注册将会将新的用户加入数据库中,如果数据库中有相同的用户,则提示“该用户已存在”。登录注册功能都会判空;
3.登录成功之后将会进入目录,目录中选择注销用户,则会将回沪从数据库中删除,该用户无法再次登录,并跳转回登录界面;
4.进入管理界面将会进入图书管理界面,该界面实现分页展示,并对书籍总数进行统计
5.在管理界面实现了对书籍的增删查改。
登录界面
注册界面
菜单界面
实现分页的管理界面
添加界面
修改界面
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
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
delete from ausertable
where aname=#{aname}
insert into ausertable (aname, apwd)
values (#{aname},#{apwd})