当前位置:首页 >> 技术分享 >> 详情
sousuo
sousuo

GET请求大于2048个字符之后报错的问题解决

上传时间:2019-11-21             浏览次数:90

最近做一个小程序修改,前后端通信时候出现一个奇怪的现象,就是当请求的参数比较长就会报错。后来直接报404错误。

本来以为是后台程序有问题,就想着怎么去修改后台程序的,最后发现原来是小程序中使用wx.request做了get请求,并不是post请求。

于是改为POST请求,立马OK!

原来罪归祸首就是:GET请求最大是2048个字符不能再多了。

附:《HTTP 请求方式: GET和POST的比较当发送数据时,GET 方法向 URL 添加数据;URL 的长度是受限制的(URL 的最大长度是 2048 个字符)。》

什么是HTTP?

超文本传输协议(HyperText Transfer Protocol -- HTTP)是一个设计来使客户端和服务器顺利进行通讯的协议。

HTTP在客户端和服务器之间以request-response protocol(请求-回复协议)工作。


GET - 从指定的服务器中获取数据

POST - 提交数据给指定的服务器处理


GET方法:

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

  • POST请求不能被缓存下来
  • POST请求不会保存在浏览器浏览记录中
  • 以POST请求的URL无法保存为浏览器书签
  • POST请求没有长度限制

GET和POST的区别:


  GE POST
点击返回/刷新按钮 没有影响 数据会重新发送(浏览器将会提示用户“数据被从新提交”)
添加书签 可以 不可以
缓存 可以 不可以
编码类型(Encoding type) application/x-www-form-urlencoded
application/x-www-form-urlencoded or multipart/form-data. 请为二进制数据使用multipart编码
历史记录 参数保留在浏览器历史中。 参数不会保留在浏览器历史中。
长度限制 当发送数据时,GET 方法向 URL 添加数据;URL 的长度是受限制的(URL 的最大长度是 2048 个字符)。
没有
数据类型限制 只允许ASCII字符类型 没有限制。允许二进制数据
安全性 查询字符串会显示在地址栏的URL中,不安全,请不要使用GET请求提交敏感数据 因为数据不会显示在地址栏中,也不会缓存下来或保存在浏览记录中,所以看POST求情比GET请求安全,但也不是最安全的方式。如需要传送敏感数据,请使用加密方式传输
可见性 查询字符串显示在地址栏的URL中,可见 查询字符串不会显示在地址栏中,不可见


其他HTTP请求方式


方式 描述
HEAD 与GET请求类似,不同在与服务器只返回HTTP头部信息,没有页面内容
PUT 上传指定URL的描述
DELETE 删除指定资源
OPTIONS 返回服务器支持的HTTP方法
CONNECT 转换为透明TCP/IP隧道的连接请求
 


0371-56789390
公司地址

郑州市花园路东风路向西300路南弘熹台22层

联系我们