request方法

2023-05-16

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

1request概述

request是Servlet.service()方法的一个参数,类型为javax.servlet.http.HttpServletRequest。在客户端发出每个请求时,服务器都会创建一个request对象,并把请求数据封装到request中,然后在调用Servlet.service()方法时传递给service()方法,这说明在service()方法中可以通过request对象来获取请求数据。

 

request的功能可以分为以下几种:

l 封装了请求头数据;

l 封装了请求正文数据,如果是GET请求,那么就没有正文;

l request是一个域对象,可以把它当成Map来添加获取数据;

l request提供了请求转发和请求包含功能。

 

2request域方法

request是域对象!在JavaWeb中一共四个域对象,其中ServletContext就是域对象,它在整个应用中只创建一个ServletContext对象。request其中一个,request可以在一个请求中共享数据。

一个请求会创建一个request对象,如果在一个请求中经历了多个Servlet,那么多个Servlet就可以使用request来共享数据。现在我们还不知道如何在一个请求中经历之个Servlet,后面在学习请求转发和请求包含后就知道了。

下面是request的域方法:


void setAttribute(String name, Object value):用来存储一个对象,也可以称之为存储一个域属性,例如:servletContext.setAttribute(“xxx”, “XXX”),在request中保存了一个域属性,域属性名称为xxx,域属性的值为XXX。请注意,如果多次调用该方法,并且使用相同的name,那么会覆盖上一次的值,这一特性与Map相同;

l Object getAttribute(String name):用来获取request中的数据,当前在获取之前需要先去存储才行,例如:String value = (String)request.getAttribute(“xxx”);,获取名为xxx的域属性;

l void removeAttribute(String name):用来移除request中的域属性,如果参数name指定的域属性不存在,那么本方法什么都不做;

l Enumeration getAttributeNames():获取所有域属性的名称;

 

3request获取请求头数据

request与请求头相关的方法有:

l String getHeader(String name):获取指定名称的请求头;

l Enumeration getHeaderNames():获取所有请求头名称;

l int getIntHeader(String name):获取值为int类型的请求头。

 

4request获取请求相关的其它方法

request中还提供了与请求相关的其他方法,有些方法是为了我们更加便捷的方法请求头数据而设计,有些是与请求URL相关的方法。

l int getContentLength():获取请求体的字节数,GET请求没有请求体,没有请求体返回-1;

l String getContentType():获取请求类型,如果请求是GET,那么这个方法返回null;如果是POST请求,那么默认为application/x-www-form-urlencoded,表示请求体内容使用了URL编码;

l String getMethod():返回请求方法,例如:GET

l Locale getLocale():返回当前客户端浏览器的Locale。java.util.Locale表示国家和言语,这个东西在国际化中很有用;

l String getCharacterEncoding():获取请求编码,如果没有setCharacterEncoding(),那么返回null,表示使用ISO-8859-1编码;

l void setCharacterEncoding(String code):设置请求编码,只对请求体有效!注意,对于GET而言,没有请求体!!!所以此方法只能对POST请求中的参数有效!

l String getContextPath():返回上下文路径,例如:/hello

l String getQueryString():返回请求URL中的参数,例如:name=zhangSan

l String getRequestURI():返回请求URI路径,例如:/hello/oneServlet

l StringBuffer getRequestURL():返回请求URL路径,例如:http://localhost/hello/oneServlet,即返回除了参数以外的路径信息;

l String getServletPath():返回Servlet路径,例如:/oneServlet

l String getRemoteAddr():返回当前客户端的IP地址;

l String getRemoteHost():返回当前客户端的主机名,但这个方法的实现还是获取IP地址;

l String getScheme():返回请求协议,例如:http;

l String getServerName():返回主机名,例如:localhost

l int getServerPort():返回服务器端口号,例如:8080

 

System.out.println("request.getContentLength(): " + request.getContentLength());

System.out.println("request.getContentType(): " + request.getContentType());

System.out.println("request.getContextPath(): " + request.getContextPath());

System.out.println("request.getMethod(): " + request.getMethod());

