仿牛客网社区项目(五)会话管理
会话管理
- HTTP的基本性质
- HTTP是简单的
- HTTP是可扩展的
- HTTP是无状态的,有会话的
- Cookie
- 是服务器发送到浏览器,并保存在浏览器端的一小块数据。
- 浏览器下次访问该服务器时,会自动携带块该数据,将其发送给服务器。
- Session
- 是JavaEE的标准,用于在服务端记录客户端信息。
- 数据存放在服务端更加安全,但是也会增加服务端的内存压力。
Http是无状态的,有会话的。简单来说即便是同一个浏览器向服务器发送多个请求,多个成功的请求之间是不存在练习的,这就带来了一个问题——用户没有办法在同一个网站中进行连续的交互。
用Cookies可以解决这个问题,是用Cookies可以创建有联系的会话。
浏览器访问服务器时,服务器会返回一个cookie给浏览器(在response header中可以找到),浏览器会自动保存cookie,下次访问服务器时,会将其带到request header中
//cookie 示例
@RequestMapping(path="/cookie/set",method= RequestMethod.GET)
@ResponseBody
public String setCookie(HttpServletResponse response){
//创建cookie
Cookie cookie = new Cookie("code", CommunityUtil.generateUUID());
//设置cookie的生效范围
cookie.setPath("/community/alpha");
//设置cookie的生存时间
cookie.setMaxAge(60*10);
response.addCookie(cookie);
return "set cookie";
}
获取cookie(值)的方法
@RequestMapping(path="/cookie/get",method= RequestMethod.GET)
@ResponseBody
public String getCookie(@CookieValue("code") String code){
System.out.println(code);
return "get cookie";
}
cookie的数据是存在客户端的,存在安全性隐患,切每次访问时都会将其发送给服务器,耗流量。因此就有了session
创建session并往里面存数据示例
//session示例
@RequestMapping(path="/session/set",method= RequestMethod.GET)
@ResponseBody
public String setSession(HttpSession session){
session.setAttribute("id",1);
session.setAttribute("name","Test");
return "set session";
}
从session中取值示例
@RequestMapping(path="/session/get",method= RequestMethod.GET)
@ResponseBody
public String getSession(HttpSession session){
System.out.println(session.getAttribute("id"));
System.out.println(session.getAttribute("name"));
return "get session";
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· spring官宣接入deepseek,真的太香了~