开发准备: 请先仔细阅读官方文档:企业内部应用免登
pom.xml
<<dependency>
<groupId>com.aliyun</groupId>
<artifactId>alibaba-dingtalk-service-sdk</artifactId>
<version>2.0.0</version>
</dependency>
因官方文档不建议频繁调用gettoken接口,所以进行本地缓存,代码如下;
public static final long cacheTime = 1000 * 60 * 55 * 2;
private static long LAST_TIME = 0;
private static String ACCESS_TOKEN = null;
/**
* 获取accessToken
* access_token的有效期为7200秒(2小时),有效期内重复获取会返回相同结果并自动续期,过期后获取会返回新的access_token。
* 不能频繁调用gettoken接口,否则会受到频率拦截。
* @return
* @throws ApiException
*/
public static String getAccessToken() {
long curTime = System.currentTimeMillis();
long differ = curTime - LAST_TIME;
if (ACCESS_TOKEN != null && differ < cacheTime)
return ACCESS_TOKEN;
DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/gettoken");
OapiGettokenRequest request = new OapiGettokenRequest();
request.setAppkey(SysConfigCache.appId);
request.setAppsecret(SysConfigCache.appSecret);
request.setHttpMethod("GET");
OapiGettokenResponse response = null;
try {
response = client.execute(request);
} catch (ApiException e) {
log.error("dingUtil getAppToken error", e);
throw new HCException(CommonErrorCode.E100002, "获取token失败");
}
if (!response.isSuccess()) {
log.error("dingUtil getAccessTokenAfresh failed, errorCode={}, errorMsg={}", response.getErrcode(), response.getErrmsg());
return null;
}
ACCESS_TOKEN = response.getAccessToken();
LAST_TIME = curTime;
return ACCESS_TOKEN;
}
@ApiOperation(value = "企业内部应用免登", notes = "企业内部应用免登")
@PostMapping(value = "/login")
public void login (@RequestParam("requestAuthCode") String requestAuthCode) throws ApiException {
// 获取access_token
String access_token= getAccessToken();
// 获取用户信息
DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/user/getuserinfo");
OapiUserGetuserinfoRequest request = new OapiUserGetuserinfoRequest();
request.setCode(requestAuthCode);
request.setHttpMethod("GET");
OapiUserGetuserinfoResponse response;
try {
response = client.execute(request, access_token);
} catch (ApiException e) {
e.printStackTrace();
return null;
}
// 查询得到当前用户的userId
String userId = response.getUserid();
// 根据userId获取用户信息
DingTalkClient clientDingTalkClient2 = new DefaultDingTalkClient("https://oapi.dingtalk.com/topapi/v2/user/get");
OapiV2UserGetRequest reqGetRequest = new OapiV2UserGetRequest();
reqGetRequest.setUserid(userId);
reqGetRequest.setLanguage("zh_CN");
OapiV2UserGetResponse rspGetResponse = clientDingTalkClient2.execute(reqGetRequest, access_token);
System.out.println(rspGetResponse.getBody());
//获取用户信息
OapiV2UserGetResponse.UserGetResponse result = rspGetResponse.getResult();
System.out.println(result.getName());
}