前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >和HTTP的简单接触

和HTTP的简单接触

作者头像
naget
发布2019-07-03 15:43:56
2940
发布2019-07-03 15:43:56
举报
文章被收录于专栏:VegoutVegout

http是一个应用层的协议,协议就是大家约定好的共同遵守的某个格式。HTTP请求的格式就是这个样子

代码语言:javascript
复制
POST /update HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.79 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
Accept-Encoding: gzip, deflate, br
Accept-Language: zh-CN,zh;q=0.9

name=naget&password=5201314

包含了三个部分:①请求方法——uri——协议版本 ②请求头 ③请求实体 第一行就是第一部分,请求方法是POST,uri是/update(其实也就是我们请求的资源在服务器上的相对路径),请求协议是HTTP,版本号是1.1,这三个小部分用空格隔开,然后加回车换行(\r\n)表示这一行的结束,紧接着就是第二部分请求头,请求头就是一些键值对(冒号前边的键和冒号后边的值,每一个键值对后边都要加回车换行表示结束),请求头结束后,会有一个空行(这一行只能有回车换行,不能有其他符号),这个空行后边就是第三部分请求实体。这里说的回车换行在上边的Http请求格式中没有体现出来,后边代码里我们返回给浏览器的信息中更能直观体现这一点。

每当我们在浏览器中输入一个网址时,就发起了一个Http请求,我们发送的数据就是按照这个格式传给了各大服务器,然后服务器就会返回给我们需要的信息。在服务器收到HTTP请求时就会按照HTTP格式来解析这些数据(有约在先是多么的重要),从而明白作为客户端的我们想得到哪些信息。解析的过程其实就是对字符串的一些操作,但为了亲身体验一把,我们就来解析一下自己浏览器发给本机的HTTP请求

代码语言:javascript
复制
public class PraseHttp {
    public static void main(String[] args) {
        ServerSocket serverSocket=null;
        Socket socket =null;
        OutputStream outputStream = null;
        InputStream inputStream = null;
        Request request =null;
        try {
            serverSocket = new ServerSocket(8080,1,InetAddress.getByName("127.0.0.1"));
        } catch (IOException e) {
            e.printStackTrace();
        }
        while (true){
            try {
                socket = serverSocket.accept();
                inputStream = socket.getInputStream();
                request = new Request(inputStream);
                request.parse();
                outputStream = socket.getOutputStream();
                String errorMessage = "HTTP/1.1 404 File Not Found\r\n" +
                        "Content-Type: text/html\r\n" +
                        "Content-Length: 23\r\n" +
                        "\r\n" +
                        "<h1>File Not Found</h1>";
                outputStream.write(errorMessage.getBytes());
//                outputStream.write("ddd".getBytes());
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

这个类用来处理浏览器发来的请求,基本就是三个步骤①打开一个套接字,等待接收请求 ②接收到请求(是一个输入流),将请求存到一个字节数组中 ③解析出请求参数,进行处理。 其中第一步我们很清晰的可以看到他的流程,而第二步是在request的parse方法中完成的,Request是自定义的一个类,下面给出parse的代码

代码语言:javascript
复制
StringBuffer request = new StringBuffer(2048);
    int i;
    byte[] buffer = new byte[2048];
    try {
      i = input.read(buffer);
    }
    catch (IOException e) {
      e.printStackTrace();
      i = -1;
    }
    for (int j=0; j<i; j++) {
      request.append((char) buffer[j]);
    }
    System.out.print(request.toString());

这一步无非就是将输入流读入一个字节数组,并且以字符串的形式把它打印出来。 第三步所谓的处理,就是直接返回了一个http格式的字节数组到输出流中。而在一个真正的web服务中,会将Http信息中的请求路径等信息解析出来,封装成为处理器能够接受的对象,交给对应的处理器,并从处理器拿到处理结果再返回给请求方(这个解析,分装的过程基本都是web服务器来完成的,比如tomcat,而作为后台程序开发者,我们直接就可以拿到分装好的对象进行处理,如Request,Response等)。 我们将这个程序运行起来,在浏览器中访问http://localhost:8080/get 可以看到控制台打印出了HTTP格式的请求信息

浏览器也收到了我们返回的消息

注意我们返回的信息是自己构造的一串HTTP格式的信息,严格遵循了http各个部分的要求,可以看换到回车换行,以及其他的格式要求,并且浏览器也进行了HTTP数据的解析,在页面中显示了响应实体中的内容。不过作为Http响应跟HTTP请求还是有细微的差别的,比如第一行,HTTP响应的内容是“协议——状态妈——描述”。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-06-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Vegout 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档