本文写的比较简单,只是一个简单的实现,如有错误,欢迎大家指出,本文为个人学习笔记,只供参考。

如果成功了给句评论,或来个赞呗!

本文大致分为三个内容:

一、注册小程序

二、微信小程序开发代码

三、java客户端代码

一、注册小程序

后台网站

https://mp.weixin.qq.com/

主要是需要以下几个信息:

1、模板id

网站截图


这里模板你自己添加一个,模板id记下来。

2、AppId、AppSecret


这里的appid、appsecret也要记录下来,有用。

二、微信小程序代码

有好多同学,代码都对,就是收不到,就是这个问题:
在创建程序时:

看见闪亮亮的大字了没?????appid,用你之前注册的!

主要通过代码获取以下几个信息

1、openid

openid是一个用户对应一个小程序唯一的id。
这么说吧,一个人有好几把钥匙,但能开家大门的就那么一把。
明白了吧。

.js中的代码


wx.login({// 获取codesuccess: function(res) {var code = res.codeconsole.log(code)wx.request({url: 'https://api.weixin.qq.com/sns/jscode2session?appid=wx8615f70ac078c2fa&secret=33de81cca94b3efa918e4e7094362dd9&js_code=' + code + '&grant_type=authorization_code',method: "GET",data: {},header: {'content-type': 'application/json'},success: function(res) {var openid = res.data.openid //返回openidconsole.log(openid)}})}})
2、formid

这个是你想发通知的必要信息。
微信小程序不允许程序给个人主动发消息,都是用户要求的,如果用户说:我不知道啊? 那就是在代码里嵌入了表单提交。
一次表单提交,产生一个formid,然后这个formid就没用了。
想下次发提醒,那你就再提交一个表单申请。

.wxml中的代码

 <form bindsubmit="form_submit" report-submit='true'><button form-type="submit" class='formid'><span>点我</span></button></form>

.js中的代码

 form_submit(e) {console.log(e.detail.formId)//formid
}

三、java中代码

/*** 微信常量* @Author: chu qiao* @CreateDate: 2018/8/17 18:11*/
public interface Wechat {/**小程序唯一标识*/String APPID = "这里填你的appid";//这里填你的appid/**小程序的 app secret*/String APPSECRET = "这里填你的appsecret";//这里填你的appsecret/**默认*/String GRANTTYPE = "authorization_code";/**根据code获取sessionKey和openId的url*/String WX_CODE2OPENID_URL = "https://api.weixin.qq.com/sns/jscode2session";/**获取access_token*/String ACCESS_TOKEN  = "https://api.weixin.qq.com/cgi-bin/token";/**获取二维码图片*/String WXACODEUNLIMIT  = "https://api.weixin.qq.com/wxa/getwxacodeunlimit";String SEND_TEMPLATE_MESSAGE = "https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=";}

实体类

/*** 发送模板消息* @Author: chu qiao* @CreateDate: 2018/9/30 16:21*/
public class sendTemplateMessage {private String touser; //接收者(用户)的 openidprivate String template_id; //所需下发的模板消息的idprivate String page; //点击模板卡片后的跳转页面,仅限本小程序内的页面。支持带参数,(示例index?foo=bar)。该字段不填则模板无跳转。private String form_id; //表单提交场景下,为 submit 事件带上的 formId;支付场景下,为本次支付的 prepay_idprivate Map<String,TemplateData> data; //模板内容,不填则下发空模板private String emphasis_keyword; //模板需要放大的关键词,不填则默认无放大public String getTouser() {return touser;}public void setTouser(String touser) {this.touser = touser;}public String getTemplate_id() {return template_id;}public void setTemplate_id(String template_id) {this.template_id = template_id;}public String getPage() {return page;}public void setPage(String page) {this.page = page;}public String getForm_id() {return form_id;}public void setForm_id(String form_id) {this.form_id = form_id;}public Map<String, TemplateData> getData() {return data;}public void setData(Map<String, TemplateData> data) {this.data = data;}public String getEmphasis_keyword() {return emphasis_keyword;}public void setEmphasis_keyword(String emphasis_keyword) {this.emphasis_keyword = emphasis_keyword;}
}

public class TemplateData {private String value;public String getValue() {return value;}public void setValue(String value) {this.value = value;}public TemplateData(String value) {this.value = value;}public TemplateData() {}}
public class Token {private Token() {}private  String token;private  String accessToken;private  long expiryTime;private static Token instance  = new Token();public static Token getInstance() {return instance;}public String getAccessToken() {return accessToken;}public void setAccessToken(String accessToken) {this.accessToken = accessToken;}public long getExpiryTime() {return expiryTime;}public void setExpiryTime(long expiryTime) {this.expiryTime = expiryTime;}public  String getToken() {return token;}public  void setToken(String token) {this.token = token;}
}
public class UrlUtils {private static final Logger log = LoggerFactory.getLogger(UrlUtils.class);/*** 向指定URL发送GET方法的请求* @param url   发送请求的URL* @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。* @return URL 所代表远程资源的响应结果*/public static String sendGet(String url, String param) {String result = "";BufferedReader in = null;try {String urlNameString = url + "?" + param;URL realUrl = new URL(urlNameString);// 打开和URL之间的连接URLConnection connection = realUrl.openConnection();// 设置通用的请求属性connection.setRequestProperty("accept", "*/*");connection.setRequestProperty("connection", "Keep-Alive");connection.setRequestProperty("user-agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");// 建立实际的连接connection.connect();// 获取所有响应头字段Map<String, List<String>> map = connection.getHeaderFields();// 遍历所有的响应头字段
//            for (String key : map.keySet()) {
//                System.out.println(key + "--->" + map.get(key));
//            }// 定义 BufferedReader输入流来读取URL的响应in = new BufferedReader(new InputStreamReader(connection.getInputStream()));String line;while ((line = in.readLine()) != null) {result += line;}} catch (Exception e) {log.error("发送GET请求出现异常!" + e);e.printStackTrace();}// 使用finally块来关闭输入流finally {try {if (in != null) {in.close();}} catch (Exception e2) {e2.printStackTrace();}}return result;}/*** 向指定 URL 发送POST方法的请求* @param url      发送请求的 URL* @param paramMap 请求参数* @return 所代表远程资源的响应结果*/public static String sendPost(String url, Map<String, ?> paramMap) {PrintWriter out = null;BufferedReader in = null;String result = "";String param = "";Iterator<String> it = paramMap.keySet().iterator();while (it.hasNext()) {String key = it.next();param += key + "=" + paramMap.get(key) + "&";}try {URL realUrl = new URL(url);// 打开和URL之间的连接URLConnection conn = realUrl.openConnection();// 设置通用的请求属性conn.setRequestProperty("accept", "*/*");conn.setRequestProperty("connection", "Keep-Alive");conn.setRequestProperty("Accept-Charset", "utf-8");conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");// 发送POST请求必须设置如下两行conn.setDoOutput(true);conn.setDoInput(true);// 获取URLConnection对象对应的输出流out = new PrintWriter(conn.getOutputStream());// 发送请求参数out.print(param);// flush输出流的缓冲out.flush();// 定义BufferedReader输入流来读取URL的响应in = new BufferedReader(new InputStreamReader(conn.getInputStream(), "UTF-8"));String line;while ((line = in.readLine()) != null) {result += line;}} catch (Exception e) {log.error(e.getMessage(), e);}//使用finally块来关闭输出流、输入流finally {try {if (out != null) {out.close();}if (in != null) {in.close();}} catch (IOException ex) {ex.printStackTrace();}}return result;}}
public class MyTest {/*** 发送模板消息sendTemplateMessage* 小程序模板消息,发送服务通知* @param touser 接收者(用户)的 openid* @param template_id 所需下发的模板消息的id* @param page 点击模板卡片后的跳转页面,仅限本小程序内的页面。支持带参数,(示例index?foo=bar)。该字段不填则模板无跳转。* @param formid 表单提交场景下,为 submit 事件带上的 formId;支付场景下,为本次支付的 prepay_id* @return*/public static JSONObject sendTemplateMessage(String touser, String template_id, String page, String formid, Map<String, TemplateData> map){String accessToken = getAccessToken();sendTemplateMessage sendTemplateMessage = new sendTemplateMessage();//拼接数据sendTemplateMessage.setTouser(touser);sendTemplateMessage.setTemplate_id(template_id);sendTemplateMessage.setPage(page);sendTemplateMessage.setForm_id(formid);sendTemplateMessage.setData(map);sendTemplateMessage.setEmphasis_keyword("");String json =  JSONObject.toJSONString(sendTemplateMessage);String ret = sendPost(Wechat.SEND_TEMPLATE_MESSAGE+accessToken, json);return JSON.parseObject(ret);}public static String getAccessToken(){String param = "grant_type=client_credential&appid="+Wechat.APPID+"&secret="+Wechat.APPSECRET;String result = UrlUtils.sendGet(Wechat.ACCESS_TOKEN,param);JSONObject demoJson = JSONObject.parseObject(result);String accessToken = demoJson.getString("access_token");String expiresIn = demoJson.getString("expires_in");Token token = Token.getInstance();token.setAccessToken(accessToken);//过期时间的毫秒数token.setExpiryTime(System.currentTimeMillis()+1000*60*100L);return accessToken;}/*** 发送post请求 json格式* @param url* @param param* @return*/public static String sendPost(String url, String param) {PrintWriter out = null;BufferedReader in = null;String result = "";try {URL realUrl = new URL(url);// 打开和URL之间的连接URLConnection conn = realUrl.openConnection();// 设置通用的请求属性conn.setRequestProperty("Accept", "application/json");conn.setRequestProperty("Content-Type", "application/json");// 发送POST请求必须设置如下两行conn.setDoOutput(true);conn.setDoInput(true);// 获取URLConnection对象对应的输出流out = new PrintWriter(conn.getOutputStream());// 发送请求参数out.print(param);// flush输出流的缓冲out.flush();// 定义BufferedReader输入流来读取URL的响应in = new BufferedReader(new InputStreamReader(conn.getInputStream()));String line;while ((line = in.readLine()) != null) {result += line;}} catch (Exception e) {System.out.println("发送 POST 请求出现异常!"+e);e.printStackTrace();}//使用finally块来关闭输出流、输入流finally{try{if(out!=null){out.close();}if(in!=null){in.close();}}catch(IOException ex){ex.printStackTrace();}}return result;}public static void main(String[] args) {Map<String,TemplateData> map = new HashMap<>();//map.put("keyword1",new TemplateData("123"));//map.put("keyword2",new TemplateData("321"));//map.put("keyword3",new TemplateData("aaa"));//map.put("keyword4",new TemplateData("bbb"));//不是创建模板了么,模板几个参数map.put你就放几个JSONObject js = sendTemplateMessage("放用户的openid", "放模板id", “”", "放formid",map);System.out.println(js);}
}

搞定!!!

本文也是参考其他人,大家都是为了学习~

微信小程序 java服务器发送通知给用户 全流程 (获取openid 获取formid)相关推荐

  1. 微信小程序-JAVA实现微信支付功能(微信支付2.0)

    微信小程序-JAVA实现微信支付功能(微信支付2.0) 一.前言 本博客主要介绍JAVA后台与微信小程序(UNI-APP或者原生微信小程序)的微信支付的实现,如果是APP或者H5的开发暂时不支持,具体 ...

  2. 微信读书登陆界面java_(JAVA后端)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好...

    转载地址:(JAVA后端)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好 转载请注明出处 一.环境搭建 相关环境软件:JDK1 ...

  3. 微信小程序配置服务器域名和业务域名

    微信小程序配置服务器域名和业务域名 背景 如何配置服务器域名 如何配置业务域名 背景 微信小程序本身的限制,并不能直接请求接口地址和在web-view中随意跳转H5页面,其需要配置服务器域名,才能在微 ...

  4. (微信小程序)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好

    转载地址:(微信小程序)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好 转载请注明出处 作者:Happy王子乐 个人网站(整理 ...

  5. 微信小程序 科学计算器(微信小程序+java+python)

    微信小程序之科学计算器 (微信小程序+java+python) 先把自己的小程序和页面贴出来 1.前后端实现步骤: 1.前端采用的就是微信小程序开发工具,后端采用的是以springboot为基础,调用 ...

  6. 驾校分期-众筹项目java前后端分离项目vue(微信小程序+java前后端源码下载)

    可以idea直接打开,mysql数据库项目,前后端分离项目vue,分期可自动设置,自动换算金额 驾校分期-众筹项目java前后端分离项目vue(微信小程序+java前后端源码下载)

  7. 亲手创建一台Ubuntu+PHP5+MySQL5+Nginx+openSSL+sshFtp(sftp)的微信小程序云服务器

    亲手创建一台Ubuntu+PHP5+MySQL5+Nginx+openSSL+sshFtp的微信小程序云服务器 小程序要求Request必须SSL连接,一般虚拟主机不支持SSL,自己有云服务器最佳. ...

  8. uniapp实现微信小程序全局【发送给朋友】、【分享到朋友圈】、【复制链接】

    在开发微信小程序的时候,发现[发送给朋友].[分享到朋友圈].[复制链接]功能,灰色不可用. 很常见的功能,但是这几个功能,并不是你项目建起来了就有的. 1.[发送给朋友]使用 onShareAppM ...

  9. 微信小程序java node python理发店美容店预约系统

    基于微信小程序美容预约管理系统 系统分为用户和管理员两个角色 用户微信小程序端的主要功能有: 1.用户注册和登陆微信小程序 2.用户查看美容的服务项目分类和服务详情 3.用户美容师推荐,查看美容师列表 ...

最新文章

  1. 世界坐标系到观察坐标系的变换步骤_《3D数学基础》提炼总结(九)矩阵和线性变换...
  2. 渗透中poc、exp、payload与shellcode的区别
  3. 设计模式研究(二)-Singleton
  4. (19) 转载: 寻找丑数
  5. hive读取hdfs存放文件_数据获取层之Flume快速入门(一) 实时监控单个追加文件
  6. 助老打车暖心车站落地杭州 帮助老年人扫码一键叫车
  7. 【报告分享】中国电信5G行业场景案例集.pdf(附下载链接)
  8. 安装mysql数据库及问题解决方法
  9. 用设计解决问题 ——访小米科技、小米路由器事业部总经理 唐沐
  10. python音乐推荐系统_音乐推荐系统
  11. 自动化/控制工程专业英语01——什么是控制[考研/保研面试]
  12. 《敏捷个人》周刊 第13期 (可下载)
  13. MSP430F5529 多路PWM输出控制舵机和电机
  14. cad剖切线的快捷键_CAD有哪些常用的快捷键?
  15. linux dropbox自动同步,Linux免dropbox客户端备份脚本
  16. matlab 图中图
  17. centos7 mysql libssl_centos7.2安装mysql5.7.13及ssl主从复制
  18. html之响应式(自适应)网页设计
  19. vue登录页面实现记住密码的操作
  20. linux sed替换文件,linux的sed命令替换文件

热门文章

  1. MapReduce的容错机制
  2. codeforces 1064 E. Dwarves, Hats and Extrasensory Abilities (交互题,二分)
  3. C语言:将数据保存到文本文件
  4. 7-1 判断两个数是否互质
  5. free software
  6. 谈谈用户留存率为何如此重要?
  7. QPainterPath
  8. 26岁学编程会不会已经晚了?
  9. 关于Python和自动化
  10. js 二进制、十进制、十六进制的互相转换