Java web的会话跟踪技术

会话跟踪主要是用在用户页面点击不同的页面时,需要用到的技术点

 

会话:多次请求与响应的过程

 

 

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会话跟踪是存在与浏览器的

你可能感兴趣的:(url会话,Cookie会话,Seession会话,Java Web,隐藏域会话)