OpenApiController.java 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. package com.qmth.xjtu.api;
  2. import com.alibaba.fastjson.JSONArray;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.qmth.boot.api.annotation.Aac;
  5. import com.qmth.boot.api.annotation.BOOL;
  6. import com.qmth.boot.api.constant.ApiConstant;
  7. import com.qmth.teachcloud.exchange.common.bean.params.OpenParams;
  8. import com.qmth.teachcloud.exchange.common.contant.SystemConstant;
  9. import com.qmth.teachcloud.exchange.common.enums.ExceptionResultEnum;
  10. import com.qmth.teachcloud.exchange.common.service.AuthInfoService;
  11. import com.qmth.teachcloud.exchange.common.service.CommonService;
  12. import com.qmth.teachcloud.exchange.common.util.HttpUtil;
  13. import com.qmth.teachcloud.exchange.common.util.JacksonUtil;
  14. import com.qmth.teachcloud.exchange.common.util.Result;
  15. import com.qmth.teachcloud.exchange.common.util.ServletUtil;
  16. import io.swagger.annotations.*;
  17. import org.slf4j.Logger;
  18. import org.slf4j.LoggerFactory;
  19. import org.springframework.beans.factory.annotation.Value;
  20. import org.springframework.validation.annotation.Validated;
  21. import org.springframework.web.bind.annotation.RequestMapping;
  22. import org.springframework.web.bind.annotation.RequestMethod;
  23. import org.springframework.web.bind.annotation.RequestParam;
  24. import org.springframework.web.bind.annotation.RestController;
  25. import javax.annotation.Resource;
  26. import javax.servlet.http.HttpServletResponse;
  27. import java.io.IOException;
  28. import java.util.LinkedHashMap;
  29. import java.util.Map;
  30. import java.util.Objects;
  31. import java.util.StringJoiner;
  32. /**
  33. * <p>
  34. * 西安交通大学开放接口前端控制器
  35. * </p>
  36. *
  37. * @author wangliang
  38. * @since 2022-04-26
  39. */
  40. @Api(tags = "西安交通大学开放接口Controller")
  41. @RestController
  42. @RequestMapping(ApiConstant.DEFAULT_URI_PREFIX + "/${prefix.url.open}")
  43. @Validated
  44. public class OpenApiController {
  45. private static final Logger log = LoggerFactory.getLogger(OpenApiController.class);
  46. private static final String ACCESS_TOKEN_URL = "https://org.xjtu.edu.cn/openplatform/oauth/getAccessToken";
  47. private static final String USER_INFO_URL = "https://org.xjtu.edu.cn/openplatform/oauth/open/getUserInfo";
  48. private static final String LOGOUT_URL = "http://org.xjtu.edu.cn/openplatform/oauth/logout";
  49. private static final String RETURN_URL = "https://org.xjtu.edu.cn/openplatform/login.html";
  50. private static final String schoolCode = "xjtu";//测试学校code,正式改成xjtu
  51. @Resource
  52. CommonService commonService;
  53. @Resource
  54. AuthInfoService authInfoService;
  55. @Value("${cas.config.logoutUrl}")
  56. String logoutUrl;
  57. @ApiOperation(value = "西安交通大学cas鉴权接口")
  58. @ApiResponses({@ApiResponse(code = 200, message = "返回消息", response = Result.class)})
  59. @RequestMapping(value = "/authentication", method = RequestMethod.GET)
  60. @Aac(auth = BOOL.FALSE)
  61. public void authentication(@ApiParam(value = "工号") @RequestParam(required = false) String code,
  62. @ApiParam(value = "系统参数") @RequestParam(required = false) String state,
  63. @ApiParam(value = "用户类型") @RequestParam(required = false) String userType,
  64. @ApiParam(value = "员工工号") @RequestParam(required = false) String employeeNo,
  65. @ApiParam(value = "返回url") @RequestParam(required = false) String returnUrl) throws IOException {
  66. if ((Objects.isNull(code) || Objects.equals(code, ""))
  67. || (Objects.isNull(employeeNo) || Objects.equals(employeeNo, ""))) {
  68. throw ExceptionResultEnum.ERROR.exception("请先通过学校地址登录");
  69. }
  70. authInfoService.appHasExpired(schoolCode);
  71. Map<String, Object> accessTokenParams = new LinkedHashMap<>();
  72. accessTokenParams.put("code", code);
  73. String accessTokenResult = HttpUtil.post(ACCESS_TOKEN_URL, accessTokenParams, null);
  74. String accessToken = null, gsessionId = null;
  75. //获取accessToken
  76. if (Objects.nonNull(accessTokenResult)) {
  77. log.info("accessTokenResult:{}", JacksonUtil.parseJson(accessTokenResult));
  78. JSONObject jsonObject = JSONObject.parseObject(accessTokenResult);
  79. JSONObject object = jsonObject.getJSONObject("data");
  80. String message = jsonObject.getString("message");
  81. if (Objects.nonNull(object) && Objects.nonNull(message) && Objects.equals(message, "成功")) {
  82. accessToken = object.getString("accessToken");
  83. gsessionId = object.getString("gsessionId");
  84. } else {
  85. throw ExceptionResultEnum.ERROR.exception(message);
  86. }
  87. }
  88. OpenParams openParams = null;
  89. //获取用户信息
  90. if (Objects.nonNull(accessToken)) {
  91. String userInfoResult = HttpUtil.post(USER_INFO_URL, null, accessToken);
  92. if (Objects.nonNull(userInfoResult)) {
  93. log.info("userInfoResult:{}", JacksonUtil.parseJson(userInfoResult));
  94. openParams = new OpenParams();
  95. // openParams.setResult(JacksonUtil.parseJson(userInfoResult));
  96. JSONObject jsonObject = JSONObject.parseObject(userInfoResult);
  97. JSONObject object = jsonObject.getJSONObject("data");
  98. String message = jsonObject.getString("message");
  99. JSONArray userTypeJsonArray = object.getJSONArray("userTypes");
  100. JSONArray deptInfoJsonArray = object.getJSONArray("deptInfos");
  101. if (Objects.nonNull(object) && Objects.nonNull(message) && Objects.equals(message, "成功")) {
  102. openParams.setOrgName(object.getString("orgName"));
  103. if (Objects.nonNull(userTypeJsonArray) && userTypeJsonArray.size() > 0) {
  104. JSONObject userTypeJsonObject = userTypeJsonArray.getJSONObject(0);
  105. openParams.setName(userTypeJsonObject.getString("memberName"));
  106. Integer userTypeRole = userTypeJsonObject.getInteger("userType");
  107. if (Objects.nonNull(userTypeRole) && userTypeRole.intValue() == 1) {
  108. openParams.setRoleName("学生");
  109. } else if (Objects.nonNull(userTypeRole) && userTypeRole.intValue() == 2) {
  110. openParams.setRoleName("教职工");
  111. }
  112. }
  113. if (Objects.nonNull(deptInfoJsonArray) && deptInfoJsonArray.size() > 0) {
  114. JSONObject deptInfoJsonArrayJsonObject = deptInfoJsonArray.getJSONObject(0);
  115. openParams.setDeptName(deptInfoJsonArrayJsonObject.getString("deptName"));
  116. }
  117. } else {
  118. throw ExceptionResultEnum.ERROR.exception(message);
  119. }
  120. }
  121. }
  122. //登出
  123. if (Objects.nonNull(gsessionId)) {
  124. StringJoiner stringJoiner = new StringJoiner("");
  125. stringJoiner.add(logoutUrl).add(SystemConstant.GET_UNKNOWN).add("gSessionId")
  126. .add(SystemConstant.GET_EQUAL).add(gsessionId);
  127. returnUrl = stringJoiner.toString();
  128. } else {
  129. throw ExceptionResultEnum.ERROR.exception("gSessionId为空");
  130. }
  131. commonService.redirectLogic(employeeNo, schoolCode, returnUrl, Objects.nonNull(openParams) ? JacksonUtil.parseJson(openParams) : null);
  132. }
  133. @ApiOperation(value = "西安交通大学cas鉴权退出接口")
  134. @RequestMapping(value = "/authentication/logout", method = RequestMethod.GET)
  135. @ApiResponses({@ApiResponse(code = 200, message = "返回消息", response = Result.class)})
  136. @Aac(auth = BOOL.FALSE)
  137. public void logout(@ApiParam(value = "sessionId", required = true) @RequestParam String gSessionId) throws IOException {
  138. if (Objects.isNull(logoutUrl) || Objects.equals(logoutUrl, "")) {
  139. throw ExceptionResultEnum.PARAMS_ERROR.exception("鉴权退出地址不存在");
  140. }
  141. if (Objects.isNull(gSessionId) || Objects.equals(gSessionId, "")) {
  142. throw ExceptionResultEnum.PARAMS_ERROR.exception("sessionId为空");
  143. }
  144. Map<String, Object> logoutParams = new LinkedHashMap<>();
  145. logoutParams.put("gSessionId", gSessionId);
  146. String logoutResult = HttpUtil.post(LOGOUT_URL, logoutParams, null);
  147. if (Objects.nonNull(logoutResult)) {
  148. log.info("logoutResult:{}", JacksonUtil.parseJson(logoutResult));
  149. JSONObject jsonObject = JSONObject.parseObject(logoutResult);
  150. String message = jsonObject.getString("message");
  151. if (Objects.nonNull(message) && Objects.equals(message, "成功")) {
  152. HttpServletResponse response = ServletUtil.getResponse();
  153. response.setHeader("Access-Control-Allow-Origin", SystemConstant.PATH_MATCH);
  154. response.sendRedirect(RETURN_URL);
  155. }
  156. }
  157. }
  158. }