前端工程师如何快速的开发一个微信JSSDK应用

亲们,订阅号出来已经很久了,作为一个前端工程师或者全栈工程师,你是不是错过了什么?
大概许多攻城狮同砚还没有反应过来订阅号怎么回事,就马上要被微信的应用号秀一脸了。在应用号还没有正式出来之前,我们赶紧一起来看看怎样给自己的订阅号加个网页功效吧。

一、订阅号网页与平凡的HTML5网页的区别

可能会有很多同学还没有弄清楚普通的HTML网页与订阅号网页的差别,我在这里简朴的说明一下。

  1. 订阅号的网页就是微信的网页,普通的网页是W3C范例下的网页。
  2. 订阅号的网页通常是以遵守W3C的网页规范为前提的,但是也有可能有所差异,具体要凭据微信浏览器的解析本领而定,但是通常是支持大部分的W3C标准的。一定程度上W3C规范的网页作为订阅号的网页是没有题目的。
  3. 订阅号网页必要微信的认证。在认证后通常可以得到比普通的W3C网页更多的能力。比如扫描二维码,微信支付,拍照片,录音,WIFI设备等能力。
    以是订阅号网页具备比普通的W3C网页更强的终端能力,可以更好的提供移动端的服务,对付很多个人与公司来说都是值得尝试的。

二、开辟订阅号网页需要那些技能?

在了解了订阅号网页与普通网页的差别后,我们根本上知道了开发订阅号所需要的基本的技术。

  1. HTML + CSS + JS的前端技术
  2. 服务器技术
  3. 微信开发是所用到的SDK技术

由于1,2都是通用技术,所以我不在这里具体介绍了。我们现在重要介绍一下微信开发所需要的SDK技术。

三、订阅号开发的微信技术

订阅号开发所需要的纯微信上的技术预备如下:

  1. 大众号配置信息
    包括app id, app secret
  2. 服务器验证哀求接口
    即需要有一个接口可以与微信服务器对接,用于处置惩罚微信服务器返回的消息
  3. 一个引入了JSSDK的微信页面

公共号配置信息

公共号配置信息需要登录

获取,关于如何注册微信个人订阅号的问题请查看微信相关帮助。不在这里赘述了。
配置信息所在的位置是:开发=》基本配置
在开发者ID栏目里有两个东西

  1. AppID(应用ID)
  2. AppSecret(应用密钥)
    AppID是固定不变的,AppSecret是可以变革的。secret最好定期变化,以防止泄漏造成宁静问题。

一个存案的服务器域名

域名备案是中国特色,所以大家需要好好享受这个特色。我就不在这里详细介绍了。
有了域名后,将域名填入:
设置 =》 公众号设置 =》 功能设置 =》 JS接口安全域名
然后填入你想放的域名即可。

准备一个JSSDK的微信页面

准备微信页面是我们这次的重点。在这里会涉及到所有关于微信页面的制作的业务逻辑。我们将会分解每个步骤,详细解说原理与操作。
由于正式上线公共帐号需要备案的域名,所以对于大部分人来说照旧有点不方便。所以在这里我主要讲解如何开发与测试订阅号微信页面,然后将这个过程复制到已经备案的域名所对应的服务器上即可。

第一步是制作JSSDK的HTML页面

1. 首先是一个最简单的包含有JSSDK的HTML代码:

<!DOCTYPE html> <html>  <head>     <meta charset="UTF-8">     <meta name=viewport content="width=device-width">     <title>微信网页</title>     <script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> </head>  <body>     <h1>微信JSSDK网页</h1> </body>  </html>

2. 然后添加JS初始代码
为了代码的简洁,我们引入了jquery.

 <script src="https://code.jquery.com/jquery-2.1.4.min.js"></script>

然后添加初始化jssdk的代码

