如何进行微信公众号开发的本地调试的方法


Posted in Javascript onJune 16, 2019

微信团队为广大的开发者提供了一个测试账号。该帐号无需公众账号,快速申请接口测试,直接体验和测试公众平台所有高级接口。这么好用的功能,只需要要你有一个手机,手机上安装了一个微信即可。

地址:https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login

如何进行微信公众号开发的本地调试的方法

登录后,会得到一个微信号,和测试好的相关信息。appID,appsecret。

如何进行微信公众号开发的本地调试的方法

接口配置信息,js接口安全域名配置按照生产环境的配置即可。

下面重点开始了。已经有了一个可供测试的公众号,如何进行测试呢,最直接的办法是,在本地开发环境把已经运行的生产环境的公众号配置成刚申请的这个开发账号即可,但显然这个方法蠢哭了。

我们采用的方法是,在配置文件上增加一个参数的方式。比如我们生产环境的微信配置信息都写在wechat-config.xml中,这个时候,增加另一个配置文件wechat-config-yimiyan.xml。启动jvm时增加参数

-Dwechat-config=yimiyan。程序中中需要稍加修改。

例如原本系统启动时读取wechat-config.xml文件

WeChatUtils.class.getResourceAsStream("/wechat-config.xml");

现在修改为:

String wechatConfig = System.getProperty("wechat-config");
//得到的是刚刚我们添加的参数-Dwechat-config的值,即yimiyan

将原本的读取配置文件修改为:

WeChatUtils.class.getResourceAsStream("/wechat-config-"+wechatConfig+".xml");

这样,每个开发的小伙伴都可以在自己的环境上进行测试了。

准备就绪之后,开始下一步的操作--配置菜单。

用手机扫描页面上的二维码后,关注了这个测试公众号,是没有菜单的,这个时候要配置菜单怎么办呢。

有两种方式,使用postman工具或者使用微信提供的调试接口。

笔者比较懒,直接用了微信的接口调试工具设置的。地址:https://mp.weixin.qq.com/debug

如何进行微信公众号开发的本地调试的方法

第一步,获取access_tocken

输入测试公众号页面的appID和appsecret,点击检查问题

如何进行微信公众号开发的本地调试的方法

获取到access_token之后,使用这个access_token跟测试公众号设置菜单。接口类型选择自定义菜单,填入刚刚获取到的access_token,以及菜单的json串。

如何进行微信公众号开发的本地调试的方法

点击检查问题后,如果设置成功,结果如下

如何进行微信公众号开发的本地调试的方法

这个时候,在用微信扫一扫测试公众号的二维码,应该就会有菜单了,但是笔者在测试的时候发现,不知道是延迟还是缓存,第一次设置还好,多设置几次,要取关,清楚手机历史等操作,才会发现新菜单生效了。

到目前为止,我们一切的准备工作就基本完成了。在测试公众号里面,点击菜单,享受着成功的喜悦的时候,满心欢喜的点击,蹦出来的是redirect_uri:参数错误

如何进行微信公众号开发的本地调试的方法

这是什么鬼

最后一步的配置:

在测试微信公众号那个页面,那个页面很长,往下拉,找到网页服务--》网页账号--》网页授权获取用户基本信息,点击修改,配上外网能访问你测试环境的ip或者域名即可。

如何进行微信公众号开发的本地调试的方法

整个配置最重要的一点就是,你需要拥有一个能通过外网访问你的测试环境的域名或者ip。

NB:这里需要注意一点,如果这个地址填写的不正确,将会报错如下。此处只需填写域名即可,授权微信访问这个域名,具体要访问哪个项目哪个方法,在程序中控制。

