Response的Header属性详解
一、Header属性
二、Header属性分类
1、通用信息头
2、请求头
3、响应头
4、实体头
5、扩展头
三、Response设置Header属性
1、控制浏览器禁止缓存当前文档内容
2、控制浏览器过期的时间期限
3、设置http响应头控制浏览器定时刷新网页(refresh)
4、设置http响应头控制浏览器定时跳转到其它页面
5、设置http响应头文件下载
一、Header属性
属性 |
备注 |
Access-Control-Allow-Origin |
该站点可以被哪些网站进行 跨域资源共享 |
Accept-Ranges |
服务器是否支持资源范围请求 |
Age |
一个资源存在于代理中 缓存的时间,单位是秒 |
Allow |
一个资源允许哪些HTTP方法进行请求 |
Cache-Control |
对缓存的控制 |
Connection |
连接方式 |
Content-Encoding |
服务器对响应数据的编码方式,但这里的编码方式不同于编码字符集(GB2312,UTF-8等),而是(通常)指压缩方式 |
Content-Language |
响应数据的自然语言 |
Content-Length |
响应数据的数据长度,单位是byte |
Content-Location |
|
Content-MD5 |
基于base64编码的回应数据的MD5校验和 |
Content-Disposition |
当客户端请求的资源是一个可下载的资源(这里的“可下载”是指浏览器会弹出下载框或者下载界面)时,对这个可下载资源的描述(例如下载框中的文件名称)就是来源于该头域。 |
Content-Range |
如果当前这个响应数据是整个资源的一部分时,是具体的哪一部分(从第几byte到第几byte)。 |
Content-Type |
服务器告诉浏览器它发送的数据属于什么文件类型,也就是响应数据的MIME类型 |
Date |
响应消息发送的GMT格式日期 |
ETag |
资 资源的一个标识,类似于key-value pair(键值对)中的key。 |
Expires |
告诉客户端该响应数据会在指定的时间过期,通常用于给客户端缓存作为参考。 |
Last-Modified |
客户端所请求的资源的最后修改时间。 |
Link |
描述当前被请求的资源和另外一个资源的关系。这种关系被定义在RFC5988。 |
Location |
用户通知客户端转跳(重定向)到另一个URL |
P3P |
Platform for Privacy Preferences Project的缩写,表示本站点遵守P3P协议(标称本站点不会违法使用用户信息)并希望收集用户信息。不过P3P目前使用并不广泛,特别国内并不重视P3P。 |
Pragma |
在请求/响应链上附近的一些参数 |
Proxy-Authenticate |
访问代理时需要使用的验证方式。 |
Refresh |
用于令客户端在指定N秒后转跳到另外一个URL。 |
Retry-After |
用于因为某些原因(例如该资源暂时无效)通知客户端在指定时间后重新尝试请求,时间单位为秒。 |
Server |
服务器的名称 |
Set-Cookie |
对客户端设置cookie |
Strict-Transport-Security |
用于指示客户端如何对HTTPS进行缓存(缓存多长时间)以及是否对子域生效。 |
Trailer |
当响应资源已chunked编码传输时,每个Chunked-Body尾部的额外数据。 |
Transfer-Encoding |
响应内容的传输编码方式,通常有 chunked, deflate, gzip等。 |
Vary |
用来指示缓存代理(例如squid)根据什么条件去缓存一个请求。 |
Via |
告诉客户端,该回应经历了那些代理。 |
WWW-Authenticate |
表示当前是用什么验证方式访问一个资源。 |
二、Header属性分类
1、通用信息头
即能用于请求消息中,也能用于响应信息中,但与被传输的实体内容没有关系的信息头,如Data,Pragma
主要 Cache-Control , Connection , Data , Pragma , Trailer , Transfer-Encoding , Upgrade
2、请求头
用于在请求消息中向服务器传递附加信息,主要包括客户机可以接受的数据类型,压缩方法,语言,以及客户计算机上保留的信息和发出该请求的超链接源地址等.
主要 Accept , Accept-Encoding , Accept-Language , Host ,
3、响应头
用于在响应消息中向客户端传递附加信息,包括服务程序的名称,要求客户端进行认证的方式,请求的资源已移动到新地址等.
主要 Location , Server , WWW-Authenticate(认证头)
4、实体头
用做实体内容的元信息,描述了实体内容的属性,包括实体信息的类型,长度,压缩方法,最后一次修改的时间和数据的有效期等.
主要 Content-Encoding , Content-Language , Content-Length , Content-Location , Content-Type
5、扩展头
主要:Refresh, Content-Disposition
三、Response设置Header属性
1、控制浏览器禁止缓存当前文档内容
response.setDateHeader(expries, -1);
response.setHeader(Cache-Control, no-cache);
response.setHeader(Pragma, no-cache);
2、控制浏览器过期的时间期限
response.setDateHeader(Expires, System.currentTimeMillis()+自己设置的时间期限);
3、设置http响应头控制浏览器定时刷新网页(refresh)
设置refresh响应头控制浏览器每隔5秒钟刷新一次
response.setHeader(refresh, 5);
4、设置http响应头控制浏览器定时跳转到其它页面
设置refresh响应头控制浏览器隔2秒后跳转到其它页面
response.setHeader(refresh,2;URL=otherPagename);
5、设置http响应头文件下载
response.setHeader(Content-Disposition, attachment; filename= + java.net.URLEncoder.encode(fileName, UTF-8));