本文章代码使用了request内置对象,可先查看之前的文章学习。
前言
一、Session使用环境
二、常用方法
三.使用示例
1. 设计某系统登陆模块,该模块需满足以下条件:
2.login.jsp登录页面
2.check.jsp校验页面
3. success.jsp成功登录页面
4.loginout.jsp注销用户
前言
作为个人学习记录,有误和不清楚地方可评论指正,互相学习共同进步!谢谢!
一、Session使用环境
“session” 对象代表服务器与客户端所建立的会话,当需要在不同的JSP页面中保留客户信息的情况下使用,比 如在线购物、客户轨迹跟踪等。
二、常用方法
session.setAttribute(String key, Object obj): //使用指定的名称将这个对象绑定到这个会话上;
session.getAttibute(String key): //返回绑定到该会话的对象;
session.removeAttribute(String key): //session对象调用该方法移掉关键字key对应的对象。
三.使用示例
1. 设计某系统登陆模块,该模块需满足以下条件:
a.当用户名和密码正确时(用户名密码自己设定),显示用户登录成功信息。
b. 当用户名和密码错误时,则跳转到登陆界面,并提示用户名或密码错误!
c. 当用户未输入用户名,密码直接访问主界面时,禁止访问!
d.当用户点击注销时,退出系统,返回到登陆界面
2.login.jsp登录页面
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>My JSP 'index.jsp' starting page</title><meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">-->
</head>
<body><form action="check.jsp" method="post"><%String flag= request.getParameter("flag"); %><strong>用户名</strong>:<input name="username" type="text" size="12"><strong>密 码</strong>:<input name="password" type="password" size="12"><%if(flag!=null&&flag.equals("error")){ %><font color="red">用户名或者密码错误</font><%} %><input type="submit" name="Submit2" value="进入"> <input name="Submit" type="reset" value="重置"></form> </div><br>
</body>
</html>
2.check.jsp校验页面
<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>密码校验</title>
</head>
<body>
<% request.setCharacterEncoding("utf-8");String user= request.getParameter("username");String pass= request.getParameter("password");if(user.equals("张三")&&pass.equals("123")){session.setAttribute("username", user);//将username绑定userRequestDispatcher rd= request.getRequestDispatcher("success.jsp"); //request类跳转rd.forward(request, response);}else{RequestDispatcher rd= request.getRequestDispatcher("login.jsp?flag=error") ; rd.forward(request, response);}%>
</body>
</html>
session.setAttribute("username", user);//将username绑定user
3. success.jsp成功登录页面
<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%String user=(String)session.getAttribute("username");//获取到usernameif(user==null){response.sendRedirect("login.jsp") ;}
%>
<%=user %>你好,欢迎使用本系统!<a href="loginout.jsp">退出/注销</a>
</body>
</html>
String user=(String)session.getAttribute("username");//获取到username
4.loginout.jsp注销用户
<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%session.removeAttribute("username");//注销此用户response.sendRedirect("login.jsp");//跳转回登录页面,此时“username”这个用户已经被注销
%>
</body>
</html>
点击退出/注销按钮后退回登录页面