java对接微信公众号,根据模板发送消息

一.首先你得创建一个公众号,完成公众号的基本配置

在这里插入图片描述
1、服务器地址(URL):必须以http://或https://开头,分别支持80端口和443端口。这个URL是很重要的,需要响应微信发送的token验证

2、令牌(Token):必须为英文或数字,长度为3-32字符。上面说过做验证的

3、消息加解密密钥:可以直接随机生成

4、消息加解密方式:明文、兼容、安全 看业务需求选择:我觉得明文省事点(个人见解)

5、详解微信开发文档:https://developers.weixin.qq.com/doc/offiaccount/Getting_Started/Overview.html

二.微信参数说明

在这里插入图片描述

三.获取公众号对应微信用户的openId

在这里插入图片描述

四.template_id:模板Id

在这里插入图片描述

五.进行开发

1.首先准备好所需的实体类与需要传输的参数

ConstantUtil:存放公众号开发者app_id,公众号开发者密码app_secret,模板messageTemplate,获取token的url.

public class ConstantUtil {
    // 公众号开发者APPID 
    public final static String app_id = "";
    //openid
    public final static String open_id = "";
    // 公众号开发者密码 
    public final static String app_secret = "";
   //获取token的url
    public final static String sendtemplateUrl = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=ACCESS_TOKEN";
  //消息模版信息
    public final static String messageTemplate = "";
}

Token

public class Token {
    // 接口访问凭证
    private String accessToken;
    // 凭证有效期,单位:秒
    private int expiresIn;

    public String getAccessToken() {
        return accessToken;
    }

    public void setAccessToken(String accessToken) {
        this.accessToken = accessToken;
    }

    public int getExpiresIn() {
        return expiresIn;
    }

    public void setExpiresIn(int expiresIn) {
        this.expiresIn = expiresIn;
    }
}

TemplateData

public class TemplateData {
    private String value;
    private String color;
    public TemplateData(String value, String color){
        this.value = value;
        this.color = color;
    }
    /**
     * @return the value
     */
    public String getValue() {
        return value;
    }
    /**
     * @param value the value to set
     */
    public void setValue(String value) {
        this.value = value;
    }
    /**
     * @return the color
     */
    public String getColor() {
        return color;
    }
    /**
     * @param color the color to set
     */
    public void setColor(String color) {
        this.color = color;
    }
}

2.开发

填充发送数据

Map<String, TemplateData> param = new HashMap<>();
param.put("first",new TemplateData("您有一条班次信息需要处理,请及时查阅!","#696969"));
param.put("keyword1",new TemplateData("班级创建审核","#696969"));
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
String dateString = formatter.format(new Date());
 param.put("keyword2",new TemplateData(dateString,"#696969"));
param.put("remark",new TemplateData("如果您已经处理,请忽略此消息","#696969"));
List<String> openIdList = new ArrayList<String>();
String openId = ConstantUtil.open_id;
openIdList.add(openId);
jwBjSendWxinfoService.senTempMsg(openIdList,ConstantUtil.messageTemplate,param);

senTempMsg

/**
     * 发送微信
     * @param openIdList
     * @param templatId
     * @param param
     * @return
     */
    public  String senTempMsg(List<String> openIdList, String templatId, Map<String, TemplateData> param){

        String strRet = "0";
        if(null != openIdList && openIdList.size() >0 ){
            String access_token = CommonUtil.getToken(ConstantUtil.app_id, ConstantUtil.app_secret).getAccessToken();
            for(int i = 0;i< openIdList.size();i++){
                String openId = openIdList.get(i);

                // 绑定了微信并且关注了服务号的用户 , 注册成功-推送注册短信
                    JSON.toJSONString(param);
                    com.alibaba.fastjson.JSONObject jsonObject = com.alibaba.fastjson.JSONObject.parseObject(JSON.toJSONString(param));
                    //调用发送微信消息给用户的接口 利用现有模版  WX_TemplateMsgUtil.sendWechatMsgToUser(access_token,openId,templatId, "", "#000000", jsonObject);
                    WX_TemplateMsgUtil.sendWechatMsgToUser(access_token,openId,templatId, "", "#000000", jsonObject);

            }
        }else{
            strRet = "1";
        }
        return strRet;

    }

CommonUtil:获取token
注意:获取token需要在公众号设置白名单,不然请求会失败
在这里插入图片描述

public class CommonUtil {
    private static Logger log = LoggerFactory.getLogger(CommonUtil.class);



    /**
     * 发送https请求
     *
     * @param requestUrl 请求地址
     * @param requestMethod 请求方式(GET、POST)
     * @param outputStr 提交的数据
     * @return JSONObject(通过JSONObject.get(key)的方式获取json对象的属性值)
     */
    public static JSONObject httpsRequest(String requestUrl, String requestMethod, String outputStr) {
        JSONObject jsonObject = null;
        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 conn = (HttpsURLConnection) url.openConnection();
            conn.setSSLSocketFactory(ssf);

            conn.setDoOutput(true);
            conn.setDoInput(true);
            conn.setUseCaches(false);
            // 设置请求方式(GET/POST)
            conn.setRequestMethod(requestMethod);

            // 当outputStr不为null时向输出流写数据
            if (null != outputStr) {
                OutputStream outputStream = conn.getOutputStream();
                // 注意编码格式
                outputStream.write(outputStr.getBytes("UTF-8"));
                outputStream.close();
            }

            // 从输入流读取返回内容
            InputStream inputStream = conn.getInputStream();
            InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");
            BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
            String str = null;
            StringBuffer buffer = new StringBuffer();
            while ((str = bufferedReader.readLine()) != null) {
                buffer.append(str);
            }

            // 释放资源
            bufferedReader.close();
            inputStreamReader.close();
            inputStream.close();
            inputStream = null;
            conn.disconnect();
            jsonObject = JSONObject.fromObject(buffer.toString());
        } catch (ConnectException ce) {
            log.error("连接超时:{}", ce);
        } catch (Exception e) {
            log.error("https请求异常:{}", e);
        }
        return jsonObject;
    }

    /**
     * 获取接口访问凭证
     * 
     * @param appid 凭证
     * @param appsecret 密钥
     * @return
     */
    public static Token getToken(String appid, String appsecret) {
        Token token = null;
        String requestUrl = ConstantUtil.token_url.replace("APPID", appid).replace("APPSECRET", appsecret);
        // 发起GET请求获取凭证
        JSONObject jsonObject = httpsRequest(requestUrl, "GET", null);

        if (null != jsonObject) {
            try {
                token = new Token();
                token.setAccessToken(jsonObject.getString("access_token"));
                token.setExpiresIn(jsonObject.getInt("expires_in"));
            } catch (JSONException e) {
                token = null;
                // 获取token失败
                log.error("获取token失败 errcode:{} errmsg:{}", jsonObject.getInt("errcode"), jsonObject.getString("errmsg"));
            }
        }
        return token;
    }

    /**
     * URL编码(utf-8)
     *
     * @param source
     * @return
     */
    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;
    }

}

WX_TemplateMsgUtil:发送消息

public class WX_TemplateMsgUtil {
    private static Logger log = LoggerFactory.getLogger(WX_TemplateMsgUtil.class);

   
    /**
     * 发送微信消息(模板消息)
     * @param touser 用户 OpenID
     * @param templatId 模板消息ID
     * @param clickurl URL置空,则在发送后,点击模板消息会进入一个空白页面(ios),或无法点击(android)。
     * @param topcolor 标题颜色
     * @param data 详细内容
     * @return 返回成功success 
     */
    public static String sendWechatMsgToUser(String access_token,String touser, String templatId, String clickurl, String topcolor, JSONObject data) {
        String tmpurl = ConstantUtil.sendtemplateUrl.replace("ACCESS_TOKEN",access_token);
        JSONObject json = new JSONObject();
        json.put("touser", touser);
        json.put("template_id", templatId);
        json.put("url", clickurl);
        json.put("topcolor", topcolor);
        json.put("data", data);
        try{
            JSONObject result = WX_HttpsUtil.httpsRequest(tmpurl, "POST", json.toString());
            JSONObject resultJson = new JSONObject(result);
            log.info("发送微信消息返回信息:" + resultJson.get("errcode"));
            String errmsg = (String) resultJson.get("errmsg");
            if(!"ok".equals(errmsg)){  //如果为errmsg为ok,则代表发送成功,公众号推送信息给用户了。
                return "error";
            }
         }catch(Exception e){
            e.printStackTrace();
            return "error";
        }finally {
            if(templatId!=null) {
                //删除新增的 微信模板
               // deleteWXTemplateMsgById(templatId);
            }
        }
        return "success";
   }

}
<think>好的,用户想了解Java如何对接微信公众号发送告警消息。首先,我需要回忆一下微信公众号开发的基本流程。记得需要先注册公众号,并且得到appID和appSecret,这两个是认证的关键。然后,可能需要配置服务器,因为微信消息交互需要验证服务器有效性。 接下来,用户提到的是发送告警消息,应该属于模板消息的范畴。模板消息需要事先申请,并且每个模板有一个ID。发送消息的时候需要access_token,所以得先获取这个token,可能需要用appID和appSecret去微信的接口获取,而且要注意token的有效期,可能需要缓存起来避免频繁请求。 然后,具体的步骤大概包括:配置微信公众号后台的服务器URL,处理微信的验证请求,验证通过后才能接收和发送消息发送模板消息的话,构造一个POST请求,携带模板ID、用户openid、数据内容等,使用获取到的access_token作为参数。 可能会遇到的问题是access_token的管理,比如过期时间处理,以及消息格式是否正确。还有,用户可能没有配置好IP白名单,导致无法调用接口,这也是需要注意的地方。另外,模板消息的内容要符合微信的规范,比如不能有诱导性词汇,否则会被拒绝发送。 用户可能是一个开发者,需要将系统告警通过微信通知,所以需要可靠的发送机制,可能需要考虑重试机制,或者异步发送,避免阻塞主流程。同时,用户的openid如何获取也是一个问题,可能需要用户关注公众号后,通过某些方式绑定用户,才能获取到对应的openid。 总结下来,步骤大概是:注册公众号,配置服务器,获取access_token,发送模板消息。需要注意token管理、消息格式、以及错误处理。可能还需要在代码中使用HTTP客户端,比如使用Spring的RestTemplate或者Apache HttpClient来发送请求,处理JSON数据。</think>以下是Java对接微信公众号发送告警消息的完整步骤(基于模板消息接口): --- **一、准备工作** 1. 注册微信公众平台(服务号) 2. 在公众号后台获取: - AppID - AppSecret 3. 配置IP白名单(服务器出口IP) 4. 申请消息模板(在「功能」→「模板消息」中申请告警类模板) --- **二、核心实现步骤** **1. 获取Access Token** ```java public String getAccessToken() { String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential" + "&appid=" + APP_ID + "&secret=" + APP_SECRET; // 建议使用带连接池的HTTP客户端(如OkHttp) String result = HttpUtil.get(url); JSONObject json = JSON.parseObject(result); return json.getString("access_token"); // 有效期7200秒,需缓存 } ``` **2. 发送模板消息** ```java public void sendWarningMessage(String openid) { String url = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken; JSONObject data = new JSONObject(); // 模板内容配置 JSONObject body = new JSONObject(); body.put("touser", openid); body.put("template_id", "您的模板ID"); body.put("url", "https://yourdomain.com/alarm-detail"); // 可选跳转链接 // 告警内容参数(根据模板配置) JSONObject content = new JSONObject(); content.put("alarmType", buildTemplateItem("CPU过载")); content.put("alarmTime", buildTemplateItem(new SimpleDateFormat("yyyy-MM-dd HH:mm").format(new Date()))); content.put("serverIP", buildTemplateItem("192.168.1.100")); body.put("data", content); // 发送POST请求 String result = HttpUtil.post(url, body.toJSONString()); // 处理返回结果(建议检查errcode) } ``` **模板项构建方法** ```java private JSONObject buildTemplateItem(String value) { JSONObject item = new JSONObject(); item.put("value", value); item.put("color", "#FF0000"); // 告警消息建议红色 return item; } ``` --- **三、注意事项** 1. **Token管理**:必须缓存access_token,每日获取次数有限制(2000次/天) 2. **失败重试**:当收到`42001`(token过期)错误时,需要刷新token后重发 3. **消息频率**:同一用户30秒内只能收到1条模板消息 4. **内容规范**:不得包含敏感信息,符合微信内容政策 5. **用户订阅**:需用户关注公众号且48小时内有过交互(或主动授权) --- **四、调试建议** 1. 使用微信公众平台接口调试工具验证 2. 先通过`/cgi-bin/user/get`接口获取测试用openid 3. 使用Postman测试接口调用 4. 关注微信返回的errcode(完整错误码参考官方文档) 完整示例代码可在GitHub获取:[https://github.com/wechat-api-demo/java-warning](示例仓库)(请替换为实际地址)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值