WeiXinController.java 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. package com.izouma.awesomeadmin.web;
  2. import com.izouma.awesomeadmin.dto.Result;
  3. import com.izouma.awesomeadmin.model.UserInfo;
  4. import com.izouma.awesomeadmin.service.UserInfoService;
  5. import com.izouma.awesomeadmin.service.WeiXinService;
  6. import com.izouma.awesomeadmin.shiro.WeiXinCodeToken;
  7. import com.izouma.awesomeadmin.util.CookieUtil;
  8. import com.izouma.awesomeadmin.util.PropertiesFileLoader;
  9. import com.izouma.awesomeadmin.util.WeixinUtil;
  10. import org.activiti.engine.IdentityService;
  11. import org.apache.log4j.Logger;
  12. import org.apache.shiro.SecurityUtils;
  13. import org.apache.shiro.authc.AuthenticationException;
  14. import org.apache.shiro.subject.Subject;
  15. import org.json.JSONObject;
  16. import org.springframework.beans.factory.annotation.Autowired;
  17. import org.springframework.stereotype.Controller;
  18. import org.springframework.web.bind.annotation.RequestMapping;
  19. import org.springframework.web.bind.annotation.RequestMethod;
  20. import org.springframework.web.bind.annotation.RequestParam;
  21. import org.springframework.web.bind.annotation.ResponseBody;
  22. import org.springframework.web.servlet.ModelAndView;
  23. import javax.servlet.http.HttpServletRequest;
  24. import javax.servlet.http.HttpServletResponse;
  25. import javax.servlet.http.HttpSession;
  26. import java.util.Map;
  27. @Controller
  28. @RequestMapping("/wx")
  29. public class WeiXinController {
  30. private static Logger logger = Logger.getLogger(WeiXinController.class);
  31. @Autowired
  32. private WeiXinService weiXinService;
  33. @Autowired
  34. private UserInfoService userInfoService;
  35. @Autowired
  36. private IdentityService identityService;
  37. @RequestMapping(value = "/getSignature", method = RequestMethod.GET)
  38. @ResponseBody
  39. public Map<String, String> getSignature(HttpServletRequest request) {
  40. String shareUrl = request.getParameter("shareUrl");
  41. return weiXinService.getSignature(shareUrl);
  42. }
  43. @RequestMapping(value = "/auth", method = RequestMethod.GET)
  44. @ResponseBody
  45. public ModelAndView auth(@RequestParam("redirectUri") String redirectUri) {
  46. return new ModelAndView("redirect:https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + PropertiesFileLoader.getProperties("weixinappid")
  47. + "&redirect_uri=" + "http://xjw.izouma.com/wx/redirectLogin?redirectUri=" + redirectUri
  48. + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect");
  49. }
  50. @RequestMapping(value = "/redirectLogin", method = RequestMethod.GET)
  51. @ResponseBody
  52. public ModelAndView redirectLogin(HttpServletRequest request, HttpServletResponse response,
  53. @RequestParam(required = true, value = "code") String code, @RequestParam(required = false, value = "redirectUri") String redirectUri) {
  54. ModelAndView mav = new ModelAndView("redirect:http://xjw.izouma.com/#/" + redirectUri);
  55. final String APP_ID = PropertiesFileLoader.getProperties("weixinappid");
  56. final String APP_SECRET = PropertiesFileLoader.getProperties("weixinsecret");
  57. try {
  58. // System.out.println("code : " + code);
  59. String url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + APP_ID + "&secret=" + APP_SECRET + "&code=" + code
  60. + "&grant_type=authorization_code";
  61. JSONObject data = WeixinUtil.loadJSON(url);
  62. // System.out.println("data : " + data);
  63. // System.out.println(json.toString());
  64. String openId = (String) data.get("openid");
  65. /**
  66. * 新用户存储用户资料
  67. */
  68. String access_token = (String) data.get("access_token");
  69. String userDataUrl = "https://api.weixin.qq.com/sns/userinfo?access_token=" + access_token + "&openid=" + openId;
  70. JSONObject userData = WeixinUtil.loadJSON(userDataUrl);
  71. String weixinInfo = userData.toString();
  72. // System.out.println("userDate : " + userData);
  73. System.out.println("loginUserInfo:" + weixinInfo);
  74. JSONObject userJson = new JSONObject(weixinInfo);
  75. System.out.println("userJson" + userJson);
  76. String headimgurl = userJson.getString("headimgurl");
  77. String sex = userJson.getInt("sex") != 0 ? "男" : "女";
  78. Subject subject = SecurityUtils.getSubject();
  79. WeiXinCodeToken weiXinCodeToken = new WeiXinCodeToken(code, openId, userJson.getString("nickname"), sex, headimgurl);
  80. try {
  81. subject.login(weiXinCodeToken);
  82. } catch (AuthenticationException e) {
  83. e.printStackTrace();
  84. logger.error(e);
  85. }
  86. UserInfo user = (UserInfo) subject.getPrincipal();
  87. identityService.setAuthenticatedUserId(user.getId().toString());
  88. HttpSession session = request.getSession();
  89. CookieUtil.addCookie(response, "JSESSIONID", session.getId(), 3 * 24 * 60 * 60);
  90. } catch (Exception e) {
  91. e.printStackTrace();
  92. return new ModelAndView("redirect:https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + APP_ID + "&redirect_uri="
  93. + "http://xjw.izouma.com/wx/redirectLogin?redirectUri=" + redirectUri
  94. + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect");
  95. }
  96. return mav;
  97. }
  98. /**
  99. * 微信身份获取,登录验证
  100. *
  101. * @return
  102. */
  103. @RequestMapping(value = "/Login", method = RequestMethod.GET)
  104. @ResponseBody
  105. public ModelAndView LoginService(HttpServletRequest request, HttpServletResponse response,
  106. @RequestParam(required = true, value = "code") String code) {
  107. ModelAndView mav = new ModelAndView("redirect:../#/");
  108. final String APP_ID = PropertiesFileLoader.getProperties("weixinappid");
  109. final String APP_SECRET = PropertiesFileLoader.getProperties("weixinsecret");
  110. try {
  111. /**
  112. * 无缓存用户
  113. */
  114. // System.out.println("code : " + code);
  115. String url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + APP_ID + "&secret=" + APP_SECRET + "&code=" + code
  116. + "&grant_type=authorization_code";
  117. JSONObject data = WeixinUtil.loadJSON(url);
  118. logger.error("Login微信身份获取,登录验证 data : " + data);
  119. String openId = (String) data.get("openid");
  120. /**
  121. * 新用户存储用户资料
  122. */
  123. String access_token = (String) data.get("access_token");
  124. String userDataUrl = "https://api.weixin.qq.com/sns/userinfo?access_token=" + access_token + "&openid=" + openId;
  125. JSONObject userData = WeixinUtil.loadJSON(userDataUrl);
  126. String weixinInfo = userData.toString();
  127. // System.out.println("userDate : " + userData);
  128. System.out.println("loginUserInfo:" + weixinInfo);
  129. JSONObject userJson = new JSONObject(weixinInfo);
  130. System.out.println("userJson" + userJson);
  131. String headimgurl = userJson.getString("headimgurl");
  132. String sex = userJson.getInt("sex") != 0 ? "男" : "女";
  133. Subject subject = SecurityUtils.getSubject();
  134. WeiXinCodeToken weiXinCodeToken = new WeiXinCodeToken(code, openId, userJson.getString("nickname"), sex, headimgurl);
  135. try {
  136. subject.login(weiXinCodeToken);
  137. } catch (AuthenticationException e) {
  138. e.printStackTrace();
  139. logger.error(e);
  140. }
  141. UserInfo user = (UserInfo) subject.getPrincipal();
  142. identityService.setAuthenticatedUserId(user.getId().toString());
  143. HttpSession session = request.getSession();
  144. CookieUtil.addCookie(response, "JSESSIONID", session.getId(), 3 * 24 * 60 * 60);
  145. } catch (Exception e) {
  146. e.printStackTrace();
  147. return new ModelAndView("redirect:https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + APP_ID + "&redirect_uri="
  148. + "http://xjw.izouma.com/wx/Login" + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect");
  149. }
  150. return mav;
  151. }
  152. @RequestMapping(value = "/checkSubscribe", method = RequestMethod.GET)
  153. @ResponseBody
  154. public Result checkSubscribe(@RequestParam("userId") String userId) {
  155. UserInfo userInfo = new UserInfo();
  156. userInfo.setId(Integer.valueOf(userId));
  157. userInfo = userInfoService.getUserInfo(userInfo);
  158. try {
  159. JSONObject jsonObject = WeixinUtil.loadJSON("https://api.weixin.qq.com/cgi-bin/user/info?access_token=" + weiXinService.getAccessToken()
  160. + "&openid=" + userInfo.getOpenId());
  161. int subscribe = jsonObject.getInt("subscribe");
  162. if (subscribe == 1) {
  163. return new Result(true, null);
  164. } else {
  165. return new Result(false, null);
  166. }
  167. } catch (Exception e) {
  168. e.printStackTrace();
  169. }
  170. return new Result(false, null);
  171. }
  172. }