Servlet基础 HttpServletrequest 简单理解

由来

Web服务器收到一个http请求,会针对每个请求创建一个HttpServletRequestHttpServletResponse对象,从客户端取数据找HttpServletRequest,向客户端发送数据找HttpServletResponse。

HTTP 协议是基于请求-响应的协议,客户端请求一个文件,服务器对该请求进行响应。HTTP 使用 TCP 协议,默认使用 80 端口,现在使用版本为HTTP/1.1

在 HTTP 协议中,总是由主动建立连接、发送 HTTP 请求的客户端来初始化一个事务。服务器不负责连接客户端,或创建一个到客户端的回调连接(callback connection)。

每个 HTTP 请求都会有一个请求方法,HTTP1.1 中支持的方法包括,GET、POST、HEAD、OPTIONS、PUT、DELETE 和 TRACE。互联网应用中最常用的是 GET 和 POST(GET和POST区别(详情))。

一个 HTTP 请求包含以下三部分:

1.请求地址(URL)

2.请求头(Request headers)

3.实体数据(Entity body)
URI 指明了请求资源的地址,通常是从网站更目录开始计算的一个相对路径,因此它总是以斜线 “/”开头的。
URL 实际上是 URI 的一种类型,请求头(header)中包含了一些关于客户端环境和请求实体(entity)的有用的信息。
每个请求头使用 CRLF(回车换行符,“\r\n”)分隔,其格式为:请求头名+英文空格+请求头值

下图示例:
在这里插入图片描述

HttpServletrequest

公共接口类HttpServletRequest继承自ServletRequest接口,其主要功能是封装HTTP请求消息。客户端发出的请求被封装成为一个HttpServletRequest对象。对象包含了客户端请求信息包括请求的地址,请求的参数,提交的数据,上传的文件客户端的ip甚至客户端操作系统都包含在其内。

在这里插入图片描述

当访问 Servlet时,所有请求消息将被封装到 HttpServletRequest 对象,为了获取这些信息,HttpServletRequest 接口定义了一系列方法。

获取请求信息的常用方法:

在这里插入图片描述

当浏览器发送 Servlet 请求时,需要通过请求消息头向服务器传递附加信息,例如,客户端可以接收的数据类型、压缩方式、语言等。 HttpServletRequest 接口中定义了一系列用于获取 HTTP 请求头字段的方法。

获取请求头的相关方法

在这里插入图片描述

HTTP请求头信息和示例

Header解释示例
Accept浏览器能够接受的内容消息Accept: text/plain, text/html
Accept-Charset浏览器可以接受的字符编码集Accept-Charset: iso-8859-5
Accept-Encoding指定浏览器可以支持的web服务器返回内容压缩编码类型Accept-Encoding: compress, gzip,br,deflate
Accept-Language浏览器可接受的语言Accept-Language: en,zh-CN;q=0.9
Accept-Ranges可以请求网页实体的一个或者多个子范围字段Accept-Ranges: bytes
AuthorizationHTTP授权的授权证书Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Cache-Control指定请求和响应遵循的缓存机制Cache-Control: no-cache
Connection表示是否需要持久连接。(HTTP 1.1默认进行持久连接)close为不长连接,keep-alive保持长连接Connection: keep-alive
CookieHTTP请求发送时,会把保存在该请求域名下的所有cookie值一起发送给web服务器。就是一段字符串,是浏览器保存服务器返回数据的方法,通常保存用户身份信息Cookie: $Version=1; Skin=new;
Content-Length请求的内容长度Content-Length: 348
Content-Type请求的与实体对应的MIME信息Content-Type: application/x-www-form-urlencoded
Date请求发送的日期和时间Date: Tue, 15 Nov 2010 08:12:31 GMT
Expect请求的特定的服务器行为Expect: 100-continue
From发出请求的用户的EmailFrom: user@email.com
Host指定请求的服务器的域名和端口号Host: www.zcmhi.com
If-Match只有请求内容与实体相匹配才有效If-Match: “737060cd8c284d8af7ad3082f209582d”
If-Modified-Since如果请求的部分在指定时间之后被修改则请求成功,未被修改则返回304代码If-Modified-Since: Sat, 29 Oct 2010 19:43:31 GMT
If-None-Match如果内容未改变返回304代码,参数为服务器先前发送的Etag,与服务器回应的Etag比较判断是否改变If-None-Match: “737060cd8c284d8af7ad3082f209582d”
If-Range如果实体未改变,服务器发送客户端丢失的部分,否则发送整个实体。参数也为EtagIf-Range: “737060cd8c284d8af7ad3082f209582d”
If-Unmodified-Since只在实体在指定时间之后未被修改才请求成功If-Unmodified-Since: Sat, 29 Oct 2010 19:43:31 GMT
Max-Forwards限制信息通过代理和网关传送的时间Max-Forwards: 10
Pragma用来包含实现特定的指令Pragma: no-cache
Proxy-Authorization连接到代理的授权证书Proxy-Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Range只请求实体的一部分,指定范围Range: bytes=500-999
Referer先前网页的地址,当前请求网页紧随其后,即来路Referer: http://www.zcmhi.com/archives/71.html
TE客户端愿意接受的传输编码,并通知服务器接受接受尾加头信息TE: trailers,deflate;q=0.5
Upgrade向服务器指定某种传输协议以便服务器进行转换(如果支持)Upgrade: HTTP/2.0, SHTTP/1.3, IRC/6.9, RTA/x11
User-AgentUser-Agent的内容包含发出请求的用户信息User-Agent: Mozilla/5.0 (Linux; X11)
Via通知中间网关或代理服务器地址,通信协议Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)
Warning关于消息实体的警告信息Warn: 199 Miscellaneous warning
Origin发送请求的主机名和端口Origin: https://www.baidu.com
sec-ch-ua可以理解用来替代user-agent的,用sec-ch-ua可以防止泄露浏览器详细信息sec-ch-ua: " Not A;Brand";v=“99”, “Chromium”;v=“101”, “Google Chrome”;v=“101”
sec-ch-ua-mobile是否是移动端用户sec-ch-ua-mobile: ?0
sec-ch-ua-platform表示操作系统名称sec-ch-ua-platform: “Windows”
Sec-Fetch-Dest表示请求的目的地,即如何使用获取的数据Sec-Fetch-Dest: empty
Sec-Fetch-Mode该请求头表明了一个请求的模式Sec-Fetch-Mode: cors
Sec-Fetch-Site请求发起者的来源与目标资源来源之间的关系Sec-Fetch-Site: same-site
Upgrade-Insecure-Requests请求头向服务器发送一个客户端对HTTPS加密和认证响应良好Upgrade-Insecure-Requests: 1
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值