System.out.println("request.getLocale(): " + request.getLocale());

 

System.out.println("request.getQueryString(): " + request.getQueryString());

System.out.println("request.getRequestURI(): " + request.getRequestURI());

System.out.println("request.getRequestURL(): " + request.getRequestURL());

System.out.println("request.getServletPath(): " + request.getServletPath());

System.out.println("request.getRemoteAddr(): " + request.getRemoteAddr());

System.out.println("request.getRemoteHost(): " + request.getRemoteHost());

System.out.println("request.getRemotePort(): " + request.getRemotePort());

System.out.println("request.getScheme(): " + request.getScheme());

System.out.println("request.getServerName(): " + request.getServerName());

System.out.println("request.getServerPort(): " + request.getServerPort());

 

4.1 案例:request.getRemoteAddr():封IP

  可以使用request.getRemoteAddr()方法获取客户端的IP地址,然后判断IP是否为禁用IP。

String ip = request.getRemoteAddr();

System.out.println(ip);

if(ip.equals("127.0.0.1")) {

response. getWriter().print("您的IP已被禁止!");

} else {

response.getWriter().print("Hello!");

}

 

5request获取请求参数

最为常见的客户端传递参数方式有两种:

l 浏览器地址栏直接输入:一定是GET请求;

l 超链接:一定是GET请求;

l 表单:可以是GET,也可以是POST,这取决与<form>的method属性值;

 

GET请求和POST请求的区别:

l GET请求:

Ø 请求参数会在浏览器的地址栏中显示,所以不安全;

Ø 请求参数长度限制长度在1K之内;

Ø GET请求没有请求体,无法通过request.setCharacterEncoding()来设置参数的编码;

l POST请求:

Ø 请求参数不会显示浏览器的地址栏,相对安全;

Ø 请求参数长度没有限制;

 

    <a href="/hello/ParamServlet?p1=v1&p2=v2">超链接</a>

    <hr/>

    <form action="/hello/ParamServlet" method="post">

     参数1:<input type="text" name="p1"/><br/>

     参数2:<input type="text" name="p2"/><br/>

     <input type="submit" value="提交"/>

    </form>

 

 

下面是使用request获取请求参数的API:

l String getParameter(String name):通过指定名称获取参数值;

 

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

String v1 = request.getParameter("p1");

String v2 = request.getParameter("p2");

System.out.println("p1=" + v1);

System.out.println("p2=" + v2);

}

 

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

String v1 = request.getParameter("p1");

String v2 = request.getParameter("p2");

System.out.println("p1=" + v1);

System.out.println("p2=" + v2);

}

 

l String[] getParameterValues(String name):当多个参数名称相同时,可以使用方法来获取;

<a href="/hello/ParamServlet?name=zhangSan&name=liSi">超链接</a>

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

String[] names = request.getParameterValues("name");

System.out.println(Arrays.toString(names));

}

 

l Enumeration getParameterNames():获取所有参数的名字;

    <form action="/hello/ParamServlet" method="post">

     参数1:<input type="text" name="p1"/><br/>

     参数2:<input type="text" name="p2"/><br/>

     <input type="submit" value="提交"/>

    </form>

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

Enumeration names = request.getParameterNames();

while(names.hasMoreElements()) {

System.out.println(names.nextElement());

}

}

 

l Map getParameterMap():获取所有参数封装到Map中,其中key为参数名,value为参数值,因为一个参数名称可能有多个值,所以参数值是String[],而不是String。

<a href="/day05_1/ParamServlet?p1=v1&p1=vv1&p2=v2&p2=vv2">超链接</a>

Map<String,String[]> paramMap = request.getParameterMap();

for(String name : paramMap.keySet()) {

String[] values = paramMap.get(name);

System.out.println(name + ": " + Arrays.toString(values));

}

p2: [v2, vv2]

p1: [v1, vv1]

 

6 请求转发和请求包含

无论是请求转发还是请求包含,都表示由多个Servlet共同来处理一个请求。例如Servlet1来处理请求,然后Servlet1又转发给Servlet2来继续处理这个请求。

 

6.1 请求转发

