会话跟踪主要是用在用户页面点击不同的页面时,需要用到的技术点
会话:多次请求与响应的过程
1,url地址传递参数,实现页面跟踪技术
格式:传一个参数的
url?名=值
传两个参数的
url?名=值 &名=值
关键代码实例:
// 获得提交的数据
String userName = request.getParameter("userName");
String userPwd = request.getParameter("userPwd");
System.out.println(userName + " " + userPwd);
if ("abc".equals(userName) && "111".equals(userPwd)) {
response.sendRedirect("suc.jsp?n=" + userName + "&p=" + userPwd);
}
在登录成功的页面获取账号的密码信息;
<% //获取账号和密码 String names = request.getParameter("n"); String pwd = request.getParameter("p"); %> 账号:<%=names%> 密码:<%=pwd %>
url传递参数会将传递会显示条状页面的网页地址栏中
2,form表单的隐藏域传递参数
格式如下:
form>
<input type="hidden" name="名" value=“值”/>
<input type="hidden" name="名" value=“值”/>
</form>
使用技术的关键代码实例:
传递姓名和密码:
// 获得提交的数据
String userName = request.getParameter("userName");
String userPwd = request.getParameter("userPwd");
System.out.println(userName + " " + userPwd);
if ("abc".equals(userName) && "111".equals(userPwd)) {
request.setAttribute("aaa",userName);
//使用隐藏域,不能使用重定向请求
request.getRequestDispatcher("suc.jsp").forward(request, response);
}
在jsp页面中获取账号和密码:
<% //获取java代码中的属性 String name = (String)request.getAttribute("aaa"); %> <form action="addBlog" method="post"> //隐藏域获取jsp中的数据 <input type="hidden" name="uname" value="<%=name %>" /> </form>
3,Cookie会话跟踪技术;
Cookie是保存在浏览器缓存/或临时文件中的一系列文本数据
//创建Cookie
Cookie ck = new Cookie("名",值);
response.addCookie(ck);
//获取Cookie
Cookie[] cks = request.getCookies();
for(Cookie ck:cks){
String name = ck.getName();
String value = ck.getValue();
}
Cookie的作用:
1.跟踪特定对象:记录浏览过的商品
2.统计网页的访问次数
3.简化登录过程:自动登录
Cookie特点:
1.Cookie一定是保存在浏览器中的文本
2.Cookie不安全,容易泄露个人信息
3。用户可以禁用浏览器的Cookie功能
Cookie分为:
临时性Cookie:保存在浏览器的缓存中,当浏览器关闭后就没有了
持久性Cookie:保存在系统的临时文件夹中,达到有效期后失效
如何保存持久性Cookie:
只要给Cookie设置有效时间,就是一个持久性Cookie
Cookie ck = new Cookie("名",值);
ck.setMaxAge(60);
Cookie的使用技术:
关键代码实例:
// 获得提交的数据
String userName = request.getParameter("userName");
String userPwd = request.getParameter("userPwd");
System.out.println(userName + " " + userPwd);
if ("abc".equals(userName) && "111".equals(userPwd)) {
response.sendRedirect("suc.jsp?n=" + userName + "&p=" + userPwd);
//使用Cookie来保存数据
Cookie cookie = new Cookie("user", userName+","+userPwd);
//将获取的Cookie数据放在浏览器中
response.addCookie(cookie);
//设置时间
cookie.setMaxAge(100);
}
在jsp中获取Cookie保存的数据
<% String uname="",upwd=""; //获取Cookie中的键值 Cookie[] cs = request.getCookies(); if(cs!=null){ for(int i=0;i<cs.length;i++){ Cookie c =cs[i]; if(c.getName().equals("user")){ String str = c.getValue(); String[] s = str.split(","); uname = s[0]; upwd = s[1]; } } } %> <form action="LoginServlet" method="post"> 账号:<input type="text" name="userName" value="<%=uname %>"/> 密码:<input type="password" name="userPwd" value="<%=upwd %>"/> <input type="submit" value="提交"/> </form>
浏览器可以关闭Cookie功能
4,Seesion会话跟踪技术;
格式:
HttpSession 会话对象
//获得Session
HttpSession session = request.getSession();
//设置数据
session.setAttribute("名",值);
//获取数据
Object obj= session.getAttribute("名");
Seesion传递参数的关键代码实例:
// 获得提交的数据
String userName = request.getParameter("userName");
String userPwd = request.getParameter("userPwd");
System.out.println(userName + " " + userPwd);
if ("abc".equals(userName) && "111".equals(userPwd)) {
response.sendRedirect("suc.jsp?n=" + userName + "&p=" + userPwd);
//将账号保存到Session对象中
HttpSession session = request.getSession();
session.setAttribute("bbbb",userName);
}
java获取Session传递的参数;
HttpSession session = request.getSession();
String name =(String)session.getAttribute("bbbb");
//输出
System.out.println("用户名:"+name);
Session会话跟踪式存在于服务器的Cookie会话跟踪是存在与浏览器的