《JavaWeb视频教程》(p8~p9)

阅读: 评论:0

《JavaWeb视频教程》(p8~p9)

《JavaWeb视频教程》(p8~p9)

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小时内删除。

标签:视频教程   JavaWeb
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23