1、请求头字段用于客户端在请求消息中向服务器传递附加信息,主要包括客户端可以接受的数据类型、压缩方法、语言以及发出请求的超链接所属页面的URL地址等信息。
2、常用请求头
请求头 | 举例 | 含义 |
---|---|---|
Accept | text/html, application/xhtml+xml, */* | 浏览器可接受的MIME类型 |
Accept-Charset | 用于告诉服务器,客户机采用的编码 | |
Accept-Encoding | gzip, deflate | 用于告诉服务器,客户机支持的数据压缩格式,比如gzip |
Accept-Language | zh-CN | 浏览器所希望的语言种类,当服务器能够提供一种以上的语言版本时要用到。 可以在浏览器中进行设置。 |
Host | localhost:8080 | 初始URL中的主机和端口,如果没有匹配的主机则访问默认主机。 |
Referer | http://localhost:8080/mail/ | 客户机通过这个头来告诉服务器,它是从哪个资源来访问服务器的(防盗链) |
Content-Type | application/x-www-form-urlencoded | 内容类型 |
If-Modified-Since | Sun, 22 Jan 2017 08:12:40 GMT | 只有当所请求的内容在指定的日期之后又经过修改才返回它,否则返回304“Not Modified”应答。 |
If-None-Match | W/”140-1485072760884” | 当服务器端资源的标识与请求给定标识不同时,标识服务器端资源发生改变,返回最新资源,否则表示资源未发生改变从客户机缓存取资源。 |
User-Agent | 浏览器类型. | |
Content-Length | 9 | 表示请求消息正文的长度 |
Connection | Keep-Alive | 表示是否需要持久连接。如果服务器看到这里的值为“Keep -Alive”,或者看到请求使用的是HTTP 1.1(HTTP 1.1默认进行持久连接) |
Cookie | 这是最重要的请求头信息之一,客户端通过该请求头向服务器发送一点数据 | |
Date | Mon, 22 Aug 2011 01:55:39 GMT请求时间GMT |
IE浏览器+HttpWatch Professional插件,可以很方便的抓包观察http请求。下面实验就是用的这个方式。
<form action="/1.html" method="get">
<input name="username" type="text"/>
<input type="submit" value="submit"/>
form>
<form action="/1.html" method="post">
<input name="username" type="text"/>
<input type="submit" value="submit"/>
form>
一个http响应代表服务器向客户端回送的数据,它包括
一个状态行、若干消息头、一个空行、实体内容,其中一些消息头和实体内容都是可选的,消息头和实体内容之间要用空行隔开。格式如下:
状态码用于表示服务器对请求的各种不同处理结果和状态,它是一个三位的十进制数。响应状态码分为五类,使用最高位为1到5来进行分类,如下所示:
状态码 | 含义 |
---|---|
100-199 | 表示成功接收请求,要求客户端提交下一次请求才能完成整个处理过程 |
200-299 | 表示成功接收请求并已完成整个过程,常用200 |
300-399 | 重定向或者资源位置发生改变。例如302重定向,304未修改从缓存取,307临时重定向,301永久移动 |
400-499 | 客户端的请求错误,常用404(未找到)、403(拒绝) |
500-599 | 服务器端出现错误,常用500(服务器内部错误) |
状态码 | 详情 |
---|---|
200(正常) | 表示一切正常,返回的是正常请求结果。 |
302/307(临时重定向) | 指出被请求的文档已被移动到别处,此文档的新的URL在location响应头中给出。 |
304(未修改) | 表示客户机缓存的版本是最新的,客户机可以继续使用它,无需到服务器请求。客户机通过If-Modified-Since请求头通知服务器缓存版本。 |
404(找不到) | 服务器上不存在客户机所请求的资源 |
500(服务器内部错误) | 服务器端的程序发生错误 |
响应头 | 举例 | 含义 |
---|---|---|
Location | http://www.it315.org/index.jsp | 配合302状态码使用,指示新的资源的位置 |
Server | apache tomcat | 指示服务器的类型 |
Content-Encoding | gzip | 服务器发送的数据采用的压缩类型 |
Content-length | 80 | 告诉浏览器正文的长度 |
Content-Type | text/html; charset=GB2312 | 服务器发送的内容的MIME类型 |
Content-Language | zh-cn | 服务器发送的文本的语言 |
Last-Modified | Tue, 11 Jul 2000 18:23:51 GMT | 资源的最后修改时间 |
Refresh | 1;url=http://www.it315.org | 指示客户端刷新频率。单位是秒。 |
Content-Disposition | attachment; filename=aaa.zip | 指示客户端下载文件 |
Transfer-Encoding | 通知浏览器数据的传送格式 | |
Set-Cookie | SS=Q0=5Lb_nQ; path=/search | 服务器端发送的cookie |
ETag | W/”140-1485072760884” | 资源的标识,如果资源更改,Etag也更改。客户端第一次请求资源时,服务器回送该响应头,客户端再次请求资源时带上该头,服务器通过比较Etag判定客户端缓存资源是否为最新。能做到实时,其他的头只能做到秒级别。 |
Expires | -1 | 通知客户机把回送的资源缓存多长时间,-1和0表示不缓存 |
Cache-Control | no-cache | 控制是否缓存资源 |
Pragma | no-cache | 控制是否缓存资源 |
Connection | close | 响应完毕是否立刻关闭连接,close表示立刻关闭,keep-alive表示不关闭 |
Date | Tue, 11 Jul 2000 18:23:51 GMT | 响应时间 |
消息头 | 类别 | 含义 |
---|---|---|
If-Modified-Since | 请求头 | 通知服务器客户端缓存资源的时间,只有当所请求的内容在指定的日期之后又经过修改才返回它,否则返回304“Not Modified”应答。 |
Last-Modified | 响应头 | 资源的最后修改时间 |
If-None-Match | 请求头 | 上一次请求该资源服务器回送Etag响应头的内容。如果服务器端的资源改变了则返回最新资源,否则客户机从缓存取资源。 |
Etag | 响应头/请求头 | 资源的标识 |
Expires | 响应头 | 通知客户机把回送的资源缓存多长时间,-1和0表示不缓存 |
Cache-Control | 响应头 | 通知客户端是否需要缓存该资源。 |
Pragma | 响应头 | 通知客户单是否需要缓存该资源。 |
消息头 | 类别 | 含义 |
---|---|---|
Range | 请求头 | Range头指示服务器只传输一部分web资源,Range头字段可以通过三种格式设置要传输的字节范围(资源从0字节开始算起): bytes=1000-2000:传输范围从1000到2000字节。 bytes=1000-:传输Web资源中第1000个字节及其以后的所有内容。 bytes=1000:传输最后1000个字节 |
Accept-Ranges | 响应头 | 说明服务器是否支持Range,以及支持的Range单位。 bytes:支持Range且单位为字节 none:不支持Range。 |
Content-Range | 响应头 | 指定了返回的web资源的字节范围,例子: 1000-3000/5000:表示返回Web资源的第1000到3000个字节的内容,该资源总长度为5000字节。 |
1、重定向
response.setStatus(302);
// "/"代表从主机开始,不加"/"表示从当前web应用开始
response.setHeader("Location", "index.html");
2、数据压缩(content-encoding,content-length)
String data="12345 54321 上山打老虎";
ByteArrayOutputStream bOut=new ByteArrayOutputStream();
GZIPOutputStream gzipOut=new GZIPOutputStream(bOut);
gzipOut.write(data.getBytes());
gzipOut.close();
byte[] gzip=bOut.toByteArray();
response.setHeader("Content-Encoding", "gzip");
response.setHeader("content-length", gzip.length+"");
response.getOutputStream().write(gzip);
3、显示图片(content-type),tomcat的web.xml可以查到文件类型的写法
response.setHeader("content-type", "image/jpeg");
InputStream in=this.getServletContext().getResourceAsStream("/1.jpg");
OutputStream out=response.getOutputStream();
byte buf[]=new byte[1024];
int len=0;
while((len=in.read(buf))>0){
out.write(buf,0,len);
}
4、定时刷新页面(refresh)
response.setHeader("refresh", "3;url=index.html");
response.getWriter().write("aaaa");
5、下载文件(content-disposition),实验表明必须先设置响应头再写数据
response.setHeader("content-disposition", "attachment;filename=1.jpg");
InputStream in=this.getServletContext().getResourceAsStream("/1.jpg");
OutputStream out=response.getOutputStream();
byte buf[]=new byte[1024];
int len=0;
while((len=in.read(buf))>0){
out.write(buf,0,len);
}
6、断点续传(range)
URL url=new URL("http://localhost:8080/WebDemo1/abc.txt");
HttpURLConnection connection=(HttpURLConnection) url.openConnection();
connection.addRequestProperty("Range", "bytes=6-");
InputStream in=connection.getInputStream();
FileOutputStream out=new FileOutputStream("D:\\abc.txt", true);
byte[] buf=new byte[1024];
int len=0;
while ((len=in.read(buf))>0) {
out.write(buf, 0, len);
}
in.close();
out.close();