浏览器禁用cookie后,如何使用session 或者 保持登录状态?

1、URL重写

2、表单隐藏字段。

sessionid是存储在cookie中的,解决方案如下:

  • Session URL重写,保证在客户端禁用或不支持COOKIE时,仍然可以使用Session

  • session机制。session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息。

  • 当程序需要为某个客户端的请求创建一个session时,服务器首先检查这个客户端的请求里是否已包含了一个session标识(称为session id),如果已包含则说明以前已经为此客户端创建过session,服务器就按照session id把这个session检索出来使用(检索不到,会新建一个),如果客户端请求不包含session id,则为此客户端创建一个session并且生成一个与此session相关联的session id,session id的值应该是一个既不会重复,又不容易被找到规律以仿造的字符串,这个session id将被在本次响应中返回给客户端保存。 保存这个session id的方式可以采用cookie,这样在交互过程中浏览器可以自动的按照规则把这个标识发挥给服务器。一般这个cookie的名字都是类似于 SEEESIONID。但cookie可以被人为的禁止,则必须有其他机制以便在cookie被禁止时仍然能够把session id传递回服务器。

  1. 经常被使用的一种技术叫做URL重写,就是把session id直接附加在URL路径的后面。
  2. 还有一种技术叫做表单隐藏字段。就是服务器会自动修改表单,添加一个隐藏字段,以便在表单提交时能够把session id传递回服务器。

比如:

<form name="testform" action="/xxx"> <input type="hidden" name="jsessionid" value="ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764″> <input type="text"> </form>
  • 1

URL重写:

http://www.test.com/test;jsessionid=ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764

3、token方式 + localStorage 来替代 cookie

但是上述两种方法不太友好,

第一个显示在地址栏,

如果浏览器不支持Cookie或用户阻止了所有Cookie,服务器端可以把会话ID附加在HTML页面中所有的URL上,这些页面作为响应发送给客户。这样,当用户单击URL时,会话ID被自动作为请求行的一部分而不是作为头行发送回服务器。这种方法称为URL重写(URL rewriting)。

一般来说,URL重写是支持会话的非常健壮的方法。在不能确定浏览器是否支持Cookie的情况下应该使用这种方法。然而,使用URL重写应该注意下面几点:

1.如果使用URL重写,应该在应用程序的所有页面中,对所有的URL编码,包括所有的超链接和表单的action属性值

2.应用程序的所有的页面都应该是动态的。因为不同的用户具有不同的会话ID,因此在静态HTML页面中无法在URL上附加会话ID。

3.所有静态的HTML页面必须通过Servlet运行,在它将页面发送给客户时会重写URL

第二个:使用这种方式时,需要页面中本身含有表单或自己构建一个表单来使用。可以传递更多的字符且不需要进行字符编码

隐藏域目的:想要提取上一页的某些信息,但在上一页又不能显示的这些东西就采用藏域 这里就是为了在

 

正式由于cookie有可能被禁用,而我们还想要跟踪用户的登录状态,上面两种方式的弊端又太大,所有提出来新的解决方案,token 而token和session是不同的,但都可以用来表示用户状态,具体区别如下:

https://blog.youkuaiyun.com/love_onefly/article/details/80738888

token相比较session优点明显:1体积更小,因为不存储用户数据 2不用想session呢样根据session_id去检索查找对比,而只需要通过算法计算对比即可,这点在服务器重启或者服务器出现问题等时候尤其有用,session可能会无法登陆而token不会受到影响。

token使用具体的方式具体如下:https://blog.youkuaiyun.com/Future1994/article/details/111112875 

像session_Id 和token在服务器端一般都是有时间限制的 所以 不用担心时效性的问题

 

 

 

参考文章:https://blog.youkuaiyun.com/weixin_45459224/article/details/103367144

禁用Cookie后,Session的实现可以采取以下方法: ### URL重写 URL重写是一种在禁用Cookie的情况下实现Session的常见方法。在每次向服务器发送请求时,将Session ID作为参数附加到URL后面。服务器接收到请求后,从URL中提取Session ID,从而找到对应的Session。 例如,在Java Web应用中,可以使用`response.encodeURL()`或`response.encodeRedirectURL()`方法来自动对URL进行重写。示例代码如下: ```java import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; public class SessionExample { public static void main(String[] args) { // 假设这是一个Servlet中的方法,包含HttpServletRequest和HttpServletResponse对象 HttpServletRequest request = null; // 初始化request对象 HttpServletResponse response = null; // 初始化response对象 // 获取或创建Session HttpSession session = request.getSession(); // 对URL进行重写 String url = response.encodeURL("/examplePage.jsp"); // 重定向到重写后的URL try { response.sendRedirect(url); } catch (Exception e) { e.printStackTrace(); } } } ``` ### 表单隐藏域 在表单提交时,可以将Session ID作为隐藏域添加到表单中。当用户提交表单时,Session ID会随着表单数据一起发送到服务器。示例代码如下: ```html <!DOCTYPE html> <html> <body> <form action="/submitForm" method="post"> <input type="hidden" name="JSESSIONID" value="${session.id}"> <input type="text" name="username" placeholder="Username"> <input type="submit" value="Submit"> </form> </body> </html> ``` ### 手动管理Cookie 虽然用户禁用浏览器Cookie功能,但在服务器端仍然可以手动设置和管理Cookie。可以通过设置响应头信息,将Session ID以自定义的方式发送给客户端,并在后续请求中手动解析和使用。示例代码如下: ```java import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; public class ManualCookieManagement { public static void main(String[] args) { // 假设这是一个Servlet中的方法,包含HttpServletRequest和HttpServletResponse对象 HttpServletRequest request = null; // 初始化request对象 HttpServletResponse response = null; // 初始化response对象 // 获取或创建Session HttpSession session = request.getSession(); // 手动设置Cookie String sessionId = session.getId(); response.setHeader("Set-Cookie", "JSESSIONID=" + sessionId + "; path=/"); } } ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值