• get与post方法的区别以及http状态码简述


    注:此文复制而来,只为便于学习!

    常用的HTTP方法

    GET:用于请求访问已经被URI(统一资源标识符)识别的资源,可以通过URL传参给服务器
    POST:用于传输信息给服务器,主要功能与GET方法类似,但一般推荐使用POST方式。
    PUT:传输文件,报文主体中包含文件内容,保存到对应URI位置。
    HEAD:获得报文首部,与GET方法类似,只是不返回报文主体,一般用于验证URI是否有效。

    DELETE:删除文件,与PUT方法相反,删除对应URI位置的文件。

    1、GET方法与POST方法的区别
    GET方法:
    使用GET方法时,查询字符串(键值对)被附加在URL地址后面一起发送到服务器:
    /test/demo_form.jsp?name1=value1&name2=value2
    特点:
    • GET请求能够被缓存
    • GET请求会保存在浏览器的浏览记录中
    • 以GET请求的URL能够保存为浏览器书签
    • GET请求有长度限制
    • GET请求主要用以获取数据
    POST方法:
    使用POST方法时,查询字符串在POST信息中单独存在,和HTTP请求一起发送到服务器:
    POST /test/demo_form.jsp HTTP/1.1
    Host: w3schools.com
    name1=value1&name2=value2
    特点:
    • POST请求不能被缓存下来
    • POST请求不会保存在浏览器浏览记录中
    • 以POST请求的URL无法保存为浏览器书签
    • POST请求没有长度限制

    区别一(使用场景):
    get重点在从服务器上获取资源,post重点在向服务器发送数据;
    区别二(请求数据位置):
    get传输数据是通过URL请求,以field(字段)= value的形式,置于URL后,并用"?"连接,多个请求数据间用"&"连接,如http://127.0.0.1/Test/login.action?name=admin&password=admin,这个过程用户是可见的;
    post传输数据通过Http的post机制,将字段与对应值封存在请求实体中发送给服务器,这个过程对用户是不可见的;
    区别三(请求数据大小):
    Get传输的数据量小,因为受URL长度限制,但效率较高;
    Post可以传输大量数据,所以上传文件时只能用Post方式;
    区别四(安全性):
    get是不安全的,因为URL是可见的,可能会泄露私密信息,如密码等;
    post较get安全性较高;
    区别五(编码集合):
    get方式只能支持ASCII字符,向服务器传的中文字符可能会乱码。
    post支持标准字符集,可以正确传递中文字符。

    区别六(共享性):
    get请求的请求数据在url中,便于分享连接,可以添加到书签,而post请求不可以。。
    区别七(缓存):
    get请求能被缓存,而post请求不行。
    区别八(表单重复提交):

    点击返回/刷新按钮,对get请求没有影响,对于post请求可能会导致数据重发(浏览器会提示)。

    常用的HTTP状态码

    状态码的职责是当客户端向服务器端发送请求时,描述返回的请求结果。借助状态码,用户可以知道服务器端是正常处理了请求,还是出现了错误。
    状态码如 200 OK,以 3 位数字和原因短语组成。
    数字中的第一位指定了响应类别,后两位无分类。响应类别有以下 5 种。
     

    1、状态码的类别

     
    1XX Informational(信息性状态码)接收的请求正在处理
     
    2XX Success(成功状态码) 请求正常处理完毕
     
    3XX Redirection(重定向状态码) 需要进行附加操作以完成请求
     
    4XX Client Error(客户端错误状态码)服务器无法处理请求
     
    5XX Server Error(服务器错误状态码)服务器处理请求出错
     
    只要遵守状态码类别的定义,即使改变 RFC2616 中定义的状态码,或服务器端自行创建状态码都200:请求被正常处理
    1开头的http状态码
    表示临时响应并需要请求者继续执行操作的状态代码。

    100   (继续) 请求者应当继续提出请求。 服务器返回此代码表示已收到请求的第一部分,正在等待其余部分。  
    101   (切换协议) 请求者已要求服务器切换协议,服务器已确认并准备切换。

    2开头的http状态码
    表示请求成功

    200     成功处理了请求,一般情况下都是返回此状态码; 
    201     请求成功并且服务器创建了新的资源。 
    202     接受请求但没创建资源; 
    203     返回另一资源的请求; 
    204     服务器成功处理了请求,但没有返回任何内容;
    205     服务器成功处理了请求,但没有返回任何内容;
    206     处理部分请求;

    3xx (重定向) 
    重定向代码,也是常见的代码

    300   (多种选择)  针对请求,服务器可执行多种操作。 服务器可根据请求者 (user agent) 选择一项操作,或提供操作列表供请求者选择。 
    301   (永久移动)  请求的网页已永久移动到新位置。 服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置。 
    302   (临时移动)  服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。 
    303   (查看其他位置) 请求者应当对不同的位置使用单独的 GET 请求来检索响应时,服务器返回此代码。 
    304   (未修改) 自从上次请求后,请求的网页未修改过。 服务器返回此响应时,不会返回网页内容。 
    305   (使用代理) 请求者只能使用代理访问请求的网页。 如果服务器返回此响应,还表示请求者应使用代理。 
    307   (临时重定向)  服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。


    4开头的http状态码表示请求出错
     
    400    服务器不理解请求的语法。 
    401   请求要求身份验证。 对于需要登录的网页,服务器可能返回此响应。 
    403   服务器拒绝请求。 
    404   服务器找不到请求的网页。 
    405   禁用请求中指定的方法。 
    406   无法使用请求的内容特性响应请求的网页。 
    407   此状态代码与 401类似,但指定请求者应当授权使用代理。 
    408   服务器等候请求时发生超时。 
    409   服务器在完成请求时发生冲突。 服务器必须在响应中包含有关冲突的信息。 
    410   如果请求的资源已永久删除,服务器就会返回此响应。 
    411   服务器不接受不含有效内容长度标头字段的请求。 
    412   服务器未满足请求者在请求中设置的其中一个前提条件。 
    413   服务器无法处理请求,因为请求实体过大,超出服务器的处理能力。 
    414   请求的 URI(通常为网址)过长,服务器无法处理。 
    415   请求的格式不受请求页面的支持。 
    416   如果页面无法提供请求的范围,则服务器会返回此状态代码。 
    417   服务器未满足”期望”请求标头字段的要求。


    5开头状态码并不常见,但是我们应该知道

    500   (服务器内部错误)  服务器遇到错误,无法完成请求。 
    501   (尚未实施) 服务器不具备完成请求的功能。 例如,服务器无法识别请求方法时可能会返回此代码。 
    502   (错误网关) 服务器作为网关或代理,从上游服务器收到无效响应。 
    503   (服务不可用) 服务器目前无法使用(由于超载或停机维护)。 通常,这只是暂时状态。 
    504   (网关超时)  服务器作为网关或代理,但是没有及时从上游服务器收到请求。 
    505   (HTTP 版本不受支持) 服务器不支持请求中所用的 HTTP 协议版本。

     

     

     
     
  • 相关阅读:
    browser-sync events.js:85 throw er; // Unhandled 'error' event
    js判断页面放大缩小
    uniapp小实例-新闻列表及详情
    uniapp 分享接口
    uniapp--第三方登录 小程序登录
    vue h5转换uni-app指南(vue转uni、h5转uni)
    uniapp详解及配置
    uniapp快速上手
    Vuex 的项目实例11 列表数据的按需切换
    Vuex 的项目实例10 底部按钮高亮切换
  • 原文地址:https://www.cnblogs.com/xgwshen/p/7089337.html
Copyright © 2020-2023  润新知