微信获取AccessToken并本地保存

不敢标原创,感谢 柳峰老师和另一位dalao(http://my.csdn.net/wgyscsf)
 
 
public class WxAccessToken {
	private static final long MAX_TIME = 7200 * 1000;// 微信允许最长Access_token有效时间(ms)

	/**
	 * 获取Access_token 保存并且只保存2小时Access_token。如果超过两个小时重新获取;如果没有超过两个小时,直接获取
	 * 思路:将获取到的Access_token和当前时间存储到file里,
	 * 取出时判断当前时间和存储里面的记录的时间的时间差,如果大于MAX_TIME,重新获取,并且将获取到的存储到file替换原来的内容
	 * ,如果小于MAX_TIME,直接获取。
	 * 
	 * @throws IOException
	 */
	public static String getSavedAccess_token() throws IOException {
		Gson gson = new Gson();
		String mAccess_token = null;// 需要获取的Access_token;
		File file = new File("temp_access_token.temp");// Access_token保存的位置
		// 如果文件不存在,创建
		if (!file.exists())
			file.createNewFile();
		// 如果文件大小等于0,说明第一次使用,存入Access_token
		if (file.length() == 0) {
			mAccess_token = getAccessToken();
			FileOutputStream fos = new FileOutputStream(file, false);// 不允许追加
			Access_token at = new Access_token();
			at.setAccess_token(mAccess_token);
			at.setExpires_in(System.currentTimeMillis() + "");
			String json = gson.toJson(at);
			fos.write((json).getBytes());
			fos.close();
		} else {
			// 读取文件内容
			FileInputStream fis = new FileInputStream(file);
			byte[] b = new byte[2048];
			int len = fis.read(b);
			String mJsonAccess_token = new String(b, 0, len);// 读取到的文件内容
			Access_token access_token = gson.fromJson(mJsonAccess_token, new Access_token().getClass());
			if (access_token.getExpires_in() != null) {
				long saveTime = Long.parseLong(access_token.getExpires_in());
				long nowTime = System.currentTimeMillis();
				long remianTime = nowTime - saveTime;
				//System.out.println(TAG + "时间差:" + remianTime);
				if (remianTime < MAX_TIME) {
					Access_token at = gson.fromJson(mJsonAccess_token, new Access_token().getClass());
					mAccess_token = at.getAccess_token();
				} else {
					mAccess_token = getAccessToken();
					FileOutputStream fos = new FileOutputStream(file, false);// 不允许追加
					Access_token at = new Access_token();
					at.setAccess_token(mAccess_token);
					at.setExpires_in(System.currentTimeMillis() + "");
					String json = gson.toJson(at);
					fos.write((json).getBytes());
					fos.close();
				}

			}
		}
		//System.out.println("获取到的Access_token是:" + mAccess_token);
		return mAccess_token;
		
	}

	public static String getAccessToken() {
		String urlString = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="
				+ Constant.APPID + "&secret=" + Constant.SERCRET;
		String reslut = null;
		try {
			URL reqURL = new URL(urlString);
			HttpsURLConnection httpsConn = (HttpsURLConnection) reqURL.openConnection();
			InputStreamReader isr = new InputStreamReader(httpsConn.getInputStream());
			char[] chars = new char[1024];
			reslut = "";
			int len;
			while ((len = isr.read(chars)) != -1) {
				reslut += new String(chars, 0, len);
			}
			isr.close();
		} catch (IOException e) {

			e.printStackTrace();
		}
		Gson gson = new Gson();
		Access_token access_token = gson.fromJson(reslut, new Access_token().getClass());
		if (access_token.getAccess_token() != null) {
			return access_token.getAccess_token();
		} else {
			return null;
		}
	}
}

 

猜你喜欢

转载自blog.csdn.net/weixin_35790330/article/details/66972004