如何进行微信公众号开发的本地调试的方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
json 定义
Jun 10 Javascript
基于jquery编写的横向自适应幻灯片切换特效的实例代码
Aug 06 Javascript
Jquery显示、隐藏元素以及添加删除样式
Aug 09 Javascript
判断日期是否能跨月查询的js代码
Jul 25 Javascript
jQuery实现分章节锚点“回到顶部”动画特效代码
Oct 23 Javascript
jQuery实现div随意拖动的实例代码(通用代码)
Jan 28 Javascript
基于jquery实现简单的分页控件
Mar 17 Javascript
教你一步步用jQyery实现轮播器
Dec 18 Javascript
JavaScript三种绑定事件方式及相互之间的区别分析
Jan 10 Javascript
利用node.js搭建简单web服务器的方法教程
Feb 20 Javascript
浅谈vue-router2路由参数注意的问题
Nov 08 Javascript
使用vue引入maptalks地图及聚合效果的实现
Aug 10 Javascript
详解vue微信网页授权最终解决方案
Jun 16 #Javascript
浅谈一种让小程序支持JSX语法的新思路
Jun 16 #Javascript
JavaScript 处理树数据结构的方法示例
Jun 16 #Javascript
JavaScript中的ES6 Proxy的具体使用
Jun 16 #Javascript
简谈创建React Component的几种方式
Jun 15 #Javascript
JS中的一些常用的函数式编程术语
Jun 15 #Javascript
JavaScript模块管理的简单实现方式详解
Jun 15 #Javascript
You might like
php实现的操作excel类详解
2016/01/15 PHP
PHP 实现浏览记录并按日期分组
2017/05/11 PHP
Javascript 代码也可以变得优美的实现方法
2009/06/22 Javascript
Ubuntu 11.10 安装Node.js的方法
2011/11/30 Javascript
Jquery中find与each方法用法实例
2015/02/04 Javascript
this,this,再次讨论javascript中的this,超全面(经典)
2016/01/05 Javascript
jquery事件绑定解绑机制源码解析
2016/09/19 Javascript
使用JavaScript获取URL中的参数(两种方法)
2016/11/16 Javascript
手机软键盘弹出时影响布局的解决方法
2016/12/15 Javascript
原生JavaScript实现Ajax异步请求
2017/11/19 Javascript
对angularJs中2种自定义服务的实例讲解
2018/09/30 Javascript
JS实现带阴历的日历功能详解
2019/01/24 Javascript
vue实现父子组件之间的通信以及兄弟组件的通信功能示例
2019/01/29 Javascript
vue使用Font Awesome的方法步骤
2019/02/26 Javascript
通过JS深度判断两个对象字段相同
2019/06/14 Javascript
基于Vue的商品主图放大镜方案详解
2019/09/19 Javascript
Vue 解决父组件跳转子路由后当前导航active样式消失问题
2020/07/21 Javascript
vuex刷新后数据丢失的解决方法
2020/10/18 Javascript
[01:10:57]Liquid vs OG 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python中的ConfigParser模块使用详解
2015/05/04 Python
Python解析树及树的遍历
2016/02/03 Python
浅谈python函数之作用域(python3.5)
2017/10/27 Python
利用Python yagmail三行代码实现发送邮件
2018/05/11 Python
Python3.6.x中内置函数总结及讲解
2019/02/22 Python
HTML5实现经典坦克大战坦克乱走还能发出一个子弹
2013/09/02 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
2020/05/14 HTML / CSS
澳大利亚最超值的自行车之家:Reid Cycles
2019/03/24 全球购物
英国豪华家具和经典家居饰品购物网站:OKA
2020/06/05 全球购物
机械专业毕业生自荐信
2013/11/02 职场文书
小学教师岗位职责
2013/11/25 职场文书
《小猪家的桃花树》教学反思
2014/04/11 职场文书
竞争与合作演讲稿
2014/05/12 职场文书
大学生自我推荐信范文
2015/03/24 职场文书
2015年员工工作总结范文
2015/04/08 职场文书
停水通知
2015/04/16 职场文书
php实现自动生成验证码的实例讲解
2021/11/17 PHP