前端工程师如何快速的开发一个微信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元素上点击后就可以调用二维码扫描功能了。

图片如下:

wxx

利用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找到源码,自行进行编译。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 微信jssdk是一种用于在网页中调用微信功能的开发工具包。其中,获取位置是其中的一个功能之一。当在调用微信jssdk获取位置接口时,如果出现获取位置失败,签名错误的情况,可能是以下几个原因所导致: 1. 签名错误:在调用获取位置接口前,需要对相关参数进行签名验证,以确保数据的完整性和安全性。签名错误可能是由于签名算法实现错误、调用接口时传入的参数错误或者服务器时间戳与微信服务器时间戳不一致等原因所导致。解决方法是检查签名算法是否正确,参数是否正确传递,并确保服务器时间戳与微信服务器时间戳一致。 2. 接口权限问题:在申请微信jssdk使用权限时,需要在公众号设置中配置相关权限。如果没有正确配置接口权限,则无法调用获取位置接口,会出现获取位置失败的情况。解决方法是检查公众号设置中的权限配置,确保获取位置接口的权限被正确开启。 3. 用户拒绝授权:在用户使用网页时,系统会通过微信弹出授权窗口,询问用户是否允许获取位置信息。如果用户选择拒绝授权,则无法获取位置信息,从而导致获取位置失败的情况。解决方法是在用户拒绝授权后,提示用户重新授权,或者提供其他方式获取位置信息。 总之,当微信jssdk获取位置失败,签名错误时,需要仔细检查签名算法、参数传递和接口权限配置等方面的问题,并根据具体情况进行相应的调整和处理。 ### 回答2: 微信jssdk一个用于在网页中调用微信的接口的开发工具包。在使用jssdk时,通过wx.config方法来进行配置,并且在配置的过程中需要传入一个参数:签名(signature)。 签名是基于一定算法生成的,用于验证消息的真实性和完整性。当微信jssdk获取位置失败并且报错签名错误时,可能是由以下几个原因造成的: 1. 签名生成错误:签名的生成过程中可能出现错误,导致最终生成的签名不正确。这可能是由于服务端生成签名的算法或参数配置有误,需要检查签名生成代码并修正错误。 2. 参数传递错误:在传递签名参数时,可能存在传递错误的情况。签名参数包括appId、timestamp、nonceStr、signature,这些参数需要按照规定的格式传递给wx.config方法。需要仔细检查参数传递的过程,确保参数的准确性和完整性。 3. SSL证书问题:微信要求在调用jssdk时使用HTTPS协议,并且需要使用有效的SSL证书。如果网页没有配置有效的SSL证书,那么在获取位置时会报错签名错误。需要确保网页使用HTTPS协议,并且配置了有效的SSL证书。 解决以上问题的步骤为: 1. 检查签名生成代码,确认生成签名的算法和参数没有错误; 2. 检查参数传递过程,确保传递给wx.config方法的参数准确无误; 3. 确认网页使用了HTTPS协议,并配置了有效的SSL证书; 4. 在修改代码后,重新测试获取位置功能,如果问题仍然存在,可以参考微信官方文档或寻求微信开发者论坛的帮助。 ### 回答3: 微信 JSSDK 是一种用于开发微信公众号的前端开发工具包,它提供了丰富的接口和功能,方便开发者构建丰富的微信公众号应用。当使用 JSSDK 中的定位功能时,获取位置失败并出现签名错误的问题可能是由以下几个原因引起的。 1. 网络问题:在使用微信 JSSDK 时,要求设备能够连接到互联网,如果网络不稳定或者设备无法连接到互联网,就可能导致定位功能失败。请确保设备有稳定的网络连接。 2. 位置权限:微信 JSSDK 需要用户授权才能获取设备的位置信息。如果用户拒绝了位置权限请求,那么就无法获取到位置信息。在使用定位功能前,应该向用户请求位置权限,并在用户授权后才能使用。 3. 未配置有效的签名:微信 JSSDK 需要在后台进行配置并生成签名,用于验证请求的合法性。如果签名错误,就无法正确获取位置信息。在生成签名时,需要保证参数的正确性,包括参数的顺序、大小写等。请仔细检查签名生成的代码逻辑和参数配置是否正确。 4. 使用的 API 接口不支持:微信 JSSDK 提供了多个获取位置的接口,不同的接口可能有不同的要求和适用场景。如果使用的接口与当前场景不匹配或者不支持当前设备的操作系统版本,可能会导致获取位置失败。请确认使用的接口与当前场景的要求是匹配的。 综上所述,当微信 JSSDK 获取位置失败并出现签名错误时,可能是网络问题、位置权限、签名配置或使用的接口不正确导致的。在解决问题时,可以逐一排查以上原因,并根据具体情况进行相应的调试和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

熊哥club

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值