微信小程序“一劳永逸”的接口封装

前言

  最近都在研究小程序了,我可以的!

需求

  之前都是用vue来开发项目的,接口模块我特意封装了一下。感觉也可以记录一下

  小程序的接口虽说简单,但是重复调用那么多,显得不专业(一本正经的胡说八道)

  还有一篇,小程序遇到了的那些坑和小技巧)待续

一、小程序接口请求流程

  

  简单的画了一个流程图

二、域名配置

  一定要配置https,小程序上配置的域名必须是域名备案的,还有一定服务器要TLS1.2以上

  

、打开微信开发者工具,打开你的项目,点开详情。确认一下域名是否一一匹对。不然会编译失败的哦

  

四、在你的项目文件utils 文件中新建api.js http.js

  

五、http.js 代码(复制过去就可以了)

    

module.exports = {
  http(url, method, params) {
    let token = ‘token‘ // 获取token,自行获取token和签名,token和签名表示每个接口都要发送的数据
    let sign = ‘sign‘ // 获取签名 (后台怎么定义的,就传什么)
    let data = {
      token,
      sign
    }
    if (params.data) { // 在这里判断一下data是否存在,params表示前端需要传递的数据,params是一个对象,有三组键值对,data:表示请求要发送的数据,success:成功的回调,fail:失败的回调,这三个字段可缺可无,其余字段会忽略
      for (let key in params.data) { // 在这里判断传过来的参数值为null,就删除这个属性
        if (params.data[key] == null || params.data[key] == ‘null‘) {
          delete params.data[key]
        }
      }
      data = { ...data, ...params.data }
    }
    wx.request({
      url: ‘你配置的域名‘ + url, // 就是拼接上前缀,此接口域名是开放接口,可访问
      method: method == ‘post‘ ? ‘post‘ : ‘get‘, // 判断请求类型,除了值等于‘post‘外,其余值均视作get 其他的请求类型也可以自己加上的
      data,
      header: {
        ‘content-type‘: ‘application/json‘
      },
      success(res) {
        params.success && params.success(res.data)
      },
      fail(err) {
        params.fail && params.fail(err)
      }
    })
  }
}

六、api.js(再次复制代码 就可以了)

  

// 在这里面定义所有接口,一个文件管理所有接口,易于维护
import { http } from ‘./http‘; // 引入刚刚封装好的http模块,import属于ES6的语法,微信开发者工具必须打开ES6转ES5选项

function femaleNameApi(params) { // 请求随机古诗词接口
  http(‘project/projectInfos‘, ‘get‘, params)  // 接口请求的路由地址以及请求方法在此处传递
}

// 每一个接口定义一个函数,然后暴露出去,供逻辑代码调用

function novelApi(params) { // 小说推荐接口
  http(‘/novelApi‘, ‘get‘, params)
}

export default { // 暴露接口
  femaleNameApi,
  novelApi
}

七、在index.js 调用(你想在哪里用就在哪里用)

//index.js
import http from ‘../../utils/api‘ // 引入api接口管理文件

Page({
  onLoad: function () {

    this.getData()
  },

  getData(){
    http.femaleNameApi({ // 调用接口,传入参数
      data: {
        token: ‘470712FF0FE2392D6CB6D8A6560805CC‘
      },
      success: res => {
        console.log(‘接口请求成功‘, res)
        this.setData({
          femaleList: res.data
        })
      },
      fail: err => {
        console.log(err)
      }
    })
  }
})

八、打开控制台

  如果你这样的错

  

  忘记说了showRequestInfo() 这个了(一开始,以为是api 接口),直接在控制台输入这个方法就可以了,可以看到错误信息详情

  那说明你们的服务器要有证书,而且TLS版本要大于等于1.2

  (我把我后台逼疯了,哈哈哈哈哈哈哈)

  如果你是这样的,恭喜你接口成功了呢

  

九、Fannie式总结

  以上的两个文件,算是接口封装的模板,你放在哪一个项目里面都可以这样配置

  有一点一劳永逸的意思

  但是它封装的不够完美

  没有我的vue项目封装的好,改天再改造一下

  希望对你有帮助,拜拜咯!

原文地址:https://www.cnblogs.com/ifannie/p/11404229.html

时间: 2024-10-03 00:30:13

微信小程序“一劳永逸”的接口封装的相关文章

微信小程序wx.request接口

微信小程序wx.request接口 wx.request是小程序客户端与服务器端交互的接口 HTTPS 请求 一个微信小程序,只能同时(同时不能大于5个)有5个网络请求 wx.request(OBJECT) 发起网络请求 url data header method dataType wx.request({ url: 'test.php', //仅为示例,并非真实的接口地址 data: { x: '' , y: '' }, header: { 'content-type': 'applicat

微信小程序开发之Http封装

公司突然要开放微信小程序,持续蒙蔽的我还不知道小程序是个什么玩意. 于是上网查了一下,就开始着手开发..... 首先开发客户端的东西,都有个共同点,那就是  数据请求! 看了下小程序的请求方式大概和ajax请求差不多,所以先打好基础 从封装http请求开始 好了废话不多说了,上代码 首先....当然是建立配置文件,用来配置请求根路径 config.js export default { basePath: 'http://192.168.6.2:9002/api', fileBasePath:

微信小程序通过api接口将json数据展现到小程序示例

实现知乎客户端的一个重要知识前提就是,要知道怎么通过知乎新闻的接口,来把数据展示到微信小程序端上. 那么我们这一就先学习一下,如何将接口获取到的数据展示到微信小程序上. 1.用到的知识点 <1> wx.request 请求接口资源(微信小程序api中的发起请求部分) <2>swiper 实现轮播图的组件 <3>wx:for 循环语句 <4>微信小程序的基础知识 2.实现原理 首先,先看一下这个请求函数 wx.request({ url: '******',

微信小程序请求API接口PHPSESSID变化的解决方式

微信小程序开发,请求服务器API的方法使用的是微信官方提供的wx.request()方法.在开发中发现,每一个请求都会生成一个独立的PHPSESSID,如下图示: 搜索后得知,这是由于wx.request()造成的.如果直接使用浏览器请求并不会出现这种情况. 解决方式如下: 通过登录接口获取到用户的session_key 和 open_id,设置session信息如下: $3rd_session = md5(session_key . $open_id) $_SESSION[$3rd_sessi

微信小程序开发——使用promise封装异步请求

前言: 有在学vue的网友问如何封装网络请求,这里以正在写的小程序为例,做一个小程序的请求封装. 关于小程序发起 HTTPS 网络请求的Api,详情可以参考官方文档:wx.request(Object object). 如果直接使用官方提供的个Api,那么每次在进行网络请求调用时,我们都要按官方文档上说的那样传递需要设置的请求参数,然后对不同的请求相应结果做不同的处理.但是前端同服务器端的接口请求中有大部分的请求参数以及响应结果处理都是很类似的,也就没有必要对所有请求代码都重新敲敲一遍,那么对原

微信小程序之工具js封装与使用

工具库的创建与使用 创建一个common文件夹 在common文件夹中创建一个utils文件夹 在utils文件夹中创建util.js // 工具 function tool() { console.log('i am a tool function.'); } module.exports = { tool: tool } 在具体的页面js中调用 首先要引入工具文件 const util = require('../../common/utils/util'); 然后在具体的位置使用即可. o

微信小程序快递鸟快递查询接口对接

微信小程序快递查询接口对接指南 1.登录快递鸟官网注册页面注册快递鸟账号 网址:http://www.kdniao.com/reg 2.登录快递鸟用户管理后台 网址:http://www.kdniao.com/login 注:登录快递鸟用户管理后台后获得用户ID和APIKey,此用于保证应用来源的可靠性,避免应用伪造,被不法使用. 3.进入“我的会员中心”进行实名认证 注: 3.1.认证类型.应用类型根据用户实际情况选择即可,接口返回数据与选择结果无关: 3.2.标记为*的为必填,要求上传清晰.

微信小程序学习指南

作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 微信小程序正式公测, 张小龙全面阐述小程序,定档1月9日上线(附90分钟演讲全文) ... 前言:新人第一坑,跳坑指南:修改后,必须保存:ctrl+S: 1:官方工具:https://mp.weixin.qq.com/debug/w ... tml?t=1476434678461 2:简易教

微信小程序的那些坑

早闻微信小程序是个坑,结果名不虚传,细数一下我开发小程序遇过到坑. 1.UI组件过度封装. 微信小程序的组件是模仿react.js或vue.js的web组件设计的,并且封装了weui.css样式. PS:实现自定义多选或多选.(看微信小程序开发社区的问题,没有很完整的解决方案,于是自己摸索了一个方法) wxml <checkbox-group class="checkbox-group"> <label class="checkbox-label"