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

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

月光魔力鸭

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


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
上一张中已经完成了比较简易的3D全景浏览,但是...这是写死在xml中的,对于我们实际的项目,这种情况是不可能适应的。所以,来了解下如何动态加载xml已经设置对应的热点。
接下来,我们综合上面的配置,再加一个选项页面配置,做一个天气预报的小栗子。
最近在做直播,是用的webrtc,然后找的免费的starrtc ,当然,可能由于种种原因吧.. 用起来并没有特别顺畅,后续还希望能够深入这部分,从现在开始学习..当然,websocket 是顺带的,可以用来发消息什么的肯定也是要用到的。
登录方式现在非常多,不过像我这种小站让用户自己注册基本是不可能的了,只能依赖现有的第三方的登录来集成,之前有集成github,不过这个太过针对性,这里准备集成QQ互联登录,慢慢记录下。
反爬有很多手段,字体反爬就是其中之一。之前一直都是听过,但是却没怎么在实际爬虫中遇到过,最近在一个爬虫题目网站上看到了,试了试,发现还挺麻烦,当然自己从头研究字体肯定麻烦,简单的是模块多的是,选几个就过了。
本来是想做一个图床,然后在chrome扩展中添加上,但是发现chrome的扩展有点毫无头绪,只能从头练习,从头学了。
昨天客户发现了个小BUG,文章发布使用的ueditor, 上传视频的时候当时好好的,后来怎么就是播放不了?
ffmpeg 采集摄像头进行推流,然后播放,实现直播。