直接上图,金山的APP“微信导航”,从界面上看有粉丝数等关键数据,实现了直接关注功能,莫不是rest接口?这江湖是大佬们的江湖,小喽啰只有眼馋的份咯。

很早就听说过WeixinJSBridge,不过官方貌似不提倡,先晒晒学习笔记

【Pockey】编辑整理

  1. //通过关注微信好友
  2. function WeiXinAddContact(wxid, cb)
  3. {
  4. if (typeof WeixinJSBridge == 'undefined') return false;
  5. WeixinJSBridge.invoke('addContact', {
  6. webtype: '1',
  7. username: wxid
  8. }, function(d) {
  9. // 返回d.err_msg取值,d还有一个属性是err_desc
  10. // add_contact:cancel 用户取消
  11. // add_contact:fail 关注失败
  12. // add_contact:ok 关注成功
  13. // add_contact:added 已经关注
  14. WeixinJSBridge.log(d.err_msg);
  15. cb && cb(d.err_msg);
  16. });
  17. };
  18. //通过微信分享
  19. function WeiXinShareBtn() {
  20. if (typeof WeixinJSBridge == "undefined") {
  21. alert("请先通过微信xxxx");
  22. } else {
  23. WeixinJSBridge.invoke('shareTimeline', {
  24. "title": "xxx",
  25. "link": "xxxx",
  26. "desc": "关注xxx",
  27. "img_url": "xxxx"
  28. });
  29. }
  30. }

复制代码

1. 上面的代码目前在微信内置浏览器才有效果
2. WeiXinAddContact中的微信wxid需要微信的原始id
例如商翼云的微信id:i3eyun,原始id:gh_b15f77615e32,
在iphone版本的微信中使用两种id都能完成正常的关注
但在android版本中如果使用i3eyun这个无法返回,一直停留在“正在关注。。。”,而修改成id:gh_b15f77615e32就正常了
3. 如果用户希望用户在打开页面的时候,直接能弹出关注的对话框

  1. //init
  2. function r(f){(typeof WeixinJSBridge == 'undefined'||(typeof WeixinJSBridge.invoke == 'undefined'))?setTimeout('r('+f+')',200):f()}
  3. r(function(){
  4. WeiXinAddContact("gh_b15f77615e32");
  5. });

复制代码

微信内置浏览器会有WeixinJSBridge,但是需要一定的加载时间,WeixinJSBridge 有了之后 WeixinJSBridge.invoke也不一定有,所有看到r这个函数了把。。。(ps:每次打开都弹多不好意思阿,所以需要通过cookie来控 制,WeiXinAddContact回调状态来设置cookie和通过cookie判断是否要执行init的部分的r)

【Denis】分享

  1. //分享到朋友圈
  2. function weixinShareTimeline(title,desc,link,imgUrl){
  3. WeixinJSBridge.invoke('shareTimeline',{
  4. "img_url":imgUrl,
  5. //"img_width":"640",
  6. //"img_height":"640",
  7. "link":link,
  8. "desc": desc,
  9. "title":title
  10. });
  11. }
  12. //发送给好友
  13. function weixinSendAppMessage(title,desc,link,imgUrl){
  14. WeixinJSBridge.invoke('sendAppMessage',{
  15. //"appid":appId,
  16. "img_url":imgUrl,
  17. //"img_width":"640",
  18. //"img_height":"640",
  19. "link":link,
  20. "desc":desc,
  21. "title":title
  22. });
  23. }
  24. //分享到腾讯微博
  25. function weixinShareWeibo(title,link){
  26. WeixinJSBridge.invoke('shareWeibo',{
  27. "content":title + link,
  28. "url":link
  29. });
  30. }
  31. //关注指定的微信号
  32. function weixinAddContact(name){
  33. WeixinJSBridge.invoke("addContact", {webtype: "1",username: name}, function(e) {
  34. WeixinJSBridge.log(e.err_msg);
  35. //e.err_msg:add_contact:added 已经添加
  36. //e.err_msg:add_contact:cancel 取消添加
  37. //e.err_msg:add_contact:ok 添加成功
  38. if(e.err_msg == 'add_contact:added' || e.err_msg == 'add_contact:ok'){
  39. //关注成功,或者已经关注过
  40. }
  41. })
  42. }

