文档章节

如何在微信小程序中使用 Hprose

andot
 andot
发布于 2016/09/28 20:59
字数 745
阅读 2808
收藏 20

Hprose 技术交流群:48855729

首先下载 微信小程序开发工具,之后安装。

然后按照网上那一堆微信小程序 Hello World 教程创建一个小程序。

接下来我们下载 hprose-wx,或者从开源中国的 Git 服务器镜像下载。

可以用 git clone 下载,也可以只下载 dist 目录下的文件,dist 目录下面的这两个版本都可以用:

  • hprose.src.js 是源码版本
  • hprose.js 是压缩版本

调试阶段建议用源码版本。

之后,你可以把它们复制到你创建的那个微信小程序的 utils 目录下(复制其中一个就可以),然后将它改名为 hprose.js(这一步可选,只为后面引用的时候,名称统一)。

接下来,打开 pages/index/index.js 文件。

在开头加上:

var hprose = require('../../utils/hprose.js');

然后在 onLoad 事件中加入以下代码:

    var client = hprose.Client.create("http://www.hprose.com/example/", ["hello"]);
    client.hello("world", function(result) {
      console.log(result);
    });

总体看上去是这样的:

//index.js

var hprose = require('../../utils/hprose.js');

//获取应用实例
var app = getApp()
Page({
  data: {
    motto: 'Hello World',
    userInfo: {}
  },
  //事件处理函数
  bindViewTap: function() {
    wx.navigateTo({
      url: '../logs/logs'
    })
  },
  onLoad: function () {
    console.log('onLoad')
    var client = hprose.Client.create("http://www.hprose.com/example/", ["hello"]);
    client.hello("world", function(result) {
      console.log(result);
    });
    var that = this
    //调用应用实例的方法获取全局数据
    app.getUserInfo(function(userInfo){
      //更新数据
      that.setData({
        userInfo:userInfo
      })
    })
  }
})

然后点编译,运行,如果你的网络没有问题的,你会在调试控制台中看到:

Hello World

好了,就这么简单,接下来,你就可以用 hprose 来做微信小程序开发了。

虽然上面仅仅列出了简单调用,但实际上 Hprose 的所有功能在微信小程序中全部可以使用,包括负载均衡,故障切换,幂等性调用失败自动重试,订阅推送等等。而且不仅仅支持 https 服务,也支持 wss 服务,而且使用方式也是一样一样的。当然,如果你需要推送数据,或者需要传输二进制数据,使用 wss 服务是最好的选择。

对于 hprose 服务器来说,编写 wss 服务和编写 https 服务器也是一样一样的,而且发布了 wss 服务的同时,也会发布相同的 https 服务,因此,你两种服务可以同时使用。

如果你用的是微信小程序的正式开发账号,那么连接的服务器地址应该是 https 的而不能是 http 的,而且应该在开发账号里设置要连接的服务器地址。

© 著作权归作者所有

共有 人打赏支持
andot

andot

粉丝 128
博文 8
码字总数 16729
作品 17
潍坊
程序员
私信 提问
加载中

评论(8)

andot
andot

引用来自“yangbo1995”的评论

我的接口地址是rpc方法,我想问下怎么调用
如果是 hprose 的 rpc 接口,就按照 hprose 客户端文档里写的那样调用就可以了。
yangbo1995
yangbo1995
我的接口地址是rpc方法,我想问下怎么调用
阿刁ktsos
hprose 真神器耶
andot
andot
已经在真机测试通过了,在 iOS 和 android 手机上都能完美运行!
andot
andot
地址改为微信小程序专用版的 hprose 地址了。
andot
andot

引用来自“沙发迪”的评论

我觉得hprose是一个神器

引用来自“啦啦啦拉拉”的评论

能不能避开跨域访问的限制???
开发环境下是可以的,真机不知道,没有内测账号。
啦啦啦拉拉
啦啦啦拉拉

引用来自“沙发迪”的评论

我觉得hprose是一个神器
能不能避开跨域访问的限制???
沙发迪
沙发迪
我觉得hprose是一个神器
Hprose for JavaScript/HTML5 支持微信小程序啦

Hprose 2.0 for JavaScript/HTML5 从发布之后,就一直紧随潮流,不但对电脑、手机、平板上的各种浏览器都提供了良好的支持以外,而且对各种 Hybird app 都提供了良好支持(包括但不限于 ioni...

andot
2016/09/28
2.8K
5
异步通信组件hprose在微信小程序中的使用例子

网上搜索了在微信小程序中的使用,基本都是最老的版本 目前在新版中无法使用 现在写一个例子 第一步: 准备好一个hprose的服务端,什么语言的都行,我这里使用的是nodejs版本的 我进入开源的官方...

MrInsight
2018/05/28
0
0
小程序 大假期,技术猿国庆假期的正确打开方式…

明天(10月1日)就是国庆黄金7天假了。作为技术猿,除了美美的睡一觉好像也没啥别的事了。与其窝在家里玩手机刷朋友圈,不如做个小程序玩玩。 微信小程序开发正当时,没有内测资格不要紧。这...

凝小紫
2016/09/30
5.7K
11
微信小程序插件 - 开发教程

昨天(2018.3.13),微信小程序发布了重大功能更新,支持插件的使用和开发,个人预计,不超过2个月,优质服务的插件将会如雨后春笋般涌现。 这篇文章,我将会带大家,从0开始,学习如何开发和...

理工男海哥
2018/03/14
554
0
云+社区技术沙龙 - 微信小程序敏捷开发实战(上海站)

从微信的诞生,到微信公众号、微信支付,再到小程序,腾讯生态在一次又一次影响用户行为习惯的同时,也为开发者提供了新的思路和技能发展方向。无可置疑,微信小程序开发浪潮已经来临,也将在...

极客邦Geekbang_Event
2018/04/15
1
0

没有更多内容

加载失败,请刷新页面

加载更多

mysql grant 用户权限总结

用户权限管理主要有以下作用: 1. 可以限制用户访问哪些库、哪些表 2. 可以限制用户对哪些表执行SELECT、CREATE、DELETE、DELETE、ALTER等操作 3. 可以限制用户登录的IP或域名 4. 可以限制用...

Airship
29分钟前
1
0
RabbitMQ学习(3)

1. 消费端 1. 消费端通过推模式或者拉模式从RabbitMQ中获取并消费消息,当消费者确认处理消息后,可以手动确认消息已被接收,然后就会将该消息从RabbitMQ的队列中标记再清除,消费者端还可以...

江左煤郎
40分钟前
1
0
linux mysql(5.7)开启慢查询

一、有3个配置需要设置, 1:相关开关 2:日志目录文件 3:慢查询的时间限制 二、设置完之后重启mysql service mariadb restart 三、重启后做个测试 连接mysql 并查询: select sleep(6); 四...

chro008
47分钟前
2
0
选择IDC机房、选择硬件、上架服务器、装系统

选择IDC机房 当业务量比较大的时候,往往选用IDC而不是公有云来跑业务。 IDC机房的服务一般分为两种 需要我们自己购买服务器和网络设备,托管到IDC机房。IDC机房会提供布线、巡检、硬件操作等...

李超小牛子
49分钟前
2
0
《傲慢与偏见》的读书笔记与读后感作文2400字

《傲慢与偏见》的读书笔记与读后感作文2400字: 作者:孙苑馨;笔者按:读书这个习惯是我爸妈养出来的。小时候父母赚的钱除了吃饭穿衣剩下的就是买书了,他们除了买各种新鲜出版的文艺派图书...

原创小博客
57分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部