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

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

月光魔力鸭

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


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
最近有个小功能需要一些基础数据,找了一下在小程序上有发现,暂时还没找到他的网站,想着把这些数据爬一些下来做为基础数据使用的。本来还想着直接反编译小程序的,没想到微信变更了加密方式,以前反编译的路子走不通了。
前一阵子做了个图床,可以粘贴上传,查看服务器上的文件... 但是自己的服务器总是有问题..空间还小,就怕哪天没钱续费了。同事昨天想要一个七牛的图床,在网上找了下,只找到了 qiniu upload files插件,自己使用了下,挺好用,但是没有复制粘贴
通过registry 自建 dockerhub
登录方式现在非常多,不过像我这种小站让用户自己注册基本是不可能的了,只能依赖现有的第三方的登录来集成,之前有集成github,不过这个太过针对性,这里准备集成QQ互联登录,慢慢记录下。
本篇文章以一个实际的小项目为主题进行从头到尾的讲解实现,该项目总计开发时长约6小时,主要是有很多页面或功能都是现成的,直接复制过来的,剩下的就调整下样式、字段内容等。
ubuntu 配置nginx反向代理,这里简单记录下,后续再复习..
最近在做直播,是用的webrtc,然后找的免费的starrtc ,当然,可能由于种种原因吧.. 用起来并没有特别顺畅,后续还希望能够深入这部分,从现在开始学习..当然,websocket 是顺带的,可以用来发消息什么的肯定也是要用到的。
功能来源于客户需求。客户有需求想把班级内所有学生的错题本生成pdf文档下载下来... 目前没有做这个功能,只有页面,还好chrome浏览器有保存pdf的功能,但是一想到这么多的学生,这么多的学科、以及这么多的参数... 还好有puppeteer