jsp学习笔记------session浏览器变量的用法


session变量属于浏览器变量,只有在下列情况下才会清除:

1. 浏览器关闭;
2. 服务器关闭
3. 删除session代码
4. session 代码删除

session 运用于浏览器记住登录账户,用于一定时间内在该网站的其他页面免登录,session 存在于30分钟,这个时间也可以手动设置

//创建一个session变量
session.setAttribute("变量名", "变量值");
//设置session的最大保存时间
session.setMaxInactiveInterval(30);
//清除名为"变量名"的session变量的值
session.removeAttribute("变量名");
//清除session变量
session.invalidate();

下面是一个网站所有网页登录一次后一定时间内免登录的例子,也避免通过网页地址免登录直接进入该网站其他页面的风险
登录界面login.jsp

<form action="Servlet.jsp" method="post">
    请输入账号:<input type="text" name="userid"><br/>
    请输入密码:<input type="password" name="userpwd"><br/>
    <input type="submit" value="登录">
</form>
${msg1}
${msg2}

服务器页面Servlet.jsp

<%
    if(request.getParameter("userid").equals("admin") 
    && request.getParameter("userpwd").equals("123456")){
        //登陆成功,设置session变量,这样在其他页面均可以直接访问该变量
        session.setAttribute("userIsLogined",true);
        response.sendRedirect("index.jsp");
    } else{
        //登录失败,返回login.jsp页面,并传回提示信息
        request.setAttribute("msg1", "账号或密码输入有误,登录失败!");
        request.getRequestDispatcher("login.jsp").forward(request, response);
    }
%>

主页index.jsp

<c:if test="${not empty userIsLogined}">
    登录成功!你现在看到的是主页..
</c:if>
<c:if test="${empty userIsLogined}">
    <%request.setAttribute("msg2", "请先登录!");%>
    <%request.getRequestDispatcher("login.jsp").forward(request, response);%>
</c:if>

在登录成功的情况下创建session变量,在主页判断session变量是否存在,存在则进入主页,否则返回登录界面,提示未登录…

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
<br>JSP Login.jsp <br><br><br><br><%@ page contentType="text/html;charset=GB2312" %><br><br><html><br><head><br><title>CH5 - Login.jsp</title><br></head><br><body><br><br><h2>javax.servlet.http.HttpSession - session 对象</h2> <br><form action=Login.jsp method="POST" ><br>Login Name: <input type="text" name="Name"><br><br>Login Password: <input type="text" name="Password" ><br><br><input type="submit" value="Send"><br><br><form><br><br><% if (request.getParameter("Name") != null &&<br> request.getParameter("Password") != null) { <br>String Name = request.getParameter("Name");<br>String Password = request.getParameter("Password");<br><br>if (Name.equals("mike") && Password.equals("1234")) { <br>session.setAttribute("Login", "OK");<br>response.sendRedirect("Member.jsp");<br>}<br>else { <br>out.println("登录错误,请输入正确名称"); <br>} <br>}<br>%><br><br></body><br></html> <br><br><br>JSP Member.jsp <br><br><br><br><%@ page contentType="text/html;charset=GB2312" %><br><br><html><br><head><br><title>CH5 - Member.jsp</title><br></head><br><body><br><br><h2>javax.servlet.http.HttpSession - session 对象</h2> <br><% <br>String Login = (String)session.getAttribute("Login");<br><br>if (Login != null && Login.equals("OK")) { <br>out.println("欢迎进入");<br>session.invalidate(); <br>} <br>else { <br>out.println("请先登录,谢谢") ;<br>out.println("<br>经过五秒之后,网页会自动返回Login.jsp");<br><br>response.setHeader("Refresh","5;URL=Login.jsp"); <br>}<br>%><br><br></body><br></html> <br>

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值