在企业微信开发中,使用 Java 获取 jsapi_ticket
并生成签名的步骤如下。以下是完整的 Java 示例代码。
1. 获取 jsapi_ticket
的流程
-
获取
access_token
。 -
使用
access_token
获取jsapi_ticket
。 -
使用
jsapi_ticket
生成签名(signature
)。
2. Java 示例代码
以下是一个完整的 Java 示例,展示如何获取 jsapi_ticket
并生成签名。
依赖
确保项目中引入了以下依赖(如使用 Maven):
xml
复制
<dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactId><version>4.5.13</version> </dependency> <dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.83</version> </dependency>
运行 HTML
代码实现
java
复制
import org.apache.http.HttpEntity; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; import com.alibaba.fastjson.JSONObject;import java.io.IOException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.UUID;public class WeChatJsApiTicket {// 获取 access_token 的接口地址private static final String ACCESS_TOKEN_URL = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=%s&corpsecret=%s";// 获取 jsapi_ticket 的接口地址private static final String JSAPI_TICKET_URL = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=%s";// 企业 ID 和应用 Secretprivate static final String CORP_ID = "YOUR_CORP_ID";private static final String CORP_SECRET = "YOUR_CORP_SECRET";/*** 发送 HTTP GET 请求*/private static String httpGet(String url) throws IOException {try (CloseableHttpClient httpClient = HttpClients.createDefault()) {HttpGet httpGet = new HttpGet(url);try (CloseableHttpResponse response = httpClient.execute(httpGet)) {HttpEntity entity = response.getEntity();return EntityUtils.toString(entity);}}}/*** 获取 access_token*/public static String getAccessToken() throws IOException {String url = String.format(ACCESS_TOKEN_URL, CORP_ID, CORP_SECRET);String response = httpGet(url);JSONObject json = JSONObject.parseObject(response);return json.getString("access_token");}/*** 获取 jsapi_ticket*/public static String getJsApiTicket(String accessToken) throws IOException {String url = String.format(JSAPI_TICKET_URL, accessToken);String response = httpGet(url);JSONObject json = JSONObject.parseObject(response);return json.getString("ticket");}/*** 生成签名*/public static String generateSignature(String jsapiTicket, String noncestr, String timestamp, String url) {String string = "jsapi_ticket=" + jsapiTicket +"&noncestr=" + noncestr +"×tamp=" + timestamp +"&url=" + url;try {MessageDigest digest = MessageDigest.getInstance("SHA-1");digest.update(string.getBytes());byte[] messageDigest = digest.digest();StringBuilder hexString = new StringBuilder();for (byte b : messageDigest) {String shaHex = Integer.toHexString(b & 0xFF);if (shaHex.length() < 2) {hexString.append(0);}hexString.append(shaHex);}return hexString.toString();} catch (NoSuchAlgorithmException e) {throw new RuntimeException("SHA-1 algorithm not found");}}public static void main(String[] args) throws IOException {// 1. 获取 access_tokenString accessToken = getAccessToken();System.out.println("access_token: " + accessToken);// 2. 获取 jsapi_ticketString jsapiTicket = getJsApiTicket(accessToken);System.out.println("jsapi_ticket: " + jsapiTicket);// 3. 生成签名String noncestr = UUID.randomUUID().toString();String timestamp = Long.toString(System.currentTimeMillis() / 1000);String url = "https://example.com"; // 当前页面的 URLString signature = generateSignature(jsapiTicket, noncestr, timestamp, url);System.out.println("noncestr: " + noncestr);System.out.println("timestamp: " + timestamp);System.out.println("signature: " + signature);} }
3. 代码说明
-
获取
access_token
:-
使用企业 ID (
CORP_ID
) 和应用 Secret (CORP_SECRET
) 调用企业微信 API 获取access_token
。
-
-
获取
jsapi_ticket
:-
使用
access_token
调用企业微信 API 获取jsapi_ticket
。
-
-
生成签名:
-
使用
jsapi_ticket
、随机字符串 (noncestr
)、时间戳 (timestamp
) 和当前页面的 URL 生成签名 (signature
)。
-
-
SHA-1 加密:
-
使用 Java 的
MessageDigest
类对字符串进行 SHA-1 加密。
-
4. 输出示例
运行代码后,输出如下:
复制
access_token: YOUR_ACCESS_TOKEN jsapi_ticket: YOUR_JSAPI_TICKET noncestr: 6a8e5f4e-3b1a-4c2d-9f8e-1a2b3c4d5e6f timestamp: 1698765432 signature: 1f3a5e7b9c2d4f6a8b0c1d2e3f4a5b6c7d8e9f0
5. 注意事项
-
缓存
access_token
和jsapi_ticket
:-
由于
access_token
和jsapi_ticket
的有效期均为 7200 秒(2 小时),建议在服务器端缓存它们,避免频繁调用接口。
-
-
URL 参数:
-
生成签名时,URL 必须是当前页面的完整 URL(不包括
#
及其后面部分)。
-
-
安全性:
-
access_token
和jsapi_ticket
是敏感信息,不要泄露给客户端或第三方。
-
通过以上代码,你可以在 Java 中实现企业微信 jsapi_ticket
的获取和签名生成。