javaWeb--http协议

一、协议:协议的甲乙双方,就是客户端(浏览器)和服务器!
  理解成双方通信的格式!
1、 请求协议格式如下: (get请求没有请求体,但是有空行)

  1. 请求首行; (GET /hello/index.jsp HTTP/1.1:GET请求,请求服务器路径为/hello/index.jsp,协议为1.1;)
  2. 请求头信息; (请求头,请求头由key/value组成。)
  3. 空行; (这个位置虽然没有东西,但很重要,它是空行。如果有请求体,那么请求体在空行的下面)
  4. 请求体。

需要知道的请求体的内容:
1、 User-Agent: Mozilla/5.0 (Windows NT 5.1; rv:5.0) Gecko/20100101 Firefox/5.0:与浏览器和OS相关的信息。有些网站会显示用户的系统版本和浏览器版本信息,这都是通过获取User-Agent头信息而来的;
2、Accept: text/html,application/xhtml+xml,application/xml;q=0.9,/;q=0.8:告诉服务器,当前客户端可以接收的文档类型,其实这里包含了/,就表示什么都可以接收;
3、 Accept-Language: zh-cn,zh;q=0.5:当前客户端支持的语言,可以在浏览器的工具选项中找到语言相关信息;
4、 Content-Type: application/x-www-form-urlencoded:表单的数据类型,说明会使用url格式编码数据;url编码的数据都是以“%”为前缀,后面跟随两位的16进制,例如“传智”这两个字使用UTF-8的url编码用为“%E4%BC%A0%E6%99%BA”;平时的时候不修改,但是上传的时候会修改。

2、响应协议;

  1. 响应首行;(HTTP/1.1 200 OK:响应协议为HTTP1.1,状态码为200,表示请求成功,OK是对状态码的解释)
  2. 响应头信息;
  3. 空行;
  4. 响应体。
    需要知道的响应头的内容
    1、Content-Type: text/html;charset=UTF-8:响应体使用的编码为UTF-8;

了解:
Referer: http://localhost:8080/hello/index.jsp:请求来自哪个页面,例如你在百度上点击链接到了这里,那么Referer:http://www.baidu.com;如果你是在浏览器的地址栏中直接输入的地址,那么就没有Referer这个请求头了;
Referer请求头是比较有用的一个请求头,它可以用来做统计工作,也可以用来做防盗链。
统计工作:我公司网站在百度上做了广告,但不知道在百度上做广告对我们网站的访问量是否有影响,那么可以对每个请求中的Referer进行分析,如果Referer为百度的很多,那么说明用户都是通过百度找到我们公司网站的。
防盗链:我公司网站上有一个下载链接,而其他网站盗链了这个地址,例如在我网站上的index.html页面中有一个链接,点击即可下载JDK7.0,但有某个人的微博中盗链了这个资源,它也有一个链接指向我们网站的JDK7.0,也就是说登录它的微博,点击链接就可以从我网站上下载JDK7.0,这导致我们网站的广告没有看,但下载的却是我网站的资源。这时可以使用Referer进行防盗链,在资源被下载之前,我们对Referer进行判断,如果请求来自本网站,那么允许下载,如果非本网站,先跳转到本网站看广告,然后再允许下载。
防盗链基本原理代码:

String referrer = request.getHeader("Referer");
        if(referrer ==null || !referrer.contains("localhost")){
            response.sendRedirect("http://www.baidu.com");
        }else{
            System.out.println("hello");
        }

二、响应码

  1. 200:请求成功,浏览器会把响应体内容(通常是html)显示在浏览器中
  2. 404:请求的资源没有找到,说明客户端错误的请求了不存在的资源;
  3. 500:请求资源找到了,但服务器内部出现了错误;
  4. 302:重定向,当响应码为302时,表示服务器要求浏览器重新再发一个请求,服务器会发送一个响应头Location,它指定了新请求的URL地址;

猜你喜欢

转载自blog.csdn.net/ilikejj0/article/details/80135189
今日推荐