复制代码

【jodan179】分享
1. 在微信内置浏览器中可以调用weixin协议链接直接查看某个微信号的资料,例如:

  1. <a href="weixin://profile/gh_b15f77615e32">商翼云</a>

复制代码

这里gh_xxxxxxxx就是用户的原始ID,注意,必须使用原始ID.

2. 分享到朋友圈:

  1. function ShareTofriends(img_url,link,title,desc) {
  2. //在HTML页面内嵌入这一段JS代码
  3. if(window.WeixinJSBridge){
  4. if( typeof(img_url) == 'undefined' || img_url == ""){
  5. var img_url = "xxxx";
  6. }
  7. if( typeof(link) == 'undefined' || link == ""){
  8. var img_url = window.location.href;
  9. }
  10. if ( typeof(title) == 'undefined' || title == "" ){
  11. var title = '点开看一下吧!';
  12. }
  13. if( typeof(desc) == 'undefined' || desc == ""){
  14. var desc = "wendoscoo";
  15. }
  16. WeixinJSBridge.invoke('shareTimeline',{
  17. "img_url": img_url,
  18. //"img_width": "640",
  19. //"img_height": "640",
  20. "link": link,
  21. "desc": desc,
  22. "title": title
  23. },function(res){
  24. // 返回res.err_msg,取值
  25. // share_timeline:cancel 用户取消
  26. // share_timeline:fail 发送失败
  27. // share_timeline:ok 发送成功
  28. WeixinJSBridge.log(res.err_msg);
  29. });
  30. return false;
  31. } else{
  32. alert("WeixinJSBridge对象不存在!!");
  33. }
  34. };

复制代码

然后同样使用一个a标签实现分享功能,加上onclick时间调用分享的JS函数就可以了

  1. <a href="javascript:void(0);" onclick="ShareTOfriend('分享弹出窗的图片URL地址','分享的页面链接','分享弹出窗的标题','分享内容的描述')">分享到朋友圈</a>

复制代码

