crm首页功能和用户登录

目录

首页功能

用户登录


首页功能

 

流程图

 整体思路:输入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";
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值