这两天在做公司的微信公众号开发。慢慢的对code有了一定的了解。有人说开发的时候直接看微信开发者文档不就行了?其实可以看,只不过我第一次看没搞明白,到底什么是code,再加上运行项目始终死在code获取不到上。最后我不得不在回过头看看到底什么是code。之后反反复复进行项目测试的时候,直到成功了,我才深有体会。下面写一下我的心里感受把。
首先关于微信网页授权,参考微信开发者文档。https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842大家可以过一遍看看。最重要的是微信的redirect_uri的填写,文档上说这个uri是要进行这个urlEncode 对链接进行处理。这个的好处并不是加密。是为了如果用户同意授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE。容易获取?后面的code和state,这两个值是微信授权页面之后,微信端附加的参数,也就是我们要获取的code,最后直接从url里面获取到参数就行,也就我们获取code。
另外关于code,code作为换取access_token的票据,每次用户授权带上的code将不一样,code只能使用一次,5分钟未被使用自动过期。
获取用户信息使用access_token和openid。然而access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用access_token。开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效。
openid的获取链接是这个
https://api.weixin.qq.com/sns/oauth2/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code
其中code就是上面所说的code。另外appid也就是你自己微信平台的aapid和secret是你自己的APPSECRET。发送http请求可以进一步获取到openid
微信的长链接转短链接官方api如下。
https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1443433600
/**
* 长链接转短链接
* @param accessToken
* @param long_url
* @return
* @throws Exception
*/
public static Map
Map
// 拼装创建菜单的url
String url = link_create_url.replace("ACCESS_TOKEN", accessToken);
String param = "{\"action\":\"long2short\","
+ "\"long_url\":\""+long_url+"\"}";
// 调用接口创建菜单
JSONObject jsonObject = httpRequest(url, "POST", param);
System.out.println(jsonObject);
if (null != jsonObject) {
returnBack.put("returnCode", jsonObject.getInt("errcode"));
returnBack.put("short_url", jsonObject.getString("short_url"));
return returnBack;
}else{
return null;
}
}
httpRequest
public static JSONObject httpRequest(String requestUrl, String requestMethod, String outputStr) {
HttpsURLConnection httpUrlConn = null;
OutputStream outputStream = null ;
InputStream inputStream = null;
JSONObject jsonObject = null;
StringBuffer buffer = new StringBuffer();
// 创建SSLContext对象,并使用我们指定的信任管理器初始化
TrustManager[] tm = { new MyX509TrustManager() };
try{
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);
httpUrlConn = (HttpsURLConnection) url.openConnection();
httpUrlConn.setSSLSocketFactory(ssf);
httpUrlConn.setDoOutput(true);
httpUrlConn.setDoInput(true);
httpUrlConn.setUseCaches(false);
// 设置请求方式(GET/POST)
httpUrlConn.setRequestMethod(requestMethod);
httpUrlConn.connect();
// 当有数据需要提交时
if (null != outputStr) {
outputStream = httpUrlConn.getOutputStream();
// 注意编码格式,防止中文乱码
outputStream.write(outputStr.getBytes("UTF-8"));
outputStream.close();
}
// 将返回的输入流转换成字符串
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();
jsonObject = JSONObject.fromObject(buffer.toString());
}catch(Exception e){
logger.error("网络请求错误 class-httpRequest-error={}",e);
e.printStackTrace();
}finally{
// 释放资源
try {
if(inputStream != null){
inputStream.close();
}
} catch (IOException e) {
e.printStackTrace();
}
inputStream = null;
if (httpUrlConn != null ){
httpUrlConn.disconnect();
}
}
return jsonObject;
}
大概就这三个方向。是我这一阵子学习的感悟。