Java Web的request、response和cookie操作

补上一节课内容

index关键代码:
<form action="login_do".jsp> method="post">
	<label>用户名</label><input type="text" name="username">
	<label>密码</label><input type="text" name="password">
	<input type="submit" value="登陆">
</form>

其中的method有两个选项可选,post和get,但get的相对传输量小,且保密性低,我们通常用post。
使用post可能会出现乱码问题,我们在接受页中用设置编码方式的方法处理
即:

request.setCharacterEncoding("UTF-8");

submit是提交按钮,这里不可用button按钮,提交之后,转至login_do.jsp继续操作

login_do关键代码
<%
	request.setCharacterEncoding("UTF-8");
	//接受传来的变量
	String username=request.getParameter("username");
	String password=request.getParameter("password");
	//输出
	out.print("用户名:"+username);
	out.print("密码:"+password);
<%

值得注意的是,若用getAttribute来获取变量,需要在前一页先设置(set)
ok!here we go.

一、request

我们知道request对象用于处理HTTP请求中的各项参数。在这些参数中,最常用的就是获取访问请求参数。当我们通过超链接的形式发送请求时,可以为该请求传递参数,这可以通过在超链接的后面加上问号“?”来实现。注意这个问号为英文半角的符号。

在进行请求转发时,需要把一些数据传递到转发后的页面进行处理。这时,就需要使用request对象的setAttribute()方法将数据保存到request范围内的变量中。
request对象的setAttribute()方法的语法格式如下:
request.setAttribute(String name,Object object);

index主要代码
<a href="deal.jsp?id=1&user=admin&pwd=1234">处理页</a>


deal.jsp主要代码
<%
	String id=request.getParameter("id");
	String user=request.getParameter("user");
	String pwd=request.getParameter("pwd");
	request.setAttribute("id",id);
	request.setAttribute("user",user);
	request.setAttribute("pwd",pwd);
%>
	id的参数为:<%=id%><br>
	user的参数为:<%=user%><br>
	pwd的参数为:<%=pwd%><br>        //在未写RequestDispatcher之前,网页会显示这三个参数,写上之后会
	<%=request.getRequestDispatcher(save.jsp).forward(requset,response) %>


save.jsp主要代码
	<%=request.getAttribute("id")%>
	<%=request.getAttribute("user")%>
	<%=request.getAttribute("pwd")%>

值得注意的是这里是:
用request.getRequestDispatcher(url).forward(request,response) 是转发,是服务器端的跳转。
request.getRequestDispatcher(url).forward(request,response)是采用请求转发方式,在跳转页面的时候是带着原来页面的request和response跳转的,request对象始终存在,不会重新创建。
还有一个是用response.sendRedirect(url),这个是重定向,客户端的跳转。
response.sendRedirect(url)跳转到指定的URL地址后,上个页面(跳转之前的原来页面)中的请求全部结束,原request对象将会消亡,数据将会消失。紧接着,当前新页面会新建request对象,即产生新的request对象。
还有很多不同之处,详细看:
让你明白response.sendRedirect()与request.getRequestDispatcher().forward()区别
以及
【Servlet】关于RequestDispatcher的原理

二、cookie

cookie的中文意思是小甜饼,然而在互联网上的意思与这就完全不同了。它和食品完全没有关系。在互联网中,cookie是小段的文本信息,在网络服务器上生成,并发送给浏览器的。通过使用cookie可以标识用户身份,记录用户名和密码,跟踪重复用户等。浏览器将cookie以key/value的形式保存到客户机的某个指定目录中。
通过cookie的getCookies()方法即可获取到所有cookie对象的集合;通过cookie对象的getName()方法可以获取到指定名称的cookie;通过getValue()方法即可获取到cookie对象的值。另外将一个cookie对象发送到客户端使用了response对象的addCookie()方法。

cookies关键代码
<%
	Cookie[ ]   cookies = request.getCookies();//从request中获得Cookie对象的集合
	String user = "";	//登录用户
	String date = "";	//注册的时间
	if (cookies != null) {
		for (int i = 0; i < cookies.length; i++) {	//遍历cookie对象的集合
			if (cookies[i].getName().equals("mrCookie")) {//如果cookie对象的名称为mrCookie
				user = URLDecoder.decode(cookies[i].getValue().split("#")[0]);//获取用户名
				date = cookies[i].getValue().split("#")[1];//获取注册时间
			}
		}
	}
	if ("".equals(user) && "".equals(date)) {//如果没有注册
%>
		游客您好,欢迎您初次光临!
		<form action="cookies_do.jsp" method="post">
			请输入姓名:<input name="user" type="text" value="">
			<input type="submit" value="确定">
		</form>
<%
	} else {//已经注册
%>
		欢迎[<b><%=user %></b>]再次光临<br>
		您注册的时间是:<%=date %>
<%
	}
%>



cookies_do关键代码
<%
	request.setCharacterEncoding("utf-8");
	Date date = new Date();
	SimpleDateFormat dtf = new SimpleDateFormat("h:m:s");
	
	String user=URLEncoder.encode(request.getParameter("user"),"utf-8");	//从“user"获取用户名
	Cookie cookie = new Cookie("mrCookie", user+"#"+dtf.format(date));
	System.out.println(dtf.format(date));
	cookie.setMaxAge(60*60*24*30);		//设置cookie有效期30天
	response.addCookie(cookie);	//保存cookie
%>

作用显而易见了。不多说。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值