zoukankan      html  css  js  c++  java
  • http协议

    http协议简介

    http协议是Hyper Text Transfer Protocol(超文本传输协议) 的缩写,是用于万维网(WWW):World Wide Web服务器与本地浏览器之间传输超文本的传送协议.

    http是一个属于应用层的面向对象的协议,由于其简洁,快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断的完善和扩展.http协议工作于客户端-服务端架构上.浏览器作为http客户端经过URL向http服务端即WEB服务器发送所有请求.Web服务器根据接收到的请求后,向客户端发送相应信息.

    http协议特性

    (1) 基于TCP/IP

    http协议是基于TCP/IP协议之上的应用层协议.

    (2) 基于请求-响应模式

    http协议规定,请求从客户端发出,最后服务端响应该请求并返回.换句话说,肯定是先从客户端开始建立通信的,服务器端在没有接受到请求之前不会发送响应.

    (3) 无状态保存

    http是一种不保存状态,即无状态(stateless)协议.http协议自身不对请求和响应之间的通信状态进行保存.也就是说在http这个级别,协议对于发送过的请求或响应都不做持久化处理.

    使用http协议,每当有新的请求发送时,就会有对应的新响应产生.协议本身并不保留之前一切的请求或响应报文的信息.这是为了更快地处理大量事物,确保协议的可伸缩性,而特意把http协议设计成如此简单的.可是随着Web的不断发展,因而无状态而导致业务处理变得棘手的情况增多了,比如,用户登录到一家购物网站,即使他跳转到该站的其他页面后,也需要能继续保持登录状态.针对这个实例,网站为了能够掌控是谁发出的请求,需要保存用户的状态.http/1.1虽然是无状态协议,但为了实现期望的保持状态功能,于是引入了Cookie技术.有了Cookie再用http协议通信,就可以管理状态了

    (4) 无连接

    无连接的含义是限制每次连接只处理一个请求.服务器处理完客户的请求,并收到客户的应答后,即断开连接.采用这种方式可以节省传输时间.

    http请求协议与响应协议

    http协议包含由浏览器发送数据到服务器需要遵循的请求协议,与服务器发送数据到浏览器需要遵循的请求协议.用于http协议交互的信息被称为http报文.请求端(客户端)的http报文做请求报文,响应端(服务器端)做响应报文.http报文本身是由多行数据构成的字文本.

    (1) 请求协议

    请求格式

    请求方式:get与post请求

    (1)

      GET提交的数据会放在URL之后,以?分割URL和传输数据,参数之间以&相连,如EditBook?name=book1&id=1.

      POST方法是把提交的数据放在http包的请求体中.

    (2)

      GET提交的数据大小有限制(因为浏览器对URL长度有限制),而POST方法提交的数据没有限制.

    (3) 

      GET与POST请求在服务端获取请求数据方式不同.

    (2) 响应协议

     响应格式

    响应状态码

    状态码是当客户端向服务器端发送请求时,返回的请求结果.借助状态码,用户可以知道服务器端是正常的请求还是出现了异常.状态码以3位数字和原因组成.数字中的第一位指定了响应类别.后两位无分别.响应分别有五种

    示例:

    服务端:

    import socket
    
    
    sock=socket.socket()
    sock.bind(("127.0.0.1",8808))
    sock.listen(5)
    
    while 1:
        print("server waiting.....")
        conn,addr=sock.accept()
        data=conn.recv(1024)
        print("data",data)
    
        # 读取html文件
        with open("login.html","rb") as f:
            data=f.read()
    
        conn.send((b"HTTP/1.1 200 OK
    
    %s"%data))
        conn.close()

    客户端:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    
    
    <form action="" method="post">
        用户名 <input type="text" name="user">
        密码 <input type="password" name="pwd">
        <input type="submit">
    </form>
    
    </body>
    </html>
  • 相关阅读:
    gcc 工作流程和常用参数
    解决webstorm卡顿问题,下面详细设置方法,使得webstorm快速打开
    使用vue 3.0 初始化vue脚手架
    vue父组件更新,子组件也更新的方法
    vue 父子组件渲染
    数组对象去重 reduce()
    webstorm 点击右上角运行run 启动vue项目
    寻找的常用webstorm快捷键
    mORMot使用基础1(转)
    win7共享win10打印机提示无法连接到打印机 错误 bcb
  • 原文地址:https://www.cnblogs.com/s593941/p/9974157.html
Copyright © 2011-2022 走看看