传说中的WeixinJSBridge和微信rest接口的更多相关文章

  1. 总结的一些微信API接口

    本文给大家介绍的是个人总结的一些微信API接口,包括微信支付.微信红包.微信卡券.微信小店等,十分的全面,有需要的小伙伴可以参考下. 1. [代码]index.php <?php include ...

  2. md笔记——微信JS接口

    微信js接口 隐藏微信中网页右上角按钮 document.addEventListener('WeixinJSBridgeReady', function onBridgeReady() { Weix ...

  3. 微信JS接口

      微信JS接口 分享到朋友圈 分享给朋友 分享到QQ 拍照或从手机相册中选图 识别音频并返回识别结果 使用微信内置地图查看位置来源:http://www.cnblogs.com/txw1958/p/ ...

  4. 微信录音接口的调用以及amr文件转码MP3文件的实现

    最近实现录音功能,主要涉及到录音的上传和下载,以及转码问题.微信,QQ默认的的音频文件是amr格式的,而播放器却不识别amr格式的音频,必须尽行转码.amr文件分为两种,一种是通用的amr格式,这种文 ...

  5. 微信支付接口 H5

    php微信支付若干问题记录 1.缺少参数$key0$ 此问题的可能性有几种,大致有1.timeStamp这个参数应该是string类型,默认time是int 2.确实是参数缺少  比如:prepay_ ...

  6. asp.net mvc 如何调用微信jssdk接口:分享到微信朋友(圈)| 分享到qq空间

    如何在asp.net mvc 项目里, 调用微信jssdk接口,现实功能: 分享到微信朋友(圈)| 分享到qq空间 1 创建一个Action,准备一些数据,初始化数据(签名): /// <sum ...

  7. 微信公开课发布微信官方教程:教你用好微信JS-SDK接口

    微信公众平台开放JS-SDK(微信内网页开发工具包),说明文档已经有相关使用方法和示例了,很多同学觉得不是很直观,为此微信公开课发布微信官方教程:教你用好微信JS-SDK接口. 1.分享类接口:支持获 ...

  8. 官方教程:教你用好微信JS-SDK接口

    微信开放JS-SDK接口,开发者和行业用户可谓是欢欣鼓舞.奔走相告,目测将激起一大波第三方开发商的创新产品!真真是H5开发者的利好!但也有用户表示,还不了解JS-SDK接口到底是啥,究竟怎么用.现在, ...

  9. php微信支付接口开发程序

    php微信支付接口开发程序讲解 微信支付接口现在也慢慢的像支付宝一个可以利用api接口来实现第三方网站或应用进行支付了, 下文整理了一个php微信支付接口开发程序并且己测试,有兴趣的朋友可进入参考. ...

随机推荐

  1. Example to use django queryset

    from django.db.models import get_app, get_models, get_model from django.db import models #get the ce ...

  2. AngularJS跨域请求

    本文主要针对网上各种跨域请求的总结,并加入自己的验证判断,实现工作中遇到的跨域问题.所涉及到的领域很小,仅仅局限于:AngularJS CORS post 并同时需要实现json数据传送给服务器. 首 ...

  3. 【转】C语言位运算符:与、或、异或、取反、左移与右移详细介绍

    转载自:http://www.jb51.net/article/40559.htm,感谢原作者. 以下是对C语言中的位运算符:与.或.异或.取反.左移与右移进行了详细的分析介绍,需要的朋友可以过来参考 ...

  4. 《TCP/IP详解 卷一》读书笔记-----DNS

    1.DNS是一个分布式数据库系统用来提供主机名和IP地址之间的映射,之所以称为分布式原因的原因是因特网上没有一台主机知道这类映射的全部信息,当然也不可能做到,因为数据量实在太大了 2.应用程序通过一个 ...

  5. java获取Json和http状态码

    最近再做接口自动化测试,其中有几个方法比较重要 1.获取http状态码 /* * 返回接口状态码 * */ public static String getHttpCode(String url) { ...

  6. 如何实现ZBrush中的Alt和Shift键的快速运用

    ZBrush是一个数字雕刻和绘画软件,它以强大的功能和直观的工作流程彻底改变了整个三维雕刻行业.在一个简洁的界面中,ZBrush®为当代数字艺术家提供了世界上最先进的工具.利用快捷键能使操作更快捷高效 ...

  7. 【每天一题ACM】 斐波那契数列(Fibonacci sequence)的实现

    最近因为一些原因需要接触一些ACM的东西,想想写个blog当作笔记吧!同时也给有需要的人一些参考 话不多说,关于斐波那契数列(Fibonacci sequence)不了解的同学可以看看百度百科之类的, ...

  8. 数字对 (长乐一中模拟赛day2T2)

    2.数字对 [题目描述] 小H是个善于思考的学生,现在她又在思考一个有关序列的问题. 她的面前浮现出一个长度为n的序列{ai},她想找出一段区间[L, R](1 <= L <= R < ...

  9. 【转】【WPF】WPF 自定义快捷键命令(Command)

    命令简介 WPF 中的命令是通过实现 ICommand 接口创建的.ICommand 公开两个方法(Execute 及 CanExecute)和一个事件(CanExecuteChanged).Exec ...

  10. C# 改变无边框窗体的尺寸大小

    以下代码为修改窗体尺寸的代码: const int HTLEFT = 10; ; ; ; ; ; const int HTBOTTOMLEFT = 0x10; ; protected override ...