OpenApiController.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. package com.qmth.xjtu.api;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONArray;
  4. import com.alibaba.fastjson.JSONObject;
  5. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  6. import com.qmth.boot.api.annotation.Aac;
  7. import com.qmth.boot.api.annotation.BOOL;
  8. import com.qmth.boot.api.constant.ApiConstant;
  9. import com.qmth.boot.core.cache.service.CacheService;
  10. import com.qmth.boot.tools.signature.SignatureEntity;
  11. import com.qmth.boot.tools.signature.SignatureType;
  12. import com.qmth.teachcloud.exchange.common.bean.params.OpenParams;
  13. import com.qmth.teachcloud.exchange.common.contant.SystemConstant;
  14. import com.qmth.teachcloud.exchange.common.entity.BasicSchool;
  15. import com.qmth.teachcloud.exchange.common.enums.ExceptionResultEnum;
  16. import com.qmth.teachcloud.exchange.common.service.AuthInfoService;
  17. import com.qmth.teachcloud.exchange.common.service.BasicSchoolService;
  18. import com.qmth.teachcloud.exchange.common.service.CommonService;
  19. import com.qmth.teachcloud.exchange.common.util.HttpUtil;
  20. import com.qmth.teachcloud.exchange.common.util.JacksonUtil;
  21. import com.qmth.teachcloud.exchange.common.util.Result;
  22. import com.qmth.teachcloud.exchange.common.util.ServletUtil;
  23. import io.swagger.annotations.*;
  24. import org.apache.commons.lang3.StringUtils;
  25. import org.slf4j.Logger;
  26. import org.slf4j.LoggerFactory;
  27. import org.springframework.beans.factory.annotation.Value;
  28. import org.springframework.http.HttpStatus;
  29. import org.springframework.util.CollectionUtils;
  30. import org.springframework.validation.annotation.Validated;
  31. import org.springframework.web.bind.annotation.RequestMapping;
  32. import org.springframework.web.bind.annotation.RequestMethod;
  33. import org.springframework.web.bind.annotation.RequestParam;
  34. import org.springframework.web.bind.annotation.RestController;
  35. import javax.annotation.Resource;
  36. import javax.servlet.http.HttpServletResponse;
  37. import java.io.IOException;
  38. import java.util.*;
  39. /**
  40. * <p>
  41. * 西安交通大学开放接口前端控制器
  42. * </p>
  43. *
  44. * @author wangliang
  45. * @since 2022-04-26
  46. */
  47. @Api(tags = "西安交通大学开放接口Controller")
  48. @RestController
  49. @RequestMapping(ApiConstant.DEFAULT_URI_PREFIX + SystemConstant.PREFIX_URL_OPEN)
  50. @Validated
  51. public class OpenApiController {
  52. private static final Logger log = LoggerFactory.getLogger(OpenApiController.class);
  53. private static final String ACCESS_TOKEN_URL = "http://org.xjtu.edu.cn/openplatform/oauth/getAccessToken";
  54. private static final String USER_INFO_URL = "http://org.xjtu.edu.cn/openplatform/oauth/open/getUserInfo";
  55. private static final String LOGOUT_URL = "http://org.xjtu.edu.cn/openplatform/oauth/logout";
  56. private static final String SCHOOL_CODE = "xjtu";//测试学校code,正式改成xjtu
  57. private static final String LOGIN_BEFORE_XJU_LOGIC_API = "/api/admin/print/open/login_before_xju_logic";//西交大登录之前逻辑
  58. private static final String VERSION = "1.0.1.1";
  59. @Resource
  60. CommonService commonService;
  61. @Resource
  62. AuthInfoService authInfoService;
  63. @Value("${cas.config.logoutUrl}")
  64. String logoutUrl;
  65. @Value("${cas.config.returnUrl}")
  66. String returnUrl;
  67. @Value("${cas.config.teachcloudPrintLoginUrl}")
  68. String teachcloudLoginUrl;
  69. @Resource
  70. BasicSchoolService basicSchoolService;
  71. @Resource
  72. CacheService cacheService;
  73. @ApiOperation(value = "西安交通大学cas鉴权接口")
  74. @ApiResponses({@ApiResponse(code = 200, message = "返回消息", response = Result.class)})
  75. @RequestMapping(value = "/authentication", method = RequestMethod.GET)
  76. @Aac(auth = BOOL.FALSE)
  77. public void authentication(@ApiParam(value = "工号") @RequestParam(required = false) String code,
  78. @ApiParam(value = "系统参数") @RequestParam(required = false) String state,
  79. @ApiParam(value = "用户类型") @RequestParam(required = false) String userType,
  80. @ApiParam(value = "员工工号") @RequestParam(required = false) String employeeNo,
  81. @ApiParam(value = "返回url") @RequestParam(required = false) String returnUrl) throws IOException {
  82. log.info("version:{}", VERSION);
  83. if ((Objects.isNull(code) || Objects.equals(code, ""))
  84. || (Objects.isNull(employeeNo) || Objects.equals(employeeNo, ""))) {
  85. throw ExceptionResultEnum.ERROR.exception("请先通过学校地址登录");
  86. }
  87. authInfoService.appHasExpired(SCHOOL_CODE);
  88. //2022-12-06加入登录之前逻辑
  89. if (Objects.isNull(teachcloudLoginUrl) || Objects.equals(teachcloudLoginUrl, "")) {
  90. throw ExceptionResultEnum.PARAMS_ERROR.exception("知学登录跳转地址不存在");
  91. }
  92. String[] strs = teachcloudLoginUrl.split(SystemConstant.PATH_SUBSTR);
  93. if (strs[0].contains(SystemConstant.PATH_MATCH)) {
  94. strs[0] = strs[0].replace(SystemConstant.PATH_MATCH, SCHOOL_CODE);
  95. }
  96. BasicSchool basicSchool = (BasicSchool) cacheService.get(SystemConstant.SCHOOL_CODE_CACHE, SCHOOL_CODE);
  97. if (Objects.isNull(basicSchool)) {
  98. QueryWrapper<BasicSchool> basicSchoolQueryWrapper = new QueryWrapper<>();
  99. basicSchoolQueryWrapper.lambda().eq(BasicSchool::getCode, SCHOOL_CODE);
  100. basicSchool = basicSchoolService.getOne(basicSchoolQueryWrapper);
  101. }
  102. Optional.ofNullable(basicSchool).orElseThrow(() -> ExceptionResultEnum.PARAMS_ERROR.exception("学校信息不存在"));
  103. Long timestamp = System.currentTimeMillis();
  104. String signature = SignatureEntity.build(SignatureType.SECRET, SystemConstant.METHOD, LOGIN_BEFORE_XJU_LOGIC_API, timestamp, basicSchool.getAccessKey(), basicSchool.getAccessSecret());
  105. String callResult = HttpUtil.postJson(strs[0] + LOGIN_BEFORE_XJU_LOGIC_API, JacksonUtil.parseJson(employeeNo), signature, timestamp);
  106. // String schoolCodeParam = null;
  107. if (!StringUtils.isBlank(callResult)) {
  108. log.info("callbackResult:{}", JacksonUtil.parseJson(callResult));
  109. Result result = JSON.parseObject(callResult, Result.class);
  110. if (result.getCode() == HttpStatus.OK.value()) {
  111. Object data = result.getData();
  112. List<Map> sysuserList = JSONObject.parseArray(JSON.toJSONString(data), Map.class);
  113. if (CollectionUtils.isEmpty(sysuserList)) {
  114. throw ExceptionResultEnum.ERROR.exception("未查到此用户");
  115. }
  116. // if (sysuserList.size() >= 2) {
  117. // throw ExceptionResultEnum.ERROR.exception("查询到有多个用户");
  118. // }
  119. // String schoolId = String.valueOf(sysuserList.get(0).get("schoolId"));
  120. // Optional.ofNullable(schoolId).orElseThrow(() -> ExceptionResultEnum.ERROR.exception("学校id为空"));
  121. // BasicSchool basicSchoolMap = (BasicSchool) cacheService.get(SystemConstant.SCHOOL_CACHE, schoolId);
  122. // Optional.ofNullable(basicSchoolMap).orElseThrow(() -> ExceptionResultEnum.ERROR.exception("学校id:" + schoolId + ",学校不存在"));
  123. // schoolCodeParam = basicSchoolMap.getCode();
  124. } else {
  125. throw ExceptionResultEnum.ERROR.exception("调用知学知考西交大登录前查找账号接口失败");
  126. }
  127. }
  128. Map<String, Object> accessTokenParams = new LinkedHashMap<>();
  129. accessTokenParams.put("code", code);
  130. String accessTokenResult = HttpUtil.post(ACCESS_TOKEN_URL, accessTokenParams, null);
  131. String accessToken = null, gsessionId = null;
  132. //获取accessToken
  133. if (Objects.nonNull(accessTokenResult)) {
  134. log.info("accessTokenResult:{}", JacksonUtil.parseJson(accessTokenResult));
  135. JSONObject jsonObject = JSONObject.parseObject(accessTokenResult);
  136. JSONObject object = jsonObject.getJSONObject("data");
  137. String message = jsonObject.getString("message");
  138. if (Objects.nonNull(object) && Objects.nonNull(message) && Objects.equals(message, "成功")) {
  139. accessToken = object.getString("accessToken");
  140. gsessionId = object.getString("gsessionId");
  141. } else {
  142. throw ExceptionResultEnum.ERROR.exception(message);
  143. }
  144. }
  145. OpenParams openParams = null;
  146. //获取用户信息
  147. if (Objects.nonNull(accessToken)) {
  148. String userInfoResult = HttpUtil.post(USER_INFO_URL, null, accessToken);
  149. if (Objects.nonNull(userInfoResult)) {
  150. log.info("userInfoResult:{}", JacksonUtil.parseJson(userInfoResult));
  151. openParams = new OpenParams();
  152. // openParams.setResult(JacksonUtil.parseJson(userInfoResult));
  153. JSONObject jsonObject = JSONObject.parseObject(userInfoResult);
  154. JSONObject object = jsonObject.getJSONObject("data");
  155. String message = jsonObject.getString("message");
  156. JSONArray userTypeJsonArray = object.getJSONArray("userTypes");
  157. JSONArray deptInfoJsonArray = object.getJSONArray("deptInfos");
  158. if (Objects.nonNull(object) && Objects.nonNull(message) && Objects.equals(message, "成功")) {
  159. openParams.setOrgName(object.getString("orgName"));
  160. if (Objects.nonNull(userTypeJsonArray) && userTypeJsonArray.size() > 0) {
  161. JSONObject userTypeJsonObject = userTypeJsonArray.getJSONObject(0);
  162. openParams.setName(userTypeJsonObject.getString("memberName"));
  163. Integer userTypeRole = userTypeJsonObject.getInteger("userType");
  164. if (Objects.nonNull(userTypeRole) && userTypeRole.intValue() == 1) {
  165. openParams.setRoleName("学生");
  166. } else if (Objects.nonNull(userTypeRole) && userTypeRole.intValue() == 2) {
  167. openParams.setRoleName("教职工");
  168. }
  169. }
  170. if (Objects.nonNull(deptInfoJsonArray) && deptInfoJsonArray.size() > 0) {
  171. JSONObject deptInfoJsonArrayJsonObject = deptInfoJsonArray.getJSONObject(0);
  172. openParams.setDeptName(deptInfoJsonArrayJsonObject.getString("deptName"));
  173. }
  174. } else {
  175. throw ExceptionResultEnum.ERROR.exception(message);
  176. }
  177. }
  178. }
  179. //登出
  180. if (Objects.nonNull(gsessionId)) {
  181. StringJoiner stringJoiner = new StringJoiner("");
  182. stringJoiner.add(logoutUrl).add(SystemConstant.GET_UNKNOWN).add("gSessionId")
  183. .add(SystemConstant.GET_EQUAL).add(gsessionId);
  184. returnUrl = stringJoiner.toString();
  185. } else {
  186. throw ExceptionResultEnum.ERROR.exception("gSessionId为空");
  187. }
  188. commonService.redirectLogic(employeeNo, SCHOOL_CODE, returnUrl, Objects.nonNull(openParams) ? JacksonUtil.parseJson(openParams) : null);
  189. }
  190. @ApiOperation(value = "西安交通大学cas鉴权退出接口")
  191. @RequestMapping(value = "/authentication/logout", method = RequestMethod.GET)
  192. @ApiResponses({@ApiResponse(code = 200, message = "返回消息", response = Result.class)})
  193. @Aac(auth = BOOL.FALSE)
  194. public void logout(@ApiParam(value = "sessionId", required = true) @RequestParam String gSessionId) throws IOException {
  195. if (Objects.isNull(logoutUrl) || Objects.equals(logoutUrl, "")) {
  196. throw ExceptionResultEnum.PARAMS_ERROR.exception("鉴权退出地址不存在");
  197. }
  198. if (Objects.isNull(gSessionId) || Objects.equals(gSessionId, "")) {
  199. throw ExceptionResultEnum.PARAMS_ERROR.exception("sessionId为空");
  200. }
  201. authInfoService.appHasExpired(SCHOOL_CODE);
  202. Map<String, Object> logoutParams = new LinkedHashMap<>();
  203. logoutParams.put("gSessionId", gSessionId);
  204. String logoutResult = HttpUtil.post(LOGOUT_URL, logoutParams, null);
  205. if (Objects.nonNull(logoutResult)) {
  206. log.info("logoutResult:{}", JacksonUtil.parseJson(logoutResult));
  207. JSONObject jsonObject = JSONObject.parseObject(logoutResult);
  208. String message = jsonObject.getString("message");
  209. if (Objects.nonNull(message) && Objects.equals(message, "成功")) {
  210. HttpServletResponse response = ServletUtil.getResponse();
  211. response.setHeader("Access-Control-Allow-Origin", SystemConstant.PATH_MATCH);
  212. response.sendRedirect(returnUrl);
  213. }
  214. }
  215. }
  216. }