本文主要是介绍《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 = request.getCookies();if(cookies != null){for(Cookie cookie:cookies){if(cookie.getName().equals("uname")){uname = cookie.getValue();}} }%><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 = request.getParameter("uname");String pwd = request.getParameter("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 = request.getCookies();for(Cookie cookie:cookies){out.print(cookie.getName()+"--"+cookie.getValue());}%>
</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 = request.getCookies();if(cookies != null){for(Cookie cookie:cookies){if(cookie.getName().equals("uname")){uname = cookie.getValue();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,如果匹配成功,那么说明该用户不是第一次访问。
这篇关于《JavaWeb视频教程》(p8~p9)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!