前端工程师如何快速的开发一个微信JSSDK应用
亲们,订阅号出来已经很久了,作为一个前端工程师或者全栈工程师,你是不是错过了什么?
大概许多攻城狮同砚还没有反应过来订阅号怎么回事,就马上要被微信的应用号秀一脸了。在应用号还没有正式出来之前,我们赶紧一起来看看怎样给自己的订阅号加个网页功效吧。
一、订阅号网页与平凡的HTML5网页的区别
可能会有很多同学还没有弄清楚普通的HTML网页与订阅号网页的差别,我在这里简朴的说明一下。
- 订阅号的网页就是微信的网页,普通的网页是W3C范例下的网页。
- 订阅号的网页通常是以遵守W3C的网页规范为前提的,但是也有可能有所差异,具体要凭据微信浏览器的解析本领而定,但是通常是支持大部分的W3C标准的。一定程度上W3C规范的网页作为订阅号的网页是没有题目的。
- 订阅号网页必要微信的认证。在认证后通常可以得到比普通的W3C网页更多的能力。比如扫描二维码,微信支付,拍照片,录音,WIFI设备等能力。
以是订阅号网页具备比普通的W3C网页更强的终端能力,可以更好的提供移动端的服务,对付很多个人与公司来说都是值得尝试的。
二、开辟订阅号网页需要那些技能?
在了解了订阅号网页与普通网页的差别后,我们根本上知道了开发订阅号所需要的基本的技术。
- HTML + CSS + JS的前端技术
- 服务器技术
- 微信开发是所用到的SDK技术
由于1,2都是通用技术,所以我不在这里具体介绍了。我们现在重要介绍一下微信开发所需要的SDK技术。
三、订阅号开发的微信技术
订阅号开发所需要的纯微信上的技术预备如下:
- 大众号配置信息
包括app id, app secret - 服务器验证哀求接口
即需要有一个接口可以与微信服务器对接,用于处置惩罚微信服务器返回的消息 - 一个引入了JSSDK的微信页面
公共号配置信息
公共号配置信息需要登录
获取,关于如何注册微信个人订阅号的问题请查看微信相关帮助。不在这里赘述了。
配置信息所在的位置是:开发=》基本配置
在开发者ID栏目里有两个东西
- AppID(应用ID)
- 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('#')[]; $.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: , // 可以指定扫二维码还是一维码,默认二者都有 scanType: ["qrCode", "barCode"], success: function (res) { // 当needResult 为 1 时,扫码返回的结果 var result = res.resultStr; alert(result); } }); }); }
这样我们在这个class为qrcode的HTML元素上点击后就可以调用二维码扫描功能了。
图片如下:
利用WeTop进行微信网页
上面的过程我们没有讨论到服务器,是因为我们使用了wetop,wetop已经帮你将所有的服务器测试环境配置好了。所以你完全不用自己开发服务器就可以进行微信的前端开发了。使用WeTop的方法非常简单。
- 在配置 =》 公共号参数配置 =》 app 将所有的参数配置完成
- 在接口 => AccessToken获取测试 测试能否正确的获取token
- 在接口 => jssdk 页面测试 里测试
- 通过指定模板地址,就可以将自己的网页放到手机服务器上进行测试了。JSSDK测试的默认地址是jssdk.html。
WeTop支持(Windows, Linux, Mac OS三种桌面OS),可以到
进行下载
或者
google搜索node-weixin-desktop找到源码,自行进行编译。
前端工程师如何快速的开发一个微信JSSDK应用的更多相关文章
- 如何快速地开发一个微信小程序
如何快速地开发一个微信小程序呢?我觉得作为初学者,最好能有一个模板,然后改这个模板. 同样作为初学者,刚开始的时候我有下面的几个问题,后来通过问同学,我弄清楚了. 微信小程序可以连接MySQL或者Sq ...
- 【如何快速的开发一个完整的iOS直播app】(原理篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 目录 [如何快速的开发一个完整的iOS直播app](原理篇) [如何快速的开发一个完整的iOS直播app](播放篇) [如何快速的开发一个完整的 ...
- 【如何快速的开发一个完整的 iOS 直播 app】(美颜篇)
来源:袁峥Seemygo 链接:http://www.jianshu.com/p/4646894245ba 前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播 ...
- 如何快速的开发一个完整的iOS直播app(原理篇)
目录 [如何快速的开发一个完整的iOS直播app](原理篇) [如何快速的开发一个完整的iOS直播app](播放篇) [如何快速的开发一个完整的iOS直播app](采集篇) 前言 大半年没写博客了,但 ...
- 抖音短视频爆火的背后到底是什么——如何快速的开发一个完整的直播app
前言 今年移动直播行业的兴起,诞生了一大批网红,甚至明星也开始直播了,因此不得不跟上时代的步伐,由于第一次接触的原因,因此花了很多时间了解直播,今天我来教你从零开始搭建一个完整的直播app,希望能帮助 ...
- 【如何快速的开发一个完整的iOS直播app】(美颜篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,美颜功能是很重 ...
- 【如何快速的开发一个完整的iOS直播app】(采集篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,首先需要采集主 ...
- 【如何快速的开发一个完整的iOS直播app】(播放篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 前言 在看这篇之前,如果您还不了解直播原理,请查看上篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,集成ijkpl ...
- 【如何快速的开发一个完整的iOS直播app】(推流篇)
前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,肯定需要流媒体服务器,本篇主要讲解直播中流媒体服务器搭建,并且讲解了如 ...
随机推荐
- iOS开发之调用系统打电话发短信接口以及程序内发短信
在本篇博客开头呢,先说一下写本篇的博客的原因吧.目前在做一个小项目,要用到在本应用程序内发验证码给其他用户,怎么在应用内发送短信的具体细节想不大起来了,于是就百度了一下,发现也有关于这方面的博客,点进 ...
- HTML5 Audio/Video 标签,属性,方法,事件汇总
HTML5 Audio/Video 标签,属性,方法,事件汇总 (转) 2011-06-28 13:16:48 <audio> 标签属性:src:音乐的URLpreload:预加载au ...
- Deffered.js的实现原理
在艾伦的推荐下,看了一个日本人写的延时加载库,非常轻量,写的很棒.作为我的源码学习的第一编. 在认真看了两天之后,才看懂它的实现原理,我下面把通自己的理解,进行了精简.只程现原理,方便日后的回顾.&l ...
- 利用Dockerfile构建一个基于centos 7,包括java 8, tomcat 7,php ,mysql+mycat的镜像
Dockerfile内容如下: FROM centos MAINTAINER Victor ivictor@foxmail.com WORKDIR /root RUN rm -f /etc/yum.r ...
- 【续集】塞翁失马,焉知非福:由 Styles.Render 所引发 runAllManagedModulesForAllRequests="true" 的思考
在上一篇中,还有个遗留问题没有解决,就是 ASP.NET MVC MapRoute .htm 不起作用,如果不使用 runAllManagedModulesForAllRequests="t ...
- 谈谈JIT编译器和本机影像生成器(NGen.exe)
前言 在看<CLR>的时候,作者在开篇的时候提到了NGen.exe,前面一节执行程序集的代码中提到:程序或方法执行前会执行MSCorEE.dll中的JIT函数把要执行方法的IL转换成本地的 ...
- 把《c++ primer》读薄(3-2 标准库vector容器+迭代器初探)
督促读书,总结精华,提炼笔记,抛砖引玉,有不合适的地方,欢迎留言指正. 标准库vector类型初探,同一种类型的对象的集合(类似数组),是一个类模版而不是数据类型,学名容器,负责管理 和 存储的元素 ...
- Word基础
1.页面设置 默认大小A4,长宽比0.618 页面布局 2.字体设置 选择要设置的字体->右键->字体 3.选择性粘贴 4.段落设置 选择文字->右键->段落 5.表格 =SU ...
- [ES] 安装
1.ElasticSearch安装的准备工作 Linux:CentOS6.4 Elasticsearc:elasticsearch-2.2.0 JDK:jdk-7u79-linux-x64 IK:1. ...
- virtualbox搭建ubuntu server nginx+mysql+tomcat web服务器1 (未完待续)
virtualbox搭建ubuntu server nginx+mysql+tomcat web服务器1 (未完待续) 第一次接触到 linux,不知道linux的确很强大,然后用virtualbox ...