5.6.3 封装通用工具类

在org.liufeng.course.util包下创建一个通用工具类CommonUtil,代码如下:

  1. package org.liufeng.course.util;
  2.  
  3. import java.io.BufferedReader;
  4. import java.io.InputStream;
  5. import java.io.InputStreamReader;
  6. import java.io.OutputStream;
  7. import java.net.ConnectException;
  8. import java.net.URL;
  9. import javax.net.ssl.HttpsURLConnection;
  10. import javax.net.ssl.SSLContext;
  11. import javax.net.ssl.SSLSocketFactory;
  12. import javax.net.ssl.TrustManager;
  13. import net.sf.json.JSONException;
  14. import net.sf.json.JSONObject;
  15. import org.liufeng.course.pojo.Token;
  16. import org.slf4j.Logger;
  17. import org.slf4j.LoggerFactory;
  18.  
  19. /**
  20. * 通用工具类
  21. *
  22. * @author liufeng
  23. * @date 2013-10-17
  24. */
  25. public class CommonUtil {
  26. private static Logger log = LoggerFactory.getLogger(CommonUtil.class);
  27.  
  28. // 凭证获取(GET)
  29. public final static String token_url = "https:// api.weixin.qq.com/cgi-bin/token?
  30. grant_type=client_credential&appid=APPID&secret=APPSECRET";
  31.  
  32. /**
  33. * 发送https请求
  34. *
  35. * @param requestUrl 请求地址
  36. * @param requestMethod 请求方式(GET、POST)
  37. * @param outputStr 提交的数据
  38. * @return JSONObject(通过JSONObject.get(key)的方式获取JSON对象的属性值)
  39. */
  40. public static JSONObject httpsRequest(String requestUrl, String requestMethod,
  41. String outputStr) {
  42. JSONObject jsonObject = null;
  43. try {
  44. // 创建SSLContext对象,并使用我们指定的信任管理器初始化
  45. TrustManager[] tm = { new MyX509TrustManager() };
  46. SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
  47. sslContext.init(null, tm, new java.security.SecureRandom());
  48. // 从上述SSLContext对象中得到SSLSocketFactory对象
  49. SSLSocketFactory ssf = sslContext.getSocketFactory();
  50.  
  51. URL url = new URL(requestUrl);
  52. HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
  53. conn.setSSLSocketFactory(ssf);
  54.  
  55. conn.setDoOutput(true);
  56. conn.setDoInput(true);
  57. conn.setUseCaches(false);
  58. // 设置请求方式(GET/POST)
  59. conn.setRequestMethod(requestMethod);
  60.  
  61. // 当outputStr不为null时,向输出流写数据
  62. if (null != outputStr) {
  63. OutputStream outputStream = conn.getOutputStream();
  64. // 注意编码格式
  65. outputStream.write(outputStr.getBytes("UTF-8"));
  66. outputStream.close();
  67. }
  68.  
  69. // 从输入流读取返回内容
  70. InputStream inputStream = conn.getInputStream();
  71. InputStreamReader inputStreamReader = new InputStreamReader(inputStream,
  72. "utf-8");
  73. BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
  74. String str = null;
  75. StringBuffer buffer = new StringBuffer();
  76. while ((str = bufferedReader.readLine()) != null) {
  77. buffer.append(str);
  78. }
  79.  
  80. // 释放资源
  81. bufferedReader.close();
  82. inputStreamReader.close();
  83. inputStream.close();
  84. inputStream = null;
  85. conn.disconnect();
  86. jsonObject = JSONObject.fromObject(buffer.toString());
  87. } catch (ConnectException ce) {
  88. log.error("连接超时:{}", ce);
  89. } catch (Exception e) {
  90. log.error("https请求异常:{}", e);
  91. }
  92. return jsonObject;
  93. }
  94.  
  95. /**
  96. * 获取接口访问凭证
  97. *
  98. * @param appid 凭证
  99. * @param appsecret 密钥
  100. * @return
  101. */
  102. public static Token getToken(String appid, String appsecret) {
  103. Token token = null;
  104. String requestUrl = token_url.replace("APPID", appid).replace("APPSECRET",
  105. appsecret);
  106. // 发起GET请求获取凭证
  107. JSONObject jsonObject = httpsRequest(requestUrl, "GET", null);
  108.  
  109. if (null != jsonObject) {
  110. try {
  111. token = new Token();
  112. token.setAccessToken(jsonObject.getString("access_token"));
  113. token.setExpiresIn(jsonObject.getInt("expires_in"));
  114. } catch (JSONException e) {
  115. token = null;
  116. // 获取token失败
  117. log.error("获取token失败 errcode:{} errmsg:{}", jsonObject.getInt
  118. ("errcode"), jsonObject.getString("errmsg"));
  119. }
  120. }
  121. return token;
  122. }
  123. }

在CommonUtil类中,定义了一个通用的HTTPS请求方法httpsRequest(),用于发送HTTPS GET和POST请求,这里用到了5.1.2节中定义的MyX509TrustManager类,它也同样位于org.liufeng.course.util包下。获取凭证、创建菜单、查询菜单和删除菜单都是通过调用httpsRequest()方法实现的,在第6章调用高级接口时也需要用到该方法。

获取凭证方法getToken()的返回值是一个Token对象,Token类的代码如下:

  1. package org.liufeng.course.pojo;
  2.  
  3. /**
  4. * 凭证
  5. *
  6. * @author liufeng
  7. * @date 2013-10-17
  8. */
  9. public class Token {
  10. // 接口访问凭证
  11. private String accessToken;
  12. // 凭证有效期,单位:秒
  13. private int expiresIn;
  14.  
  15. public String getAccessToken() {
  16. return accessToken;
  17. }
  18.  
  19. public void setAccessToken(String accessToken) {
  20. this.accessToken = accessToken;
  21. }
  22.  
  23. public int getExpiresIn() {
  24. return expiresIn;
  25. }
  26.  
  27. public void setExpiresIn(int expiresIn) {
  28. this.expiresIn = expiresIn;
  29. }
  30. }