Java Session获取/销毁

Session会话机制,它是保存在服务器里面的,就是当我们进入一个浏览器,浏览器会
自动给我们创建一个session保存用户的信息,当关闭浏览器的时候,session就销毁
了,Session在web项目中是经常用到的。下面是session的用法。
Session在web项目中的登录是基本都用上的,那么就以账号登录为例:
代码只是展示了最里面判断登录成功并保存数据到session的

//获取session里的验证码	
String sessIdentityKey=	session.getAttribute("identityKey").toString();
//判断登录页传递过来的不等空并且等于session里的验证码
if(Tools.isNotNull(identityKey)&&identityKey.equalsIgnoreCase(sessIdentityKey)) 	{
	//根据登录页传过来的用户名跟密码查询到用户信息
	PwUsers users=pwUsersService.login(userName, enterpassword);
	if (users!=null) {
		session.setAttribute("SESSION_USER", users);
		//把用户名存到session
		request.getSession().setAttribute("suserName", users.getUserName());
		//把用户id存到session
		request.getSession().setAttribute("suserId", users.getUserId());	
		   jsonReturn.setState(true);
		jsonReturn.setMsg("登录成功");
		}else {
			jsonReturn.setState(false);
			jsonReturn.setMsg("账号或密码错误");
		}
	}else {
		jsonReturn.setState(false);
		jsonReturn.setMsg("验证码不正确");
}		

登录成功了,并且将用户名跟用户id保存到session了,要现在我需在前台获取到
session的数据,因为session是服务端的变量。jsp页面是客户端,那么怎么在客户
端获取到session呢。
在代码块 ------------→ <% Java 代码(变量:_jspService方法的局部变量) %>
获取session数据

<%
 	String sessionName=(String)request.getSession().getAttribute("suserName");
	Integer sessionUserId=(Integer)request.getSession().getAttribute("suserId");
%>

Js:

var UserID = <%=sessionUserId%>;
//--------- 获取到是否登录成功保存的用户ID --------------
if (UserID==null) {
    	$("#lal").html("");
		$("#lal").append("<a href='#'>免费注册</a><span></span><a href='#'>立即登录</a>")    

在这里插入图片描述

}else {
        $("#lal").html("");
        $("#lal").append("欢迎你:<a href='#'><%=sessionName%></a><a href=#'onclick='LoginOut()'>注销</a></label>")    
}

在这里插入图片描述
在这里插入图片描述
有服务端验证登录成功保存到session,客户端获取session数据判断绑定,那么最后就
是要销毁session注销账号登录了,这个销毁跟关闭浏览器的销毁不同的就是,这个是
主动销毁,不同关闭浏览器,直接以代码销毁session达到注销账号的操作。

//============================ 注销 =============================
    function LoginOut() {
        if (window.confirm("确定要注销吗?")) {
            $.post("${ctx}/servlet/mainServlet?fun=loginOut", function (msg) {
            	 	location.reload();
             });
     	}
}
很简单,直接将整个session销毁掉,invalidate()
private void loginOut(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		request.getSession().invalidate();
}
  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值