HTTP协议

一、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)得进一步操作的资源

                                               * 304:服务器通知浏览器当前资源没有修改,从缓存中获取

                                      * 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");//浏览器每两秒向服务器发送一次请求
}
运行结果:
                 
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时,

                                   必须以"/"的形式给出。通常这个工作浏览器就帮我们完成了。

转载于:https://my.oschina.net/weslie/blog/471966

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值