在AServlet中,把请求转发到BServlet:

public class AServlet extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

System.out.println("AServlet");

RequestDispatcher rd = request.getRequestDispatcher("/BServlet");

rd.forward(request, response);

}

}

public class BServlet extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

System.out.println("BServlet");

}

}

Aservlet

BServlet

 

6.2 请求包含

在AServlet中,把请求包含到BServlet:

public class AServlet extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

System.out.println("AServlet");

RequestDispatcher rd = request.getRequestDispatcher("/BServlet");

rd.include(request, response);

}

}

public class BServlet extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

System.out.println("BServlet");

}

}

Aservlet

BServlet

 

6.3 请求转发与请求包含比较

l 如果在AServlet中请求转发到BServlet,那么在AServlet中就不允许再输出响应体,即不能再使用response.getWriter()和response.getOutputStream()向客户端输出,这一工作应该由BServlet来完成;如果是使用请求包含,那么没有这个限制;

l 请求转发虽然不能输出响应体,但还是可以设置响应头的,例如:response.setContentType(”text/html;charset=utf-8”);

l 请求包含大多是应用在JSP页面中,完成多页面的合并;

l 请求请求大多是应用在Servlet中,转发目标大多是JSP页面;

 

 

 

6.4 请求转发与重定向比较

l 请求转发是一个请求,而重定向是两个请求;

l 请求转发后浏览器地址栏不会有变化,而重定向会有变化,因为重定向是两个请求;

l 请求转发的目标只能是本应用中的资源,重定向的目标可以是其他应用;

l 请求转发对AServlet和BServlet的请求方法是相同的,即要么都是GET,要么都是POST,因为请求转发是一个请求;

l 重定向的第二个请求一定是GET;

转载于:https://my.oschina.net/u/3648651/blog/1813113

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

request方法 的相关文章

