request对象封装了由客户端生成的HTTP请求的所有细节,主要包括HTTP头信息、系统信息、请求法师和请求参数等。通过request对象提供的相应方法可以处理客户端浏览器提交的HTTP请求中的各项参数。
request对象用于处理HTTP请求参数的各项参数。在这些参数中,最常用 的就是获取访问请求参数。当通过超链接的形式发送请求时,可以为该请求传递参数,这可以通过在超链接的后面加上问号“?”来实现。注意这个问号为英文半角的符号。例如,发送一个请求到delete.jsp,并传递一个名称为id的参数,可以通过以下超链接实现。
<a href="delete.jsp?id=1">删除</a>
1.使用request请求对象获取参数值
(1)创建index.jsp,在该文件中添加一个用于添加一个用于链接到deal.jsp页面的超链接,并传递两个参数。index.jsp文件的具体代码如下:
<%@ page language="java" contentType="text/html; charset=GB18030" pageEncoding="GB18030"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>使用request对象获取请求参数值</title>
</head>
<body>
<a href="deal.jsp?id=1&user=">处理页</a>
</body>
</html>
(2)创建deal.jsp文件,在该文件中通过request对象的getParameter()方法获取请求参数id user 和pwd的值并输出。
<%@ page language="java" contentType="text/html; charset=GB18030" pageEncoding="utf-8"%>
<%
String id=request.getParameter("id"); //获取id参数的值
String user=request.getParameter("user");//获取user参数的值
String pwd=request.getParameter("pwd");//获取pwd参数值
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>处理页</title>
</head>
<body>
id参数的值为:<%=id %><br>
user参数的值为:<%=user %><br>
pwd参数的值为:<%=pwd %>
</body>
</html>
运行本实例,首先进入到Index.jsp页面,单击“处理页”超链接,将进入到处理页获取请求参数并输出。如下图所示
(在使用request的getParameter()方法获取传递的参数值时,如果指定的参数不存在,将返回null;如果指定了参数名,但未指定参数值,将返回空的字符串“”。)
3 在作用域中管理属性
request.setAttribute(String name,Object object);//name为变量名,object为指定需要在request范围内传递的数据,为Object类型。
request.getAttribute(String name);//name表示变量名,该变量名在request范围内有效。
4.cookie
cookie可以标识用户身份,记录用户名和密码,跟踪重复用户等。浏览器将cookie以key/value的形式保存到客户机的某个指定目录中。
通过cookie 的getCookies()方法即可获取到所有cookie对象的集合;通过cookie对象的getName()方法可以获取到指定名称的cookie;通过getValue()方法即可获取到cookie对象的值。另外,将一个cookie对象发送到客户端,使用response对象addCookie()方法。
在使用cookie时,应保证客户机上允许使用cookie。这可以通过在IE浏览器中选择“工具”、“Internet选项”命令,在打开对话框的“隐私”选项卡中进行设置。
(1)创建index.jsp文件,在该文件中,首先获取cookie对象的集合,如何集合不为空,就通过for循环遍历cookie集合,从中找出设置的cookie(这里设置为mrCookie),并从该cookie中提取出用户名和注册时间,再根据获取的结果不同显示不同的提示信息。index.jsp文件的具体代码如下:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ page import="java.net.URLDecoder" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>通过cookie保存并读取用户登录信息</title>
</head>
<body>
<%
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="deal.jsp" method="post">
请输入姓名:<input name="user" type="text" value="">
<input type="submit" value="确定">
</form>
<%
} else {//已经注册
%>
欢迎[<b><%=user %></b>]再次光临<br>
您注册的时间是:<%=date %>
<%
}
%>
</body>
</html>
(2)编写deal.jsp文件,用于向cookie中写入注册信息。deal.jsp文件的具体代码如下:
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ page import="java.net.URLEncoder" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>写入cookie</title>
<script type="text/javascript">window.location.href="index.jsp"</script>
</head>
<body>
<%
request.setCharacterEncoding("utf-8");
String user=URLEncoder.encode(request.getParameter("user"),"utf-8"); //获取用户名
Cookie cookie = new Cookie("mrCookie", user+"#"+new java.util.Date().toLocaleString());
cookie.setMaxAge(60*60*24*30); //设置cookie有效期30天
response.addCookie(cookie); //保存cookie
%>
</body>
</html>
5.解决中文乱码