<script>   $(document).ready(function() {     // 根据实际填写接口的配置地点     // 这里的接口地址是基于node-weixin配置的。     var url = "/jssdk/config";        // 当前的网页请求地址     var weixinUrl = location.href.split(‘#‘)[0];      $.ajax({       url: url, //这个地址是服务器配置JSSDK的地址       data: {           // 这个地址是发生jssdk调用的url地址           // 用于服务器配置               url: weixinUrl       }     }).success(function(json) {       // 获得服务器返回的配置信息       var data = json.data;       var config = {};       for (var k in json.data) {         config[k] = json.data[k];       }       // config.debug = true;        // 添加你需要的JSSDK的权限       config.jsApiList = [         ‘checkJsApi‘,         ‘scanQRCode‘       ];       config.timestamp = parseInt(config.timestamp);       wx.config(config);       wx.ready(function() {         alert("微信jssdk配置成功!");       });       wx.error(function(res) {         alert(‘微信JSSDK配置失败!‘);       });     }); }); </script>

效果如下 :

对于配置JSSDK来说,最重要的是需要在服务器端提供一个配置参数,这个可以参考node-weixin的参数配置接口。如许前端只需要将当前的URL转入就可以完成整个JSSDK的参数的匹配。
获得配置信息后只要将接口权限配置一下就可以完成整个JSSDK的配置了。

3. 调用JSSDK的接口API
JSSDK的接口API有很多,我们可以通过一个简单的扫描调用来验证我们的代码的正确性。

首先我们要添加一个可以点击的HTML元素:

    <h2 class="qrcode">点击扫描</h2>

然后我们将wx.ready里的回调函数举行重写:

function() {   $(‘.qrcode‘).click(function () {     wx.scanQRCode({       // 默认为0,扫描效果由微信处理,1则直接返回扫描结果,       needResult: 1,        // 可以指定扫二维码还是一维码,默认二者都有       scanType: ["qrCode", "barCode"],        success: function (res) {         // 当needResult 为 1 时,扫码返回的结果         var result = res.resultStr;          alert(result);       }     }); }); }

这样我们在这个class为qrcode的HTML元素上点击后就可以调用二维码扫描功能了。

图片如下:


利用WeTop进行微信网页

上面的过程我们没有讨论到服务器,是因为我们使用了wetop,wetop已经帮你将所有的服务器测试环境配置好了。所以你完全不用自己开发服务器就可以进行微信的前端开发了。使用WeTop的方法非常简单。

  1. 在配置 =》 公共号参数配置 =》 app 将所有的参数配置完成
  2. 在接口 => AccessToken获取测试 测试能否正确的获取token
  3. 在接口 => jssdk 页面测试 里测试
  4. 通过指定模板地址,就可以将自己的网页放到手机服务器上进行测试了。JSSDK测试的默认地址是jssdk.html。

WeTop支持(Windows, Linux, Mac OS三种桌面OS),可以到

进行下载
或者
google搜索node-weixin-desktop找到源码,自行进行编译。

时间: 2024-12-23 15:47:22

前端工程师如何快速的开发一个微信JSSDK应用的相关文章

【如何快速的开发一个完整的iOS直播app】(原理篇)

一.个人见解(直播难与易) 直播难:个人认为要想把直播从零开始做出来,绝对是牛逼中的牛逼,大牛中的大牛,因为直播中运用到的技术难点非常之多,视频/音频处理,图形处理,视频/音频压缩,CDN分发,即时通讯等技术,每一个技术都够你学几年的. 直播易:已经有各个领域的大牛,封装好了许多牛逼的框架,我们只需要用别人写好的框架,就能快速的搭建一个直播app,也就是传说中的站在大牛肩膀上编程. 二.了解直播 热门直播产品 映客,斗鱼,熊猫,虎牙,花椒等等 直播效果图 直播效果.jpeg 1.一个完整直播ap

如何快速的开发一个完整的iOS直播app(原理篇)

前言 大半年没写博客了,但我一直关注着互联网的动向,最近会研究很多东西,并分享,今年移动直播行业的兴起,诞生了一大批网红,甚至明星也开始直播了,因此不得不跟上时代的步伐,由于第一次接触的原因,因此花了很多时间了解直播,整理了直播的原理,当前只是原理篇,后续会持续发布实战篇,教你从零开始搭建一个完整的iOS直播app,希望能帮助到更多的人更快的了解直播. 一.个人见解(直播难与易) 直播难:个人认为要想把直播从零开始做出来,绝对是牛逼中的牛逼,大牛中的大牛,因为直播中运用到的技术难点非常之多,视频

前端工程师养成记:开发环境搭建(Sublime Text必备插件推荐)

为了让自己更像一个前端工程师,决定从开发环境开始武装自己.本文将介绍前段工程师开发的一些利器的安装步骤,主要包括了: 1.Node.js的安装 2.Grunt的安装及常用插件 3.Sublime Text的安装及必备插件 一.Node.js的安装 Node.js就是一堆前端工程师捧红的,所以装上这个嘛,主要不是自己需要使用Node.js而是一堆工具对他的依赖. Windows下安装步骤很简单: 1.去到http://nodejs.org/下载最新的安装包,安装. 2.在CMD下运行,node和n

【如何快速的开发一个完整的 iOS 直播 app】(美颜篇)

来源:袁峥Seemygo 链接:http://www.jianshu.com/p/4646894245ba 前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,美颜功能是很重要的,如果没有美颜功能,可能分分钟钟掉粉千万,本篇主要讲解直播中美颜功能的实现原理,并且实现美颜功能. 利用GPUImage处理直播过程中美颜的流程 采集视频 => 获取每一帧图片 => 滤镜处理 => GPUImageView展示 美颜原

【如何快速的开发一个完整的iOS直播app】(播放篇)

前言 在看这篇之前,如果您还不了解直播原理,请查看上篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,集成ijkplayer成功后,就算完成直播功能一半的工程了,只要有拉流url,就能播放直播啦 本篇主要讲解的是直播app中,需要用到的一个很重要的开源框架ijkplayer,然后集成这个框架可能对大多数初学者还是比较有难度的,所以本篇主要教你解决集成[ijkplayer]遇见的各种坑. 很多文章,可能讲解的是如何做,我比较注重讲解为什么这样做,大家有什么不明白,还可以

【微信公众平台开发】微信JS-SDK开发

根据微信开发文档步骤如下: 1.先登录微信公众平台进入"公众号设置"的"功能设置"里填写"JS接口安全域名". JS接口安全域名设置 mi.com(前面不用带www/http,域名必须备案过) 2.引入JS文件 在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.0.0.js 3.通过config接口注入权限验证配置 wx.config({ debug: tr

【微信公众平台开发】微信JS-SDK开发,信公众平台js-sdk

根据微信开发文档步骤如下: 1.先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”. JS接口安全域名设置 mi.com(前面不用带www/http,域名必须备案过)   2.引入JS文件在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.0.0.js   3.通过config接口注入权限验证配置 wx.config({ debug: true, // 开启调试模式,调用的所有api

.NET开发一个微信跳一跳辅助程序

昨天微信更新了,出现了一个小游戏"跳一跳",玩了一下 赶紧还蛮有意思的 但纯粹是拼手感的,玩了好久,终于搞了个135分拿了个第一名,没想到过一会就被朋友刷下去了,最高的也就200来分把,于是就想着要是开发个辅助就好了,于是简单想了一下最高游戏 先来说下这个游戏的界面和规则: 先看看界面 规则:按住屏幕 按一定时间松开就可以跳跃,跳跃到前方的图案中得1分,图按中间得2分(连续多个中间累加2分,比如第一个2分 第二个4分 第三个6分 最高累计32分) 其它规则不说明了 整理了下实现原理,其

用Xamarin 开发一个微信(ios和android)(1) 架构篇

安装好xamarin 以后,我们就可以考虑开发的架构了,我们模拟企业级的应用,那么就考虑前后台分离了(如果简单,当然可以用sqlLite数据库了),物理架构如下 当然实际情况,肯定远比这个复杂,数据库服务器和web 服务器可以部署多台了. 数据库我们使用SQL server 即可(当然可以换成其他的,看自己了), Web服务器这边我们采用Web Api来实现接口,关于Web Api的知识,自己可以补充下了 至于为什么采用web api, 主要是因为 Web API 框架基于 ASP.NET MV