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

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

月光魔力鸭

2021-01-16 23:36 阅读 99 喜欢 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


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
最近在做直播,是用的webrtc,然后找的免费的starrtc ,当然,可能由于种种原因吧.. 用起来并没有特别顺畅,后续还希望能够深入这部分,从现在开始学习..当然,websocket 是顺带的,可以用来发消息什么的肯定也是要用到的。
chrome 如何查看placeholder样式以及其他伪类样式
昨天实现一个tabbar的时候发现怎么都无法跳转,直接拿的官方的demo,后来才发现是自定义tabbar的问题。
最近一直琢磨着做一个第三方统一登录的这么一个小东西,虽然网上其实也挺多的.. 不过造轮子的感觉还是很爽的。 QQ /Github 比较简单,申请下就OK 了.. 微信真不是个东西,得花钱。
登录方式现在非常多,不过像我这种小站让用户自己注册基本是不可能的了,只能依赖现有的第三方的登录来集成,之前有集成github,不过这个太过针对性,这里准备集成QQ互联登录,慢慢记录下。
之前看知乎相中了一个想法,给宝宝做一个站,上传生活的日常照片啊、视频之类的,存储肯定是在自己家里,然后做个穿透这样..开始做的时候又想着是时候接触下这些东西了,虽然公司都一点不用,但是自己没事接触下拓展下也是好的。
需求:可能会有在页面加载的时候想执行某个js,例如统计页面的DOM等等。
上一章,我们学习和了解了websocket 是什么以及初始搭建,接下来,我们继续了解,如何进行广播以及对应的私聊呢。