要在Java项目中向微信公众号推送模板消息,首先需要确保我们已经有了微信公众号,并且已经设置了模板消息权限和模板ID。微信公众号模板消息是一种向用户发送通知的服务,广泛用于订单状态更新、服务提醒等场景。
下面,我们将详细介绍如何使用Java结合微信官方提供的API来实现模板消息的推送。这通常涉及几个步骤:获取access_token、组装模板消息数据、发送请求。
微信公众号配置:确保我们的公众号已经开通模板消息功能,并创建了相应的模板。
引入依赖:我们可能需要使用HTTP客户端库,如Apache HttpClient或OkHttp。这里我们使用Apache HttpClient。
在我们的pom.xml
中添加依赖(如果使用Maven):
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.13</version>
</dependency>
微信公众号API的调用大多需要Access Token,这是一个临时票据,用于调用接口的身份验证。
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
public class WeChatUtil {
private static final String APP_ID = "我们的AppID";
private static final String APP_SECRET = "我们的AppSecret";
private static final String TOKEN_URL = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={}&secret={}";
public static String getAccessToken() throws Exception {
String url = TOKEN_URL.replace("{}", APP_ID).replace("{}", APP_SECRET);
HttpGet request = new HttpGet(url);
CloseableHttpClient httpClient = HttpClients.createDefault();
String result = httpClient.execute(request, httpResponse ->
EntityUtils.toString(httpResponse.getEntity()));
// 解析JSON获取access_token,这里假设已经通过某种方式(如Jackson, Gson)解析
// 这里简单用String.split()模拟解析
String[] parts = result.split(",");
for (String part : parts) {
if (part.contains("access_token")) {
String[] tokenParts = part.split(":");
return tokenParts[1].trim().replace("\"", "");
}
}
return null;
}
}
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.message.BasicHeader;
import org.apache.http.util.EntityUtils;
public class TemplateMessageSender {
public static void sendTemplateMessage(String accessToken, String toUserOpenId, String templateId, String url, Map<String, TemplateData> data) throws Exception {
String json = "{\"touser\":\"" + toUserOpenId + "\",\"template_id\":\"" + templateId + "\",\"url\":\"" + url + "\",\"data\":{";
for (Map.Entry<String, TemplateData> entry : data.entrySet()) {
json += "\"" + entry.getKey() + "\":{\"value\":\"" + entry.getValue().getValue() + "\",\"color\":\"" + entry.getValue().getColor() + "\"},";
}
if (!json.endsWith(",")) {
json = json.substring(0, json.length() - 1);
}
json += "}}";
String messageUrl = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken;
HttpPost request = new HttpPost(messageUrl);
request.setHeader(new BasicHeader("Content-Type", "application/json; charset=UTF-8"));
request.setEntity(new StringEntity(json, "UTF-8"));
CloseableHttpClient httpClient = HttpClients.createDefault();
String result = httpClient.execute(request, httpResponse ->
EntityUtils.toString(httpResponse.getEntity()));
System.out.println("发送结果: " + result);
}
static class TemplateData {
private String value;
private String color;
// 构造器、getter和setter省略
}
}
在完成了WeChatUtil
类用于获取access_token
和TemplateMessageSender
类用于发送模板消息后,我们需要在我们的应用逻辑中调用这些方法。以下是一个示例,展示如何整合这些步骤来发送模板消息。
首先,确保我们有一个包含模板消息数据的Map
,其中键是模板中定义的字段名,值是TemplateData
对象(包含具体的值和可选的颜色)。
import java.util.HashMap;
import java.util.Map;
public class WeChatTemplateMessageExample {
public static void main(String[] args) {
try {
// 获取access_token
String accessToken = WeChatUtil.getAccessToken();
if (accessToken == null) {
System.out.println("获取access_token失败");
return;
}
// 准备模板消息数据
Map<String, TemplateMessageSender.TemplateData> data = new HashMap<>();
data.put("first", new TemplateMessageSender.TemplateData("这是第一条消息", "#173177"));
data.put("keyword1", new TemplateMessageSender.TemplateData("这是关键词1的内容", "#173177"));
data.put("keyword2", new TemplateMessageSender.TemplateData("这是关键词2的内容", "#173177"));
data.put("remark", new TemplateMessageSender.TemplateData("这是备注信息", "#173177"));
// 发送模板消息
String toUserOpenId = "用户的OpenID";
String templateId = "我们的模板ID";
String url = "点击后跳转的链接";
TemplateMessageSender.sendTemplateMessage(accessToken, toUserOpenId, templateId, url, data);
System.out.println("模板消息发送成功");
} catch (Exception e) {
e.printStackTrace();
System.out.println("发送模板消息失败:" + e.getMessage());
}
}
}
APP_ID
和APP_SECRET
硬编码在代码中,可以通过配置文件或环境变量等方式来管理。通过上述步骤,我们应该能够在Java项目中成功地向微信公众号发送模板消息。
本文被 Java编程 专题收录