GET 和 POST

简介: GET 和 POST

与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。


然而,在以下情况中,请使用 POST 请求:


无法使用缓存文件(更新服务器上的文件或数据库) 向服务器发送大量数据(POST 没有数据量限制) 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠


发送一个带有参数的 get 请求


get 请求的参数就直接在 url 后面进行拼接就可以


const xhr = new XMLHttpRequest() // 直接在地址后面加一个 ?,然后以 key=value 的形式传递 // 两个数据之间以 & 分割 xhr.open('get', './data.php?a=100&b=200') xhr.send()


这样服务端就能接受到两个参数 一个是 a,值是 100,一个是 b,值是 200
发送一个带有参数的 post 请求
post 请求的参数是携带在请求体中的,所以不需要再 url 后面拼接
  const xhr = new XMLHttpRequest() xhr.open('post', './data.php')
  // 如果是用 ajax 对象发送 post 请求,必须要先设置一下请求头中的 content- type
  // 告诉一下服务端我给你的是一个什么样子的数据格式 xhr.setRequestHeader('content-type', 'application/x-www-form- urlencoded')
  // 请求体直接再 send 的时候写在 () 里面就行
  // 不需要问号,直接就是 'key=value&key=value' 的形式 xhr.send('a=100&b=200')


// 接口文档

// api
// XMLHttpRequest 对象
// 1. 创建一个 ajax 对象
// open(method,url,async)


// send(string) 将请求发送到服务器。
// string:仅用于 POST 请求
var xhr = new XMLHttpRequest()
// 2. 配置本次的请求信息
// 请求方式: 按照接口文档来进行书写


// 请求地址: 按照接口文档来进行书写
// 是否异步: 默认是 true 表示异步请求, 选填为 false, 表示同步请求
// xhr 对象中的 open ⽅法是来配置请求信息的
// 第⼀个参数是本次请求的请求⽅式 get / post / put / ...


// 第⼆个参数是本次请求的 url
// 第三个参数是本次请求是否异步,默认 true 表示异步,false 表示同步
// xhr.open('请求⽅式', '请求地址', 是否异步)


xhr.open('GET', 'http://webview.happyjia.top/api/api/getBanner_index', true)


// 3. 配置一个请求完成后触发的事件
// 请求完整: 本次请求发送出去, 服务器接收到了我们的请求, 并且服务器返回的信息已经回到了浏览器
xhr.onload = function () {
// 如何拿到后端返回的信息


// 语法: xhr.responseText
console.log(xhr.responseText)
}


// 4. 把本次请求发送出去

xhr.send()


  /*
      第一次尝试 ajax
    */
    // 1. 创建一个 ajax 对象
    var xhr = new XMLHttpRequest()
    // 2. 配置本次的请求信息
    // 请求方式: 按照接口文档来进行书写
    // 请求地址: 按照接口文档来进行书写
    // 是否异步: 默认是 true 表示异步请求, 选填为 false, 表示同步请求
    xhr.open('GET', 'http://localhost:8888/test/first', true)
    // 3. 配置一个请求完成后触发的事件
    // 请求完整: 本次请求发送出去, 服务器接收到了我们的请求, 并且服务器返回的信息已经回到了浏览器
    xhr.onload = function () {
      // 如何拿到后端返回的信息
      // 语法: xhr.responseText
      console.log(xhr.responseText)
    }
    // 4. 把本次请求发送出去
    xhr.send()
```
```
 /*
​      第二次测试 ajax
​    */
​    // 1. 创建ajax 对象
​    var xhr = new XMLHttpRequest()
​    // 2. 配置本次的请求信息
​    xhr.open('GET', 'http://localhost:8888/test/second', true)
​    // 3. 配置请求完成的事件
​    xhr.onload = function () {
​      // 当后端返回的是 json 格式字符串的时候, 我们需要进行单独的解析
​      // 语法: JSON.parse(json格式字符串)
​      // 返回值: 解析好的 js 格式的数据
​      var res = JSON.parse(xhr.responseText)
​      console.log(res)
​    }
​    // 4. 发送出去
​    xhr.send()
```
```
   /*
​      GET 和 POST 请求
​    */
​    // 1. GET 请求
​    // var xhr = new XMLHttpRequest()
​    // // 需要携带参数
​    // // 因为是 GET 请求, 直接在地址后面进行参数的书写
​    // xhr.open('GET', 'http://localhost:8888/test/third?name=前端小灰狼&age=18', true)
​    // xhr.onload = function () {
​    //   console.log(JSON.parse(xhr.responseText))
​    // }
​    // xhr.send()
​    // 2. POST 请求
​    var xhr = new XMLHttpRequest()
​    // 注意: 因为是 POST 请求, 不需要在地址后面拼接参数
​    xhr.open('POST', 'http://localhost:8888/test/fourth', true)
​    xhr.onload = function () {
​      console.log(JSON.parse(xhr.responseText))
​    }
​    // 注意: 当你发送 POST 请求, 并且需要携带参数的时候, 需要进行特殊说明
​    // 语法: xhr.setRequestHeader('content-type', 你传递参数的格式)
​    xhr.setRequestHeader('content-type', 'application/x-www-form-urlencoded')
​    // send 后面的() 就是书写请求体的位置
​    xhr.send('name=前端小灰狼&age=18')


https://www.axios-http.cn/docs/api_intro

相关文章
|
6月前
|
网络协议 数据安全/隐私保护
get和post的区别
get和post的区别
55 0
|
6月前
|
Web App开发 缓存 网络协议
get和post的区别!
get和post的区别!
|
6月前
|
缓存 安全 数据安全/隐私保护
get 跟 post 有什么区别?
get 跟 post 有什么区别?
73 0
|
JSON 数据格式
Post与@RequestBody
Post与@RequestBody
183 0
|
缓存 安全 数据库
【探索】Get与Post
Http,url,get,post的关系:Http协议通过定义get post等请求,对url地址描述的资源进行增删改查。
104 0
|
XML JSON 编解码
POST 怎么样用
POST 怎么样用
NSMutableURLRequest POST
NSMutableURLRequest POST
76 0
|
安全 数据处理
GET和POST到底啥区别了
GET和POST到底啥区别了
113 0
GET和POST到底啥区别了
|
缓存 前端开发 数据库
Ajax的get与post的区别,什么时候使用post?
Ajax的get与post的区别,什么时候使用post?
151 0
|
Web App开发 缓存 网络协议
深入【Get】与【Post】区别
深入【Get】与【Post】区别
203 0