会话跟踪主要是用在用户页面点击不同的页面时,需要用到的技术点
会话:多次请求与响应的过程
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会话跟踪是存在与浏览器的