目录
5、根据本机下载对应的natapp客户端 ,下载之后解压至任意目录,得到natapp.exe (linux下无需解压,直接 wget)
8、打开IDEA,配置后台开启8080端口,运行wxapplication
9、修改weixin4j.properties文件,与微信公众号构建联系
前言:关于微信程序开发的网站
微信开发平台:微信公众平台
微信官方文档:微信官方文档 | 微信开放文档
微信公众平台接口调试工具:微信公众平台接口调试工具
内网穿透工具:几款免费内网穿透工具测评使用 - 哔哩哔哩
测试号:微信公众平台
natapp:NATAPP-内网穿透 基于ngrok的国内高速内网映射工具
一、公众号分类
订阅号: 个人
服务号 支付: 公司-工商营业执照,个体户-工商营业执照
企业号: 公司-工商营业执照
测试号: 拥有所有接口
二、微信公众号开发
1、先进入到测试号进行测试
扫码之后关注公众号即可
进去之后只有一个输入框
2、获取令牌access_token
access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用access_token。开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效。并且获取acces_token是有上限的,只能调用2000次。
使用微信公众平台接口调试工具:
其中access_token是从基础接口中获取过来的:
appid和appsecret
3、制作自定义菜单
注意:
①、自定义菜单最多包括3个一级菜单,每个一级菜单最多包含5个二级菜单。
②、一级菜单最多4个汉字,二级菜单最多8个汉字,多出来的部分将会以“...”代替。
③、创建自定义菜单后,菜单的刷新策略是,在用户进入公众号会话页或公众号profile页时,如果发现上一次拉取菜单的请求在5分钟以前,就会拉取一下菜单,如果菜单有更新,就会刷新客户端的菜单。测试时可以尝试取消关注公众账号后再次关注,则可以看到创建后的效果。
菜单代码:
{
"button": [
{
"name": "扫码",
"sub_button": [
{
"type": "scancode_waitmsg",
"name": "扫码带提示",
"key": "rselfmenu_0_0",
"sub_button": [ ]
},
{
"type": "scancode_push",
"name": "扫码推事件",
"key": "rselfmenu_0_1",
"sub_button": [ ]
}
]
}
]
}
效果:
4、接口配置信息
URL:ip需要与域名绑定,并且需要到公安/网上备案
所以此处不支持IP的,将它变成域名,我使用了内网穿透工具:NATAPP-内网穿透 基于ngrok的国内高速内网映射工具
现在进入到natapp官网进行注册
1、注册的时候必须要实名认证
2、选择免费注册隧道
3、免费购买:
注意此处的端口号一定要为本地端口,我的是为8080
4、注册隧道成功,复制authtoken:
5、根据本机下载对应的natapp客户端 ,下载之后解压至任意目录,得到natapp.exe (linux下无需解压,直接 wget)
6、配置config.ini文件
#将本文件放置于natapp同级目录 程序将读取 [default] 段
#在命令行参数模式如 natapp -authtoken=xxx 等相同参数将会覆盖掉此配置
#命令行参数 -config= 可以指定任意config.ini文件
[default]
authtoken=80c645978d2a81aa #对应一条隧道的authtoken
clienttoken= #对应客户端的clienttoken,将会忽略authtoken,若无请留空,
log=none #log 日志文件,可指定本地文件, none=不做记录,stdout=直接屏幕输出 ,默认为none
loglevel=ERROR #日志等级 DEBUG, INFO, WARNING, ERROR 默认为 DEBUG
http_proxy= #代理设置 如 http://10.123.10.10:3128 非代理上网用户请务必留空
7、用cmd窗口运行netapp.exe文件
运行Document得到:
8、打开IDEA,配置后台开启8080端口,运行wxapplication
server: port: 8080 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/wx?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false username: root password: root123 redis: database: 0 # Redis数据库索引(默认为0 redis有16个库) host: 127.0.0.1 # Redis服务器地址 port: 6379 # Redis服务器连接端口 #password: 123456 # Redis服务器连接密码(默认为空) jedis: pool: max-active: 100 # 连接池最大连接数(使用负值表示没有限制) max-idle: 10 # 连接池中的最大空闲连接 min-idle: 0 # 连接池中的最小空闲连接 max-wait: -1 # 连接池最大阻塞等待时间(使用负值表示没有限制) timeout: 5000 # 连接超时时间(毫秒),不能设置为0,时间太短连接不上会报错 freemarker: allow-request-override: false request-context-attribute: req suffix: .ftl content-type: text/html;charset=UTF-8 enabled: true cache: false template-loader-path: classpath:/templates/ charset: UTF-8 application: name: wx
注意:这里用到redis是因为token令牌是有期限的,存到数据库不太方便,所以存储到redis
运行:
9、修改weixin4j.properties文件,与微信公众号构建联系
接口信息配置信息固定:
10、后台创建菜单
创建菜单:
package com.yk.wx.controller;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.weixin4j.Configuration;
import org.weixin4j.Weixin;
import org.weixin4j.component.MenuComponent;
import org.weixin4j.model.base.Token;
import org.weixin4j.model.menu.Menu;
import org.weixin4j.model.menu.SingleButton;
import org.weixin4j.model.menu.ViewButton;
import org.weixin4j.spring.WeixinTemplate;
import javax.servlet.http.HttpServletRequest;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@Controller
@RequestMapping("/wx")
@Slf4j
@SuppressWarnings("all")
public class WeixinController {
private WeixinTemplate weixinTemplate;
@Autowired
public WeixinController(WeixinTemplate weixinTemplate) {
this.weixinTemplate = weixinTemplate;
}
public static void main(String[] args) throws Exception {
Weixin weixin = new Weixin();
weixin.base().token();
Token token = weixin.getToken();
System.out.println(token);
}
@RequestMapping("/createMenu")
@ResponseBody
public Map<String, Object> createMenu(Model model, HttpServletRequest request) {
log.info("WeixinController.createMenu");
String ctx = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath();
log.info("ctx=" + ctx);
Map<String, Object> jsonData = new HashMap<String, Object>();
jsonData.put("code", 0);
jsonData.put("message", "微信菜单创建成功,ts=" + System.currentTimeMillis());
try {
Menu menu = new Menu();
//创建菜单按钮
List<SingleButton> buttons = new ArrayList<SingleButton>();
menu.setButton(buttons);
SingleButton btn1 = new ViewButton("主界面", ctx + "/toMain");
buttons.add(btn1);
SingleButton btn2 = new ViewButton("更多", ctx + "/toHello");
buttons.add(btn2);
SingleButton btn3 = new ViewButton("还想要", ctx + "/toHello");
buttons.add(btn3);
//设置子菜单
System.out.println(menu.toJSONObject().toString());
//创建自定义菜单
Weixin weixin = weixinTemplate.getWeixinFactory().getWeixin();
MenuComponent menu1 = weixin.menu();
menu1.create(menu);
model.addAttribute("message", "微信菜单创建成功");
} catch (Exception e) {
log.error(e.getMessage());
jsonData.put("code", -1);
jsonData.put("message", "微信菜单创建失败,原因:" + e.getMessage());
}
return jsonData;
}
@RequestMapping("/test1")
@ResponseBody
public Map<String, Object> test1() {
log.info("WeixinController.test1");
Map<String, Object> jsonData = new HashMap<String, Object>();
System.out.println("test");
String s1 = Configuration.getProperty("weixin4j.message.handler.normal");
String s2 = Configuration.getProperty("weixin4j.message.handler.event");
jsonData.put("weixin4j.message.handler.normal", s1);
jsonData.put("weixin4j.message.handler.event", s2);
return jsonData;
}
}
开始访问:
创建成功:
redis出现数据,证明菜单创建成功
今天的知识就分享到这了,希望能够帮助到你!