当前位置:首页 > 后端开发 > 用户登录用session和cookie来实现

用户登录用session和cookie来实现

7个月前 (05-20)67

1.      用户通过手机号mobile登录或注册,此时调用一个接口,通过该接口得到该手机号对应的userid,调用该接口后,把userid以及对应的手机号存到session中,代码如下:

HttpSessionsession=beat.getRequest().getSession();
session.setAttribute("useridsession",userid);
session.setAttribute("usermobile",mobile);

2.  判断用户是否已经登录或注册

<pre name="code" class="java">HttpSessionsession=beat.getRequest().getSession();
String usermobile=(String)session.getAttribute("usermobile");
String userid=(String)session.getAttribute("useridsession");
if (usermobile !=null && !usermobile.equals("")) {
   此时用户已经登录了
}

 
  

3. 退出登录

HttpSessionsession=beat.getRequest().getSession();
session.removeAttribute("useridsession");
session.removeAttribute("usermobile");

如果把代码部署到一台机器上,那没什么问题;但是如果把代码部署到两台至多台机器上就有问题了,因为一个用户登录时只有一台机器假设是A机器接受请求并在该台机器上把userid和手机号存在session里,但是该用户在发起别的请求时被另一台机器假设是B机器通过  //

HttpSessionsession=beat.getRequest().getSession();
String usermobile=(String)session.getAttribute("usermobile");
String userid=(String)session.getAttribute("useridsession");
if (usermobile !=null && !usermobile.equals("")) {
   此时用户已经登录了
}

;得到的useridmobile都为空

 

为了尽快上线,采用cookie来实现登录或注册的功能

1.绑定手机号的时候

Cookie useridsession = new Cookie("useridsession", userid);
useridsession.setPath("/");
usermobile = new Cookie("usermobile",mobile);
usermobile.setPath("/");
 
beat.getResponse().addCookie(useridsession);
beat.getResponse().addCookie(usermobile);

2.判断是否登录或注册的时候

String userid = "";
String usermobile = "";
Cookie[] cookies = beat.getRequest().getCookies();
if(cookies != null) {
for (Cookie c : cookies) {
System.out.println(c.getName() + "--->" + c.getValue());
if (c.getName().equals("useridsession")) {
userid = c.getValue();
} else if (c.getName().equals("usermobile")) {
usermobile = c.getValue();
         }
  }
}
 
if (usermobile !=null && !usermobile.equals("")) {
   此时用户已经登录了
}

3.退出登录

Cookie useridsession = newCookie("useridsession", null);
useridsession.setMaxAge(0);
useridsession.setPath("/");
beat.getResponse().addCookie(useridsession);
 
Cookie usermobile = newCookie("usermobile", null);
usermobile.setMaxAge(0);
usermobile.setPath("/");
beat.getResponse().addCookie(usermobile);

作者:lulu19870526
来源链接:https://blog.csdn.net/lululove19870526/article/details/41943051

标签: CookieSession

“用户登录用session和cookie来实现” 的相关文章

浅谈COOKIE和SESSION关系和区别等

浅谈COOKIE和SESSION关系和区别等

COOKIE介绍 cookie 常用于识别用户。cookie 是服务器留在用户计算机中的小文件。每当相同的计算机通过浏览器请求页面时,它同时会发...

用户登录的session以及cookie

用户登录的session以及cookie

session: 保存在服务端,随着服务端的死亡而死亡,或者是超过sesison设置的过期时间死亡(默认30分钟)。 cookie:保存在客户端,在不持久话的情况下随着...

.NET Core2.0+MVC 用session,cookie实现的sso单点登录

.NET Core2.0+MVC 用session,cookie实现的sso单点登录

基于.NET Core2.0+MVC 用session,cookie实现的sso单点登录 博主刚接触.NET Core2.0,想做一个单点登录的demo,所以参考了一些...

cookie session token区别(简单原理理解)

cookie session token区别(简单原理理解)

HTTP 协议是一种无状态协议,即每次服务端接收到客户端的请求时,都是一个全新的请求,服务器并不知道客户端的历史请求记录;Session 和 Cookie 的主要目的就是为了...

Cookie和Session的原理及区别

Cookie和Session的原理及区别 1.Cookie Cookie是服务器在本地机器上存储的小段文本并随每一个请求发送至同...

token,session,以及cookie的联系和区别

token,session,以及cookie的联系和区别

  token就是令牌,比如你授权(登录)一个程序时,他就是个依据,判断你是否已经授权该软件;cookie就是写在客户端的一个txt文件,里面包括你登录信息之类的,...

cookie和session的区别,联系

cookie和session的区别,联系

一、cookie和session关系图: 二、Session的概念 Session 是存放在服务器端的,类似于Session结构来存放用户数据,当...

深入理解cookie和session

深入理解cookie和session

cookie和session在java web开发中扮演了十分重要的作用,本篇文章对其中的重要知识点做一些探究和总结。(转发自https://www.cnblogs.com/roy-bl...

JavaWeb之Servlet:Cookie 和 Session

JavaWeb之Servlet:Cookie 和 Session

会话 现实生活中我们会用手机跟对方对话,拿起手机,拨号,然后对面接听,跟着互相通话,最后会话结束。 这个过程也可以用我们的B/S模式来描述:   &nb...

Cookie与Session概念与区别

Cookie与Session概念与区别

Cookie 一、概述 HTTP 协议是无状态的,为了让 HTTP 协议尽可能简单,使得它能够处理大量事务。HTTP 引入 Cookie...