微信模板消息开发总结——7.26

2023-11-05 20:10

本文主要是介绍微信模板消息开发总结——7.26,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求:A管理员在微信端提交用户加入群组,给B高级管理员审核。

           B管理员审核成功后,微信公众号会发送一个消息给A管理员,提示新增成功。

微信后台模板消息接口:

 

官方文档:

        请求需要三个参数——

        touser:用户的微信openId

        template_id:模板消息id

        topcolor:字体颜色

        data:替换模板消息内的具体数据

代码——

接口端:

            …………String openId = null;String userName = null;if (jsonObject.containsKey("flag") && jsonObject.getInteger("flag") == 1) {// 获得提交人的信息User user = mbUserService.searchOpenIdById(id);if (user == null) {logger.error("系统错误");} else {// 得到提交人的openid 用户名openId = user.getOpenId();userName = user.getUserName();}// 审核成功之后,发送模板消息Template tem = new Template();tem.setTemplateId("E1P3fwW5GGSFdGraAuOjcVy-6xRNC2c78LKslYoumxk");tem.setTopColor("#00DD00");tem.setToUser(openId);// 模板消息具体url,没找到tem.setUrl("");List<TemplateParam> paras = new ArrayList<TemplateParam>();paras.add(new TemplateParam("OperaUser", userName, "#0044BB"));paras.add(new TemplateParam("UserTel", phone, "#0044BB"));paras.add(new TemplateParam("Group", "出租车司机", "#0044BB"));paras.add(new TemplateParam("Status", "成功", "#0044BB"));tem.setTemplateParamList(paras);// 获取accessTokenString token = null;try {token = WeiXinUtil.getAccessToken().getToken();} catch (Exception e) {e.printStackTrace();}// 调用发送消息boolean result = sendTemplateMsg(token, tem);logger.info("模板消息发送结果:" + result);

工具类:

public class WeiXinUtil {@Value("${wx.appId}")private static String APPID;@Value("${wx.appsecret}")private static String APPSECRET;// 从微信后台拿到APPID和APPSECRET 并封装为常量// private static final String APPID = "wx93ee9c70c625f281";// private static final String APPSECRET = "93e787d23e2e1e5c45d1c7f5cdc6fe79";private static final String ACCESS_TOKEN_URL ="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET";/*** 编写Get请求的方法。但没有参数传递的时候,可以使用Get请求* * @param url 需要请求的URL* @return 将请求URL后返回的数据,转为JSON格式,并return*/public static JSONObject doGetStr(String url) throws ClientProtocolException, IOException {DefaultHttpClient client = new DefaultHttpClient();// 获取DefaultHttpClient请求HttpGet httpGet = new HttpGet(url);// HttpGet将使用Get方式发送请求URLJSONObject jsonObject = null;HttpResponse response = client.execute(httpGet);// 使用HttpResponse接收client执行httpGet的结果HttpEntity entity = response.getEntity();// 从response中获取结果,类型为HttpEntityif (entity != null) {String result = EntityUtils.toString(entity, "UTF-8");// HttpEntity转为字符串类型jsonObject = JSONObject.parseObject(result);// 字符串类型转为JSON类型}return jsonObject;}/*** 编写Post请求的方法。当我们需要参数传递的时候,可以使用Post请求* * @param url 需要请求的URL* @param outStr 需要传递的参数* @return 将请求URL后返回的数据,转为JSON格式,并return*/public static JSONObject doPostStr(String url, String outStr) throws ClientProtocolException, IOException {DefaultHttpClient client = new DefaultHttpClient();// 获取DefaultHttpClient请求HttpPost httpost = new HttpPost(url);// HttpPost将使用Get方式发送请求URLJSONObject jsonObject = null;httpost.setEntity(new StringEntity(outStr, "UTF-8"));// 使用setEntity方法,将我们传进来的参数放入请求中HttpResponse response = client.execute(httpost);// 使用HttpResponse接收client执行httpost的结果String result = EntityUtils.toString(response.getEntity(), "UTF-8");// HttpEntity转为字符串类型jsonObject = JSONObject.parseObject(result);// 字符串类型转为JSON类型return jsonObject;}/*** 获取AccessToken* * @return 返回拿到的access_token及有效期*/public static AccessToken getAccessToken() throws ClientProtocolException, IOException {AccessToken token = new AccessToken();String url = ACCESS_TOKEN_URL.replace("APPID", APPID).replace("APPSECRET", APPSECRET);// 将URL中的两个参数替换掉JSONObject jsonObject = doGetStr(url);// 使用刚刚写的doGet方法接收结果if (jsonObject != null) { // 如果返回不为空,将返回结果封装进AccessToken实体类token.setToken(jsonObject.getString("access_token"));// 取出access_tokentoken.setExpireIn(jsonObject.getInteger("expires_in"));// 取出access_token的有效期}return token;}
}

发送模板消息调用方法:

 // 发送模板消息public static boolean sendTemplateMsg(String token, Template template) {boolean flag = false;String requestUrl = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=ACCESS_TOKEN";requestUrl = requestUrl.replace("ACCESS_TOKEN", token);JSONObject jsonResult = CommonUtil.httpsRequest(requestUrl, "POST", template.toJSON());if (jsonResult != null) {int errorCode = jsonResult.getInteger("errcode");String errorMessage = jsonResult.getString("errmsg");if (errorCode == 0) {flag = true;} else {System.out.println("模板消息发送失败:" + errorCode + "," + errorMessage);flag = false;}}return flag;}

发送消息时需要的CommonUtil

public class CommonUtil {public static JSONObject httpsRequest(String requestUrl, String requestMethod, String outputStr) { JSONObject jsonObject = null;StringBuffer buffer = new StringBuffer();  try {  // 创建SSLContext对象,并使用我们指定的信任管理器初始化  TrustManager[] tm = { new MyX509TrustManager() };  SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");  sslContext.init(null, tm, new java.security.SecureRandom());  // 从上述SSLContext对象中得到SSLSocketFactory对象  SSLSocketFactory ssf = sslContext.getSocketFactory();  URL url = new URL(requestUrl);  HttpsURLConnection httpUrlConn = (HttpsURLConnection) url.openConnection();  httpUrlConn.setSSLSocketFactory(ssf);  httpUrlConn.setDoOutput(true);  httpUrlConn.setDoInput(true);  httpUrlConn.setUseCaches(false);  // 设置请求方式(GET/POST)  httpUrlConn.setRequestMethod(requestMethod);  if ("GET".equalsIgnoreCase(requestMethod)) {httpUrlConn.connect();  } // 当有数据需要提交时  if (null != outputStr) {  OutputStream outputStream = httpUrlConn.getOutputStream();  // 注意编码格式,防止中文乱码  outputStream.write(outputStr.getBytes("UTF-8"));  outputStream.close();  }  // 将返回的输入流转换成字符串  InputStream inputStream = httpUrlConn.getInputStream();  InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");  BufferedReader bufferedReader = new BufferedReader(inputStreamReader);  String str = null;  while ((str = bufferedReader.readLine()) != null) {  buffer.append(str);  }  bufferedReader.close();  inputStreamReader.close();  // 释放资源  inputStream.close();  inputStream = null;  httpUrlConn.disconnect();  jsonObject = JSONObject.parseObject(buffer.toString());  } catch (ConnectException ce) {  ce.printStackTrace();} catch (Exception e) {  e.printStackTrace();}  return jsonObject;  }public static String httpRequest(String requestUrl, String requestMethod, String outputStr) { StringBuffer buffer = new StringBuffer();  try {  URL url = new URL(requestUrl);  HttpURLConnection httpUrlConn = (HttpURLConnection) url.openConnection();  httpUrlConn.setDoOutput(true);  httpUrlConn.setDoInput(true);  httpUrlConn.setUseCaches(false);  // 设置请求方式(GET/POST)  httpUrlConn.setRequestMethod(requestMethod);  if ("GET".equalsIgnoreCase(requestMethod)) {httpUrlConn.connect();  } // 当有数据需要提交时  if (null != outputStr) {  OutputStream outputStream = httpUrlConn.getOutputStream();  // 注意编码格式,防止中文乱码  outputStream.write(outputStr.getBytes("UTF-8"));  outputStream.close();  }  // 将返回的输入流转换成字符串  InputStream inputStream = httpUrlConn.getInputStream();  InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");  BufferedReader bufferedReader = new BufferedReader(inputStreamReader);  String str = null;  while ((str = bufferedReader.readLine()) != null) {  buffer.append(str);  }  bufferedReader.close();  inputStreamReader.close();  // 释放资源  inputStream.close();  inputStream = null;  httpUrlConn.disconnect();  //jsonObject = JSONObject.fromObject(buffer.toString());  } catch (ConnectException ce) {  ce.printStackTrace();} catch (Exception e) {  e.printStackTrace();}  return buffer.toString();  }public static String urlEncodeUTF8(String source){String result = source;try {result = java.net.URLEncoder.encode(source,"utf-8");} catch (UnsupportedEncodingException e) {e.printStackTrace();}return result;}public static String httpsRequestForStr(String requestUrl, String requestMethod, String outputStr) { String result="";StringBuffer buffer = new StringBuffer();  try {// 创建SSLContext对象,并使用我们指定的信任管理器初始化  TrustManager[] tm = { new MyX509TrustManager() };  SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");  sslContext.init(null, tm, new java.security.SecureRandom());  // 从上述SSLContext对象中得到SSLSocketFactory对象  SSLSocketFactory ssf = sslContext.getSocketFactory();  URL url = new URL(requestUrl);  HttpsURLConnection httpUrlConn = (HttpsURLConnection) url.openConnection();  httpUrlConn.setSSLSocketFactory(ssf);  httpUrlConn.setDoOutput(true);  httpUrlConn.setDoInput(true);  httpUrlConn.setUseCaches(false);  // 设置请求方式(GET/POST)  httpUrlConn.setRequestMethod(requestMethod);  if ("GET".equalsIgnoreCase(requestMethod)) {httpUrlConn.connect();  } // 当有数据需要提交时  if (null != outputStr) {  OutputStream outputStream = httpUrlConn.getOutputStream();  // 注意编码格式,防止中文乱码  outputStream.write(outputStr.getBytes("UTF-8"));  outputStream.close();  }  // 将返回的输入流转换成字符串  InputStream inputStream = httpUrlConn.getInputStream();  InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");  BufferedReader bufferedReader = new BufferedReader(inputStreamReader);  String str = null;  while ((str = bufferedReader.readLine()) != null) {  buffer.append(str);  }  bufferedReader.close();  inputStreamReader.close();  // 释放资源  inputStream.close();  inputStream = null;  httpUrlConn.disconnect();  result=buffer.toString();  } catch (ConnectException ce) {  ce.printStackTrace();} catch (Exception e) {  e.printStackTrace();}  return result;  }
}

 


                                      

这篇关于微信模板消息开发总结——7.26的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/352197

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来