This commit is contained in:
Leo
2026-02-04 16:49:13 +08:00
parent be64dcfb61
commit 79eb651e12
3 changed files with 33 additions and 13 deletions

View File

@@ -28,20 +28,28 @@ public class WPS365ApiServiceImpl implements IWPS365ApiService {
@Override
public JSONObject getUserInfo(String accessToken) {
try {
// WPS365用户信息API: GET /api/v1/user/info
// 注意如果此API不存在或需要不同的路径请查看WPS365官方文档
String url = wps365Config.getApiBaseUrl() + "/user/info";
log.debug("调用用户信息API: {}", url);
JSONObject result = WPS365ApiUtil.httpRequest("GET", url, accessToken, null);
log.debug("用户信息API响应: {}", result);
return result;
} catch (Exception e) {
log.error("获取用户信息失败 - url: {}, error: {}",
wps365Config.getApiBaseUrl() + "/user/info", e.getMessage(), e);
// 不抛出异常,让调用方处理(使用降级方案)
throw new RuntimeException("获取用户信息失败: " + e.getMessage(), e);
// 官方文档open.wps.cn 用户授权流程)仅写“通过 access_token 获取用户信息”,未给出具体路径;
// /api/v1/user/info 返回 404以下按常见惯例尝试若均不可用则返回 null由 Controller 降级返回
String[] urlsToTry = {
"https://openapi.wps.cn/v7/user",
"https://openapi.wps.cn/v7/userinfo",
wps365Config.getApiBaseUrl() + "/userinfo",
wps365Config.getApiBaseUrl() + "/user/info"
};
for (String url : urlsToTry) {
try {
log.debug("尝试用户信息API: {}", url);
JSONObject result = WPS365ApiUtil.httpRequest("GET", url, accessToken, null);
if (result != null) {
log.debug("用户信息API成功 - url: {}", url);
return result;
}
} catch (Exception e) {
log.debug("用户信息API失败 - url: {}, error: {}", url, e.getMessage());
}
}
log.warn("所有用户信息接口均不可用,请以 open.wps.cn 文档为准确认正确路径");
return null;
}
@Override