p8 cookie应用案例
建议cookie中,只保存英文和数字,否则需要进行编码,解码处理
其中login.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 uname;%><%Cookie[] cookies = Cookies();if(cookies != null){for(Cookie cookie:cookies){Name().equals("uname")){uname = Value();}} }%><form action="check.jsp" method="post">用户名:<input type="text" name="uname" value="<%=(uname==null?"":uname)%>"><br/>密码:<input type="password" name="upwd"><br/><input type="submit" name="登陆"><br/></form>
</body>
</html>
check.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><%request.setCharacterEncoding("utf-8");String name = Parameter("uname");String pwd = Parameter("upwd");//将用户名加入到Cookie 中Cookie cookie = new Cookie("uname",name);//不要中文response.addCookie(cookie);response.sendRedirect("result.jsp");%>
</body>
</html>
result.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><%//客户端Cookie[] cookies = Cookies();for(Cookie cookie:cookies){out.Name()+"--"Value());}%>
</body>
</html>
p9 session执行机制
login.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 uname;%><%boolean flag = false;Cookie[] cookies = Cookies();if(cookies != null){for(Cookie cookie:cookies){Name().equals("uname")){uname = Value();flag = true;}} if(!flag){out.print("cookie已失效");}else{out.print("cookie: " + uname);}}%><form action="check.jsp" method="post">用户名:<input type="text" name="uname" value="<%=(uname==null?"":uname)%>"><br/>密码:<input type="password" name="upwd"><br/><input type="submit" name="登陆"><br/></form>
</body>
</html>
运行结果:
2. session:会话
a. 浏览网站:开始->关闭
b. 购物:浏览,付款,退出
c. 电子邮件:浏览,写邮件,退出
开始->结束
客户端第一次请求服务端的时候,(JESSIONID不存在,所以试图匹配,但是失败)服务端会产生一个session对象(用于保存该用户的信息)。
并且这个session都会自动带有一个唯一的sessionID(用于区分其他session),
服务端都会产生一个cookie,并且该cookie的name=JSESSIONID(cookie),value=服务器端sessionID的值。
然后服务端,会在响应客户端的同时,将该cookie发送给客户端,至此客户端就有了一个cookie(JESSIONID)
因此,客户端的cookie就可以和服务器端的session一一对应。(JESSIONID sessionID)
客户端第二/n次请求服务端的时候: 服务端会先用客户端的cookie中的JESSIONID,去服务端的session中匹配sessionID,如果匹配成功,那么说明该用户不是第一次访问。
本文发布于:2024-01-28 20:14:59,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/17064441049998.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |