微信小程序通过jsonrpc调用python服务端接口

微信小程序通过jsonrpc调用python服务端接口

月光魔力鸭

2021-01-16 23:36 阅读 684 喜欢 0 jsonrpc

与python后端进行联调,后端协议为jsonrpc ,这里简单记录下jsonrpc的通用请求函数,并附带几个栗子。

jsonrpc 这里以2.0进行记录

JSON-RPC是一个无状态且轻量级的RPC协议,其传输内容以JSON方式,相对于一般的HTTP请求通过URI调用远程服务器,JSON-RPC直接在内容中定义了要调用的函数名称(如 {“method”: “getUser”}),对于开发者来说非常的方便。Bitcoin和Ethereum都支持JSON-RPC通过客户端直接调用节点上的函数或方法。

JSON-RPC请求

JSON-RPC 2.0和1.0之间一些差异,我们这里介绍2.0的使用,一个JSON-RPC的请求必须包含以下4个字段。

在微信小程序中的请求函数

/**
   * 封装通用请求,jsonrpc
   * @param {String} url server请求地址
   * @param {Object} params jsonrpc 附带params数据
   */
  request : function(url,params,cookie){
    let _util = this;
    return new Promise((r,j)=>{
      let header = {
        'content-type': 'application/json',
        'Cookie' :cookie,
        'x-requested-with': 'XMLHttpRequest'
      }
      wx.request({
        url: config.serverHost+url,
        method: 'POST',
        data: {
          jsonrpc: "2.0",
          method: "call",
          params: params,
        },
        header: header,
        success: function (res) {
          //判断正常返回数据,如果不符合,则直接提示报错即可。
          res = res.data;
          if(res.error && res.error.data && res.error.data.message){
            _util.msg(res.error.data.message);
          }
          r(res);
        },
        fail : function(err){
          console.log(`请求失败:[${url}] : ${err.message}`)
          //如果请求失败后,需要将当前的数据进行记录日志,然后发送至server
          _util.msg('当前请求失败,请退出后重试')
          r(null);
        }
      })
    })
  },

调用栗子A

let requestContext = {
  lang : 'zh_CN',tz : false,uid : 2,allowed_company_ids:[1],bin_size:true
};
...
/**
   * 保存加梯表单
   */
  saveForm: async function(formData){
    let cookie = await util._getCookie();//获取之前保存的cookie
    let params = {
      //按照顺序写入参数
      args : [formData.name,formData.phone,formData.address,formData.community,formData.location],
      kwargs : {context : requestContext},
      method : 'submit',
      model : 'see.happy.lead'
    }
    let res = await util.request(config.url,params,cookie);
    return res && res.result ? true : false;
  },

一直没接触python,对于jsonrpc 也没怎么用过,都是跟java nodejs 做对接。 个人感觉这种方式对于后端来说会减少不少工作。

转载请注明出处: https://chrunlee.cn/article/mini-program-jsonrpc-python.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
扩展程序中会有需要请求外部接口获取数据的时候,如果直接在JS中写的话,会跨域,但是谷歌扩展程序支持这种情况,只需要配置一下即可。
最近一直琢磨着做一个第三方统一登录的这么一个小东西,虽然网上其实也挺多的.. 不过造轮子的感觉还是很爽的。 QQ /Github 比较简单,申请下就OK 了.. 微信真不是个东西,得花钱。
前几天同事抱怨说微博太费劲了... 一万多条记录,可能会把他累死,我心想.. 重复工作不都可以用程序代替么..
之前看知乎相中了一个想法,给宝宝做一个站,上传生活的日常照片啊、视频之类的,存储肯定是在自己家里,然后做个穿透这样..开始做的时候又想着是时候接触下这些东西了,虽然公司都一点不用,但是自己没事接触下拓展下也是好的。
本篇文章以一个实际的小项目为主题进行从头到尾的讲解实现,该项目总计开发时长约6小时,主要是有很多页面或功能都是现成的,直接复制过来的,剩下的就调整下样式、字段内容等。
本来是想做一个图床,然后在chrome扩展中添加上,但是发现chrome的扩展有点毫无头绪,只能从头练习,从头学了。
mysql数据库插入double类型确没有小数点
chrome 如何查看placeholder样式以及其他伪类样式