JSP内置对象request

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有效期30response.addCookie(cookie); //保存cookie
%>

</body>
</html>

5.解决中文乱码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值