一、login登录业务
注意事项:登录时要将用户存储到哪的问题(redis,cookie,session);
步骤:
1、控制类定义post请求方法,参数包含用户名username和密码password
2、服务业务类,使用mapper查询用户名是否存在,再匹配密码是否一致
3、将用户存入cookie、redis、session
4、返回同一返回类(自定义的类,包含code,message,data)
1、使用cookie
- 存入cookie
方法中需带有HttpServletResponse
步骤:创建cookie对象,setMaxAge()设置有效时长,SetPath()设置作用域
Cookie cookie=new Cookie("key","value");
cookie.setPath("/");
cookie.setMaxAge(3600);
response.addCookie(cookie);
- 获取cookie信息
方法中需带有HttpServletRequest
// 得到所有的cookie
Cookie[] cookies = request.getCookies();
//对所有的cookie进行遍历
for(Cookie cookie:cookies){
if(cookies.getName().equals("LoginAct")
String LoginAct = cookie.getvalue();
}
- cookie的其他方法
new Cookie(String name,String value)
创建一个cookie对象 必须传入cookie的名字和cookie的值
getValue():
得到cookie保存的值
getName():
得到cookie的名称
setMaxAge(int expiry):
设置cookie的有效期,默认为-1。这个如果设置负数,表示客服端关闭,cookie就会删除。0表示马上删除。正数表示有效时间,单位是秒。
setPath(String uri):
设置cookie的作用域
2、使用session
- 存入session
//第1步:通过request对象创建Session实例
HttpSession session = req.getSession();
//第2步:将用户信息(user)保持到session中
session.setAttribute("user", user);
化简为
request.getSession().setAttribute("key",value);
- 获取session信息
//第1步:通过request对象获取session实例
HttpSession session = req.getSession();
//第2步:通过session对象获取用户信息(user)
User user = (User) session.getAttribute("user");
化简
request.getSession().getAtrribute("key");
3、使用redis
- 存入redis
1、引入redis依赖
2、application.yml中添加redis配置
3、创建redisConfig类,其中添加
注意:此处的value为string类型,json转string——》JSON.toJSONString(对象);
//把用户信息存入redis set(key,value,过期时长,过期格式) 设置三天过期
stringredistemplate.opsforvalue().set("user" + "/" + uuid, userjoin, 3, timeunit.days);
- 获取redis信息
1、将得到的数据转换为json——>JSONObject.parseObject()
//根据key获取redis的值
stringRedisTemplate.opsForValue().get("user" + "/" + struuid);