封装http请求

在utils下的axios中写入

import Vue from 'vue'

import axios from 'axios'

import { getToken, userLoginOut } from './auth'

import router from '../router'

import { baseUrl } from '@/common/env.js'

let vm = new Vue()

const ajax = axios.create({

  baseURL: baseUrl,

  timeout: 30000

})

/** 请求拦截器 **/

ajax.interceptors.request.use(

  config => {

    const token = getToken()

    if (token) {

      config.headers.Authorization = token

    }

    return config

  },

  error => {

    return Promise.reject(error)

  }

)

/** 响应拦截器 **/

ajax.interceptors.response.use(

  response => {

    if (response.data.code === -1) {

      vm.$message({

        message: '登录已过期,请重新登录',

        type: 'error'

      })

      userLoginOut()

      router.push({

        name: 'Login'

      })

      return

    }

    if (response.status === 200) {

      return Promise.resolve(response.data)

    } else {

      return Promise.reject(response.data.message)

    }

  },

  error => {

    return Promise.reject(error)

  }

)

/* 统一封装get请求 */

export const get = (url, params, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'get',

      url,

      params,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

/* 统一封装post请求  */

export const post = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'post',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

/* 统一封装put请求  */

export const put = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'put',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

/* 统一封装delete请求  */

export const deletefn = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'delete',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

// 上传文件

export const upload = (url, data, config = {}) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'post',

      url,

      data,

      ...config

    })

      .then(response => {

        console.log(response)

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

// 下载文件

export const downLoad = (url, data, config = { responseType: 'blob' }) => {

  return new Promise((resolve, reject) => {

    ajax({

      method: 'get',

      url,

      data,

      ...config

    })

      .then(response => {

        resolve(response)

      })

      .catch(error => {

        reject(error)

      })

  })

}

=======================================================================

common.js中写入

/************************* 测试环境 ***********************/

const ip = ''

const baseUrl = ip + '/credit' // 本地测试用

/************************* 正式环境 ***********************/

// const ip = '' // 测试服

// const ip = '' // 正式服

// const baseUrl = ip + '/credit'


 

/********************* 图片上传管理 ***********************/

const upload = ip + '/upload/'

const myValidator = {

  regExpPhone: /^1([345789])[0-9]\d{8}$/,

  regExpEmail: /^([A-Za-z0-9_\-.])+@([A-Za-z0-9_\-.])+\.([A-Za-z]{2,4})$/,

  regExpPassword: /.{6,20}$/

}

module.exports = {

  ip,

  baseUrl,

  upload,

  myValidator

}

==================================================================

utils下的auth用于封装存储

export function setToken(val) {

  localStorage.setItem('token', val)

  localStorage.setItem('isLogin', true)

}

==================================================================

最后在api中引入即可

import { get, post, put, downLoad, deletefn } from '@/utils/axios'

// 用户登录

export function login(data) {

  return post('/site/login', data).then(res => {

    return res

  })

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Qt是一个功能强大的跨平台开发框架,其中包括了丰富的网络模块,可以轻松地实现HTTP请求。对于HTTP请求封装,主要包括以下几个方面。 1. QNetworkAccessManager类 QNetworkAccessManager类是Qt网络模块的核心类之一,它负责管理所有的网络请求。具体而言,它能够发出发出http请求,接收响应数据,并负责处理中间操作例如网络重定向、HTTP认证、代理等。总的来说,使用该类可以轻松完成HTTP请求封装。 2. QNetworkRequest类 QNetworkRequest类封装了一个HTTP请求,包括URL、HTTP请求头、HTTP请求方法等。我们可以通过设置这些属性来制定HTTP请求。例如,构造一个GET请求,设置请求头: QNetworkRequest request(QUrl("http://www.baidu.com"));request.setHeader(QNetworkRequest::ContentTypeHead er, "application/x-www-form-urlencoded"); 3. QNetworkReply类 QNetworkReply类封装了一个HTTP响应,它可以提取包括HTTP响应码和响应头在内的所有与HTTP请求及响应相关的信息。可以通过这个类获取HTTP返回的结果。 总结:Qt提供了完善的网络模块,支持httphttps协议,可以轻松实现http请求封装,自定义请求头,处理响应信息等。本质上就是通过一个网络管理器,发出请求,获取响应,进而完成http请求封装。因此,使用Qt实现http请求是一种简洁有效的方案。 ### 回答2: Qt是一款跨平台的C++开发框架,它提供了用于网络通信的相关组件,其中也包括了HTTP请求封装类。在Qt中,可以使用QNetworkAccessManager类来封装HTTP请求,这个类简化了HTTP请求的发送和接收,并提供了一些有用的事件和回调函数。 使用QNetworkAccessManager类发送HTTP请求时,需要先创建一个QNetworkRequest对象,指定要发送的URL地址和请求方法。可以在请求中添加自定义的HTTP请求头和请求体。接着,使用QNetworkAccessManager的post()、get()、put()等方法发送请求。当响应结果返回时,可以在接收的数据中解析出HTTP响应头和响应体,QNetworkAccessManager也提供了相关的信号和槽函数。 QNetworkAccessManager使用异步请求方式,即发送请求后会立即返回,等待从远端接收响应结果。如果需要同步请求,可以使用QNetworkReply类的waitForFinished()方法,但不建议在主线程中使用。 在Qt中,也提供了第三方的HTTP库,例如QHttpEngine和Qhttplib,可以更简便地实现HTTP请求。但使用Qt自带的QNetworkAccessManager类是更加轻量和简单的方式,可以避免额外依赖,并且具有更好的可移植性和跨平台性。 ### 回答3: Qt是一种跨平台的C++应用程序框架,提供了许多丰富的库,其中包括Qt网络库(QtNetwork),可轻松地进行HTTP请求。Qt封装了许多网络协议,例如TCP、UDP、HTTP、FTP等,使得开发者可以轻松地进行网络操作。 Qt提供了QNetworkAccessManager类,用于处理网络请求。它支持GET、POST、PUT、DELETE等HTTP请求方式。可以通过QNetworkRequest类设置请求头和请求参数。QNetworkAccessManager在请求完成后会发出信号,开发者可以捕获信号并进行逻辑处理。 除了QNetworkAccessManager,Qt还提供了QHttp类,用于发送和接收HTTP请求和响应。QHttp类是基于底层网络套接字的,需要开发者自行处理协议和数据传输。但是,在Qt5中,已不推荐使用QHttp类,而是推荐使用QNetworkAccessManager。 总之,Qt提供了一种简便的方式,使得开发者可以轻松地进行HTTP请求。无论是使用QNetworkAccessManager还是QHttp类,都可以轻松地进行网络请求并处理响应。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值