随机推荐

  • VBA编程中的 sheet1 与 sheets(1)的区别

    自己理解 sheet1是一个专有名词 xff0c 不是任何对象的属性 xff0c 只能单独使用 xff0c 特指代码所在工作簿的那个sheet1 和顺序无关 xff0c 是固定的一个表 xff0c sheets 1 则和顺序有关 参考资料
  • python练习笔记——计算1/1-1/3+1/5-1/7……的和

    1 1 1 3 43 1 5 1 7 43 求100000个这样的分式计算之为是多少 xff1f 将此值乘以4后打印出来 xff0c 看看是什么 xff1f num list 61 count 61 1 i 61 1 while True
  • Django Model获取指定列的数据

    model一般都是有多个属性的 xff0c 但是很多时候我们又只需要查询特定的某一个 xff0c 这个时候可以用到values和values list 利用values查询 from attendence models import Emp
  • HIVE自定义函数的扩展

    作者简介 淳敏 xff0c 物流架构师同时也是一位team leader xff0c 工作认真负责 xff0c 曾在休假期间 面向大海编程 xff0c 不明觉厉 在Hive中 xff0c 用户可以自定义一些函数 xff0c 用于扩展Hive
  • Flink Window分析及Watermark解决乱序数据机制深入剖析-Flink牛刀小试

    版权声明 xff1a 本套技术专栏是作者 xff08 秦凯新 xff09 平时工作的总结和升华 xff0c 通过从真实商业环境抽取案例进行总结和分享 xff0c 并给出商业应用的调优建议和集群环境容量规划等内容 xff0c 请持续关注本套博
  • 使用Network Recycle Bin启用映射网络驱动器上的回收站

    前言 在内网环境中我们经常会使用NAS或者Samba在Windows中映射网络驱动器 xff0c 方便局域网用户实时共享交换数据 但当存储在网络或映射网络上的任何文件被删除时 xff0c 该文件将被永久删除 它不会去到本地计算机回收站 xf
  • 为强化机器学习性能,ARM推出两款新GPU Mali-G52和Mali-G31

    ARM于近期推出了两款图形处理器产品 xff0c 分别为Mali G52以及Mali G31 xff0c 主要应用于主流移动市场 由于移动端AI计算 图形处理需求的与日俱增 xff0c GPU之于手机SoC的作用日渐凸显 xff0c ARM
  • 判断python字典某个键的值是否为空

    2019独角兽企业重金招聘Python工程师标准 gt gt gt code if dict get key 0 61 61 0 值即为空 code 转载于 https my oschina net u 2254175 blog 37213
  • javascript中的==和===

    判断两个变量是否相等是程序设计中非常重要的运算 在处理原始值时 xff0c 这种运算相当简单 xff0c 但涉及对 象 xff0c 任务就稍有点复杂 ECMAScript提供了两套运算符处理这个问题 xff0c 等号和非等号用于处理原始值
  • 如何检测资源泄露

    Window上我们常见的资源泄露包括内存和对象句柄泄露 xff0c 下面讨论下对各类泄露的检测方法 关于内存泄漏 xff0c 我以前写过2篇文章 xff1a C 43 43 中基于Crt的内存泄漏检测 xff0c 基于WinDbg的内存泄漏
  • WPF触屏Touch事件在嵌套控件中的响应问题

    前几天遇到个touch事件的坑 xff0c 记录下来以增强理解 具体是 想把一个listview嵌套到另一个listview xff0c 这时候如果list view xff08 子listview xff09 的内容过多超过容器高度 xf
  • 设计模式-工厂模式

    xl echo编辑整理 xff0c 欢迎转载 xff0c 转载请声明文章来源 欢迎添加echo微信 微信号 xff1a t2421499075 进行交流学习 百战不败 xff0c 依不自称常胜 xff0c 百败不颓 xff0c 依能奋力前行
  • IBM AIX5.3 linux下C/C++实现HTTPS接口

    最近在工作中需要开发一个Https接口 xff0c 其不同于http soap等协议 xff0c 可以直接组织报文并发送 xff0c 不存在加密 xff0c 认证和获取密钥等安全操作 且之前开发的项目没有开发过这类接口 xff0c 所以当时
  • c语言把网络字节序转换成小端,网络编程字节序转换问题

    一 xff1a 大小端 一 大小端区别 字节 区别是依据 xff1a 计算机系统在存储数据时起始地址是高地址仍是低地址 小端 xff1a 从低地址开始存储 大端 xff1a 从高地址开始存储 补充 xff1a 这里大小端是按字节区别的 xf
  • [转载]Linux C 字符串函数 sprintf()、snprintf() 详解

    一 sprintf 函数详解 在将各种类 型的数据构造成字符串时 xff0c sprintf 的强大功能很少会让你失望 由于 sprintf 跟 printf 在用法上几乎一样 xff0c 只是打印的目的地不同而已 xff0c 前者打印到字
  • http Authorization

    MDN 文档 HTTP协议中的 Authorization 请求消息头含有服务器用于验证用户代理身份的凭证 xff0c 通常会在服务器返回401 Authorization lt type gt lt credentials gt curl
  • linux编译动态库未定义,GCC链接库的一个坑:动态库存在却提示未定义动态库的函数...

    背景 在GCC中已经指定链接库 xff0c 然而编译时却提示动态库函数未定义 xff01 测试出现的错误提示如下 xff1a GMPY 64 13 48 tmp gcc o test L lmylib test c tmp ccysQZI3
  • .inf右键没有安装菜单项解决办法

    打开我的电脑 xff0c 工具菜单中的文件夹选项 切换至文件类型选项卡 xff0c 在其中找到inf文件 xff0c 点高级按钮 xff0c 双击安装 I xff0c 没有新建一个 按如下内容修 改 用于执行操作的应用程序C WINDOWS
  • C++ : 编译单元、声明和定义、头文件作用、防止头文件在同一个编译单元重复引用、static和不具名空间...

    转 自 xff1a http www cnblogs com rocketfan archive 2009 10 02 1577361 html 1 编译单元 xff1a 一个 cc或 cpp文件作为一个编译单元 xff0c 生成 o 2
  • request方法

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 1request概述 request是Servlet service 方法的一个参数 xff0c 类型为javax servlet http HttpServletRequ