一、HTTP请求
HTTP请求包括:请求行、请求头、请求体
(1)请求行:描述请求的资源
* 格式:请求方法 资源路径 协议
* 例如:GET /day04/1.html HTTP/1.1
* 请求方法:
* GET:请求内容追加在URL之后,注意:在HTML文档中,书写GET与POST,不区分大小写,但HTTP协议中的必须都大写
* URL的长度有限制1k
* POST:请求内容放置在请求体中
(2)请求头
* Accept:浏览器通知服务器,浏览器可以接受的数据类型
* Accept-charset:浏览器通知服务器,浏览器支持的字符集
* Accept-Encoding:浏览器通知服务器,浏览器支持的压缩格式
* Accept-Language:浏览器通知服务器,浏览器支持的语言环境
* Host:浏览器通知服务器,浏览器访问的服务器的主机名
* If-Modified-since:浏览器询问服务器,浏览器本地是否修改过.如果服务器响应没有就取本地的缓存
* Referer:浏览器通知服务器,浏览器当前页来自哪个页面(防盗链)
* user-agent:浏览器通知服务器,浏览器端的基本信息
* cookie:
* connection:浏览器保持服务器,是否保持连接状态
* Date:浏览器通知服务器,浏览器端的时间
(3)请求体
* 请求体与请求头之间存在一个空行
二、HTTP响应
HTTP响应包括:响应行 响应头 响应体(或状态行、消息报头、响应正文)
(1)响应行:协议 状态码 状态信息
* 格式:HTTP-Version Status-Code Reason-Phrase CRLF
* HTTP-Version表示服务器HTTP协议的版本;
* Status-Code表示服务器发回的响应状态代码;
* Reason-Phrase表示状态代码的文本描述。
* CRLF表示回车换行
* 例如:HTTP1.1 200 OK(CRLF)
* 状态码:状态代码有三位数字组成,第一个数字定义了响应的类别,后面俩个数字是具体的类别,且有五种可能取值:
* 1xx:指示信息--表示请求已接收,继续处理(服务器通知浏览器,服务器还没有处理完成)
* 2xx: 成功--表示请求已被成功接收、理解、接受(服务器通知浏览器,服务器已经处理完成)
* 200 OK //客户端请求成功
* 3xx: 重定向--要完成请求必须进行更进一步的操作(服务器通知浏览器,服务器还需要浏览器进一步处理来完成整个操作)
* 302:服务器通知浏览器需要进一步操作,从http响应头获(location)得进一步操作的资源
* 4xx:客户端错误--请求有语法错误或请求无法实现(服务器通知浏览器,浏览器发送数据有误)
* 400 Bad Request //客户端请求有语法错误,不能被服务器所理解
* 401 Unauthorized //请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用
* 403 Forbidden //服务器收到请求,但是拒绝提供服务
* 404 Not Found //请求资源不存在,eg:输入了错误的URL
* 5xx:服务器端错误--服务器未能实现合法的请求(服务器通知浏览器,服务器出现异常)
* 500 Internal Server Error //服务器发生不可预期的错误
* 503 Server Unavailable //服务器当前不能处理客户端的请求,一段时间后可能恢复正常
(2)响应头
* Location: http://www.it315.org/index.jsp --跳转方向
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 跳转 (重定向) -- 服务器通知浏览
// 设置http响应头
response.setHeader("location", "http://localhost:8080/day044/1.html");
// 状态码确定行为
response.setStatus(302);
}
运行结果:
* Server:apache tomcat --服务器型号
* Content-Encoding: gzip --数据压缩
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 通知浏览器,服务器发送的数据时压缩的,并且指定压缩的格式
response.setHeader("content-encoding", "gzip");
// 将大数据压缩后,发送给浏览器
StringBuilder builder = new StringBuilder();
for (int i = 0; i < 80000; i++) {
builder.append("abcd");
}
String data = builder.toString();
// 确定压缩的位置 ByteArrayOutputStream继承自OutputStream
ByteArrayOutputStream baos = new ByteArrayOutputStream();
// 压缩 gzip
GZIPOutputStream gzip = new GZIPOutputStream(baos); // 压缩的位置
// 压缩数据
gzip.write(data.getBytes());
gzip.close();
// 获得压缩后的字节数组
byte[] endData = baos.toByteArray();
// 将压缩的数据发送给浏览器 --
response.getOutputStream().write(endData);
}
* Content-Length: 80 --数据长度
* Content-Language: zh-cn --语言环境
* Content-Type: text/html; charset=GB2312 --数据类型
private void type(HttpServletResponse response) throws IOException {
// content-type:服务器通知浏览器,服务器发送的数据的编码
response.setHeader("content-type", "text/html;charset=UTF-8");
response.getWriter().write("中文");
}
* Last-Modified: Tue, 11 Jul 2000 18:23:51 GMT --最后修改时间
* Refresh: 1;url=http://www.it315.org --定时刷新
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// refresh:服务器通知浏览器,刷新的时间以及url 单位:秒
response.setHeader("refresh", "2");//浏览器每两秒向服务器发送一次请求
}
运行结果:
![](http://static.oschina.net/uploads/img/201506/29132435_ej7H.jpg)
int num = 5;
// refresh:服务器通知浏览器,刷新的时间以及url 单位:秒
if (num > 0) {
// 将内容输出
response.getWriter().print(num--);
response.setHeader("refresh", "1");
} else {
//传URL实现跳转
response.setHeader("refresh", "0;url=http://localhost:8080/day044/1.html");
}
* Content-Disposition: attachment; filename=aaa.zip --下载
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 通知浏览器进行下载
//处理中文的文件名
response.setHeader("content-disposition", "attachment;filename="+java.net.URLEncoder.encode("图片.jpg","UTF-8"));
// response.setHeader("content-disposition", "attachment;filename=22.jpg");
InputStream is = this.getServletContext().getResourceAsStream("1.jpg");
OutputStream out = response.getOutputStream();
byte[] buf = new byte[1024];
int len = -1;
while ((len = is.read(buf)) > -1) {
out.write(buf, 0, len);
}
out.close();
is.close();
}
* Set-Cookie:SS=Q0=5Lb_nQ; path=/search
* Expires: -1 --缓存
* Cache-Control: no-cache --缓存
* Pragma: no-cache --缓存
* Connection: close/Keep-Alive --连接
* Date: Tue, 11 Jul 2000 18:23:51 GMT --时间
(3)响应体:服务器响应浏览器所有的内容
* 注意:响应头与响应体之间存在一个空行
三、URL与URI
1)URL叫统一资源定位符,就是通常说的一个网站地址,格式如下:
>> http://host[:port][abs_path]
· 其中http表示要通过HTTP协议来定位网络资源
· Host表示合法的Internet主机域名或IP地址(以点分十进制格式表示)
· Port用于指定一个端口号,拥有被请求资源的服务器主机监听该端口的TCP连接。如果port是空,则使用缺省的端口80。
·abs_path指定请求资源的URI(Uniform Resource Identifier,统一资源标识符),如果URL中没有给出abs_path,那么当它作为请求URI时,
必须以"/"的形式给出。通常这个工作浏览器就帮我们完成了。