目录
首页功能
流程图
整体思路:输入url,跳转发送请求到IndexController,在indexController请求转发到跳转到index.jsp页面。index.jsp页面通过window.location去请求Usertroller中的toLogin方法,toLogin方法请求转发跳转到login.jsp登录页面。
1.输入url跳转请求,请求IndexController。
2.请求到IndexController,接着直接请求转发跳转到index.jsp。
IndexController
package com.bjpowernode.crm.web.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class IndexController {
/*
理论上,给Controller方法分配url:http://127.0.0.1:8080/crm/
为了简便,协议://ip:port/应用名称必须省去,用/代表应用根目录下的/
*/
@RequestMapping("/")
public String index(){
//请求转发
return "index";
}
}
请求转发这里有视图解析器,所以可以省略,完整的为/WEB-INF/pages/index.jsp,访问这个页面。
index.jsp
该jsp在tomcat运行是个页面响应给浏览器,该页面通过window.location发请求访问UserController中的toLogin方法。(响应信息返回,一个资源目录对应一个controller,所以login.jsp是在user目录下,我们也新创建个UserController)
UserController
@Controller
public class UserController {
@Autowired
private UserService userService;
/**
* url要和controller方法处理完请求之后,响应信息返回的页面的资源目录保持一致
*/
@RequestMapping("/settings/qx/user/toLogin.do")
public String toLogin(){
//请求转发到登录页面
return "settings/qx/user/login";
}
}
请求转发到login.jsp后,页面响应给浏览器。
用户登录
整体思路: 输入用户名和密码点登录按钮,发请求到UserController,UserController调用service层和mapper层,去查询并返回user对象。对返回的user对象,判断非空、是否过期、账号状态、ip是否符合等条件。都符合则登录成功,否则登录失败。给前端返回响应信息。
tbl_user表
LoginDto
LoginDto继承User实体类,带上isRemPwd表示是否记住密码。
UserController
返回ReturnObject对象,封装code和message。
@Controller
public class UserController {
@Autowired
private UserService userService;
@RequestMapping("/settings/qx/user/Login.do")
@ResponseBody
public ReturnObject login(LoginDto loginDto, HttpServletRequest request, HttpServletResponse response, HttpSession session){
// //把request封装进loginDto
// loginDto.setData(request);
User user = userService.QueryByLoginActAndPwd(loginDto);
//根据返回的user对象,进行非空、过期、状态、ip的判断
if (user != null){
//把时间转成字符串,用String的compareTo方法比较大小
//获取当前时间
Date date = new Date();
//调用工具类中方法 将日期转成数据库中 日期的格式
String nowStr = DateTimeUtils.formatDateTime(date);
//判断是否过期
if(nowStr.compareTo(user.getExpireTime()) > 0){
//账号过期登陆失败
return new ReturnObject(Constants.RETURN_OBJECT_CODE_FAIL,"账号已过期");
} else if ("0".equals(user.getLockState())) {
//账号被锁定登陆失败
return new ReturnObject(Constants.RETURN_OBJECT_CODE_FAIL,"账号锁定");
} else if (! user.getAllowIps().contains(request.getRemoteAddr())) {
//ip不符合
return new ReturnObject(Constants.RETURN_OBJECT_CODE_FAIL,"ip不符合");
}else {
//登陆成功
ReturnObject returnObject = new ReturnObject(Constants.RETURN_OBJECT_CODE_SUCCEED, "登陆成功");
//把用户名存到session中
session.setAttribute(Constants.SESSION_USER,user);
//判断isRemPwd,是否需要把用户名密码存到cookie
if ("true".equals(loginDto.getIsRemPwd())){
Cookie c1 = new Cookie("loginAct", loginDto.getLoginAct());
c1.setMaxAge(10*24*60*60);
response.addCookie(c1);
Cookie c2 = new Cookie("loginPwd", loginDto.getLoginPwd());
c2.setMaxAge(10*24*60*60);
response.addCookie(c2);
}else {
//没有选择记住密码,删除cookie
Cookie c1 = new Cookie("loginAct", "1");
c1.setMaxAge(0);
response.addCookie(c1);
Cookie c2 = new Cookie("loginPwd", "1");
c1.setMaxAge(0);
response.addCookie(c2);
}
return returnObject;
}
}else{
//user为空,返回相应的ReturnObject对象
return new ReturnObject(Constants.RETURN_OBJECT_CODE_FAIL,"用户名或密码错误");
}
}
}
controller记得要被springmvc的配置文件或配置类扫描到
UserServiceImpl
@Service("UserService")
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
/**
* 根据用户名和密码查询user对象
* @param loginDto
* @return
*/
@Override
public User QueryByLoginActAndPwd(LoginDto loginDto) {
//取出user的用户名和密码,封装为map<String ,Object>
String loginAct = loginDto.getLoginAct();
String loginPwd = loginDto.getLoginPwd();
Map<String, Object> map = new HashMap<>();
map.put("loginAct",loginAct);
map.put("loginPwd",loginPwd);
//调用mapper查询方法
User user = userMapper.selectByLoginActAndPwd(map);
return user;
}
}
UserMapper
public interface UserMapper {
/**
* 根据用户名和密码查询用户
* @param map
* @return
*/
User selectByLoginActAndPwd(Map<String,Object> map);
}
Mapper接口要么添加@Mapper注解,要么让spring配置文件扫描到sql映射文件。
当查询完返回到UserController,做一系列判断,返回登录成功或失败的ReturnObject对象。
其中判断过期时间,通过把当前时间转成数据库对应格式的时间的字符串,用string中的compareTo方法比较大小来判断是否过期。
返回的ReturnObject中的code,单独写在Constants中,需要时直接调用。
最后返回给前端json,要带上@RequestBody注解。
需要注意的是:
发送 登录请求后,前端 接收到返回对象,code为1浏览器请求WorkbenchIndexController,来跳转到主页面index.jsp。
@Controller
public class WorkbenchIndexController {
@RequestMapping("/workbench/index.do")
public String index(){
//跳转到主页面
return "workbench/index";
}
}