微信企业号(三)-发送消息给企业号指定成员
2015-11-08 21:56
537 查看
1、通过代码控制微信企业号向指定成员发送消息。
发送消息的URL:https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=ACCESS_TOKEN
2、发送消息代码
3、工具类
4、实现X509TrustManager
5、运行main方法就可以向指定成员发送消息了。
发送消息的URL:https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=ACCESS_TOKEN
2、发送消息代码
package com.py.weixin.msg; import com.py.weixin.util.ComUtil; import com.py.weixin.util.ParamesAPI; import net.sf.json.JSONObject; public class TestSendMes { // 发送消息 public static String SEND_MSG_URL = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=ACCESS_TOKEN"; public static void main(String[] args) { //应用ID,账号,部门为"",标签为"",消息类型,内容 //部门不为"",标签不为"",将会给该部门的每个成员发送消息 Send_msg("1","username","","","text","hello"); } /** * @Description : 主动发送文字给企业用户 */ public static int Send_msg(String agentid,String touser,String toparty,String totag,String msgtype,String content){ int errCode=0; //拼接请求地址 String requestUrl=SEND_MSG_URL.replace("ACCESS_TOKEN", ComUtil.getAccessToken(ParamesAPI.corpId, ParamesAPI.corpsecret)); //需要提交的数据 String postJson = "{\"agentid\":\"%s\",\"touser\":\"%s\",\"toparty\":\"[1, %s]\",\"totag\":\"%s\",\"msgtype\":\"text\",\"%s\":{\"content\":\"%s\"},\"safe\":\"0\"}"; String outputStr=String.format(postJson,agentid,touser,toparty,totag,msgtype, content); System.out.println(outputStr); //创建成员 JSONObject jsonObject=ComUtil.httpsRequest(requestUrl, "POST", outputStr); if(null!=jsonObject){ System.out.println(jsonObject.toString()+"====="); // int errcode = jsonObject.getInt("errcode"); // errCode=jsonObject.getInt("errcode"); } return errCode; } }
3、工具类
package com.py.weixin.util; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.net.ConnectException; import java.net.URL; import javax.net.ssl.HttpsURLConnection; import javax.net.ssl.SSLContext; import javax.net.ssl.SSLSocketFactory; import javax.net.ssl.TrustManager; import net.sf.json.JSONException; import net.sf.json.JSONObject; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.py.weixin.weixinapi.MyX509TrustManager; /** * 通用工具类 * */ public class ComUtil { private static Logger log = LoggerFactory.getLogger(ComUtil.class); // 凭证获取(GET) public final static String token_url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=CORPID&corpsecret=CORPSECRET"; /** * 发送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 corpid 凭证 * @param corpsecret 密钥 * @return */ public static String getAccessToken(String corpid, String corpsecret) { String access_token = ""; String requestUrl = token_url.replace("CORPID", corpid).replace("CORPSECRET", corpsecret); // 发起GET请求获取凭证 JSONObject jsonObject = httpsRequest(requestUrl, "GET", null); if (null != jsonObject) { try { access_token = jsonObject.getString("access_token"); } catch (JSONException e) { access_token = null; // 获取token失败 log.error("获取token失败 errcode:{} errmsg:{}", jsonObject.getInt("errcode"), jsonObject.getString("errmsg")); } } return access_token; } }
4、实现X509TrustManager
package com.py.weixin.weixinapi; import java.security.cert.CertificateException; import java.security.cert.X509Certificate; import javax.net.ssl.X509TrustManager; /** * 信任管理器 * */ public class MyX509TrustManager implements X509TrustManager { // 检查客户端证书 public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException { } // 检查服务器端证书 public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException { } // 返回受信任的X509证书数组 public X509Certificate[] getAcceptedIssuers() { return null; } }
5、运行main方法就可以向指定成员发送消息了。
相关文章推荐
- java微信消息加解密
- 微信摇骰子100%必胜的方法
- 仿照微信的界面,即ViewPager+Fragment的结合使用
- 微信企业号开发(二)-回调接口
- [004]微信公众账号开发教程第1篇-根据用户openID获取用户基本信息
- 微信开发学习路线
- Android之附加图片—— 仿微信图片选择器
- XMPP框架 微信项目开发之登录的实现——登录的步骤示例
- 022.随机数输出
- 微信开发中bug的修复和遇到的问题。
- Android之微信接入分享,登录功能。
- 用Notepad++中的NppExec插件编译运行Java小程序
- XMPP框架 微信项目开发之XMPP框架的导入——XMPP框架导入的详细步骤
- 玩转微信开发(带你读懂开源微信营销平台微擎)
- 一个典型的JDBC小程序
- JAVA微信支付 实现服务端返回预付单号和签名
- 微信开发之附近商家地理位置计算和腾讯地图坐标转百度地图坐标的方法
- Android支付宝、微信支付阐述
- XMPP框架 微信项目开发之XMPP框架目录作用详解——以及登录的Demo分析
- 原创视频|手把手教你用Axure做一个微信高保真原型(一)