| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827 |
- package com.uas.sso.controller;
- import com.alibaba.fastjson.JSON;
- import com.alibaba.fastjson.JSONObject;
- import com.uas.account.AccountConfig;
- import com.uas.account.entity.UserDetail;
- import com.uas.sso.*;
- import com.uas.sso.common.util.HttpUtil;
- import com.uas.sso.core.Const;
- import com.uas.sso.entity.*;
- import com.uas.sso.entity.Token;
- import com.uas.sso.service.*;
- import com.uas.sso.util.*;
- import com.uas.sso.web.waf.request.WafRequestWrapper;
- import com.uas.sso.weixin.service.WeChatService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.ui.ModelMap;
- import org.springframework.util.Assert;
- import org.springframework.util.CollectionUtils;
- import org.springframework.util.StringUtils;
- import org.springframework.web.bind.annotation.*;
- import org.springframework.web.servlet.ModelAndView;
- import java.io.IOException;
- import java.util.*;
- /**
- * 登录controller
- *
- * @author wangmh
- * @date 2018/1/5
- */
- @RequestMapping("/sso/login")
- @RestController
- public class LoginController extends BaseController {
- /**
- * 密码输错3次
- */
- private static final int PWD_ERROR_FIVE_TIME = 5;
- /**
- * 密码输错3次
- */
- private static final int PWD_ERROR_THREE_TIME = 3;
- /**
- * 登录验证码存session的key值
- */
- private static final String LOGIN_CAPTCHA = "loginCaptcha";
- /**
- * 优软云首页地址
- */
- private static final String HOME_PAGE = "https://www.ubtob.com/";
- @Autowired
- private AppService appService;
- @Autowired
- private UserService userService;
- @Autowired
- private UserspaceService userspaceService;
- @Autowired
- private UserAccountService userAccountService;
- @Autowired
- private PersonalAccountService personalAccountService;
- @Autowired
- private WeChatService weChatService;
- @RequestMapping(method = RequestMethod.POST)
- public ModelMap login() {
- // 获取登录信息
- WafRequestWrapper wr = new WafRequestWrapper(request);
- String appId = wr.getParameter("appId");
- String spaceUU = wr.getParameter("spaceUU");
- String username = StringUtils.trimAllWhitespace(wr.getParameter("username"));
- String password = wr.getParameter("password");
- String captcha = wr.getParameter("captcha");
- String returnUrl = wr.getParameter("returnUrl");
- String baseUrl = wr.getParameter("baseUrl");
- // 校验空参数
- try {
- Assert.hasText(username, "用户名不能为空");
- Assert.hasText(password, "密码不能为空");
- } catch (IllegalArgumentException e) {
- return error(e.getMessage());
- }
- // 设置baseUrl
- if (!StringUtils.isEmpty(baseUrl)) {
- request.getSession().setAttribute("baseUrl", baseUrl);
- }
- // 校验appId,appId为空的话默认为sso
- appId = StringUtils.isEmpty(appId) ? SSOHelper.getSSOService().getConfig().getAppName() : appId;
- App app = appService.findOne(appId);
- if (app == null) {
- return error("应用id不存在");
- }
- // 校验returnUrl,为空默认为优软云
- if (StringUtils.isEmpty(returnUrl)) {
- returnUrl = HOME_PAGE;
- }
- // 获取用户基本信息
- User user = userService.findByUsername(username);
- if (user == null) {
- return error("用户名或密码错误");
- }
- // 校验账户密码输错次数
- if (user.getUserRecord() == null) {
- UserRecord userRecord = userService.save(new UserRecord(user.getUserUU()));
- user.setUserRecord(userRecord);
- }
- int pwdErrorCount = user.getUserRecord() == null ? 0 : user.getUserRecord().getPwdErrorCount();
- Object loginCaptcha = request.getSession().getAttribute(LOGIN_CAPTCHA);
- String checkCode = loginCaptcha == null ? "" : loginCaptcha.toString();
- if (pwdErrorCount >= PWD_ERROR_FIVE_TIME) {
- return error("403", "密码错误次数已达上限,今日无法登陆");
- }
- // 校验账号是否被锁定,5次输错密码
- if (pwdErrorCount >= PWD_ERROR_THREE_TIME && StringUtils.isEmpty(captcha)) {
- return error("404", "验证码不能为空");
- }
- if (pwdErrorCount >= PWD_ERROR_THREE_TIME && !captcha.equalsIgnoreCase(checkCode)) {
- return error("验证码错误");
- }
- // 校验密码
- String encryPwd = userService.getEncryPassword(Const.ENCRY_FORMAT, password, user.getSalt());
- if (!encryPwd.equals(user.getPassword())) {
- pwdErrorCount = inputErrorPwd(user.getUserRecord());
- return error("您输入的账号或密码有误").addAttribute("errorCount", pwdErrorCount);
- }
- // 校验密码强度,如果和存储的不同,则保存
- int strength = PasswordLevelUtils.checkPasswordLevel(password).getValue();
- if (strength != user.getPasswordLevel()) {
- user.setPasswordLevel(strength);
- userService.save(user);
- }
- return success(login(user.getUserUU(), appId, spaceUU, returnUrl));
- }
- /**
- * 根据企业uu号和用户uu号获取登录token,有效期1分钟
- * @param enUU 企业uu号
- * @param userUU 用户uu号
- * @return tokenId,token存入ModelMap对象,值为 {userUU:用户uu号,spaceUU:企业uu号}
- */
- @RequestMapping(value = "/getToken", method = RequestMethod.GET)
- public ModelMap getToken(String enUU, String userUU, @RequestParam String appId) {
- ModelMap data = new ModelMap();
- if (enUU == null || userUU == null) {
- return error("参数错误");
- }
- // 根据企业uu号找到企业信息
- Userspace userspace = userspaceService.findOne(Long.valueOf(enUU));
- if (userspace == null) {
- return error(new ModelMap("hasUserSpace", false));
- }
- // 校验请求
- checkRequest(userspace.getAccessSecret());
- // 将企业信息、企业管理员信息写入SystemSession
- User user = userService.findOne(Long.valueOf(userUU));
- if (user == null) {
- return error(new ModelMap("hasUser", false));
- }
- if (!userspace.getUsers().contains(user)) {
- userService.bindUserspace(appId, user.getUserUU(), userspace.getSpaceUU());
- }
- data.put("spaceUU", enUU);
- data.put("userUU", userUU);
- // token有效期,单位秒
- int expires_in = 1 * 60;
- Token token = new Token(data, expires_in);
- tokenService.save(token);
- return success(token.getId());
- }
- /**
- * token代理页面
- * @return
- */
- @RequestMapping(value = "/proxy", method = RequestMethod.GET)
- public ModelAndView loginProxyByToken() {
- WafRequestWrapper wr = new WafRequestWrapper(request);
- String returnUrl = wr.getParameter("returnURL");
- String appId = wr.getParameter("appId");
- String token = wr.getParameter("token");
- String baseUrl = wr.getParameter("baseURL");
- String isLoginAll = wr.getParameter("isLoginAll");
- ModelMap data = new ModelMap();
- data.put("returnUrl", returnUrl);
- data.put("appId", appId);
- data.put("token", token);
- data.put("baseUrl", baseUrl);
- data.put("isLoginAll", isLoginAll == null ? true : isLoginAll);
- return new ModelAndView("/sso/proxyByToken", data);
- }
- /**
- * erp和uu互联跳转
- * 代理登录,根据tokenId拿到当前用户登录的用户uu号和企业uu号进行登录
- *
- * @param token tokenId
- * @param appId 应用id
- * @param returnUrl 跳转页面
- * @param baseUrl 而外登录接口
- * @return
- */
- @RequestMapping(value = "/proxy", method = RequestMethod.POST)
- public ModelMap loginProxyByToken(String token, String appId, String returnUrl, String baseUrl) {
- Token tk = tokenService.findOne(token);
- if (null != tk) {
- JSONObject data = JSON.parseObject(JSON.toJSONString(tk.getBind()));
- Long userUU = data.getLong("userUU");
- Long spaceUU = data.getLong("spaceUU");
- request.getSession().setAttribute("baseUrl", baseUrl);
- App app = appService.findOne(appId);
- if (app != null) {
- app = StringUtils.isEmpty(app.getUserControl()) ? app : appService.findOne(app.getUserControl());
- }
- if (app == null) {
- app = appService.findOne(AccountConfig.ACCOUNT_CENTER);
- }
- UserAccount userAccount = userAccountService.findOneByUserUU(app.getUid(), userUU, spaceUU);
- if (userAccount == null) {
- return success(new ModelMap("returnUrl", HttpUtil.decodeURL(returnUrl)));
- }
- return success(loginByUser(userAccount, returnUrl, true));
- }
- return success(new ModelMap("returnUrl", HttpUtil.decodeURL(returnUrl)));
- }
- /**
- * uu互联代理登录
- * @param token tokenId
- * @param appId 登录应用应用id
- * @param spaceUU 企业uu号
- * @param returnUrl 跳转页面
- * @return
- */
- @RequestMapping(value = "/mobile/proxy", method = RequestMethod.POST)
- public ModelMap loginProxyByToken(String token, @RequestParam(defaultValue = "sso") String appId, Long spaceUU, String returnUrl, String baseUrl) {
- Token tk = tokenService.findOne(token);
- if (tk == null) {
- return success(new ModelMap("returnUrl", HttpUtil.decodeURL(returnUrl)));
- }
- App app = appService.findOne(appId);
- baseUrl = StringUtils.isEmpty(baseUrl) ? app.getLoginUrl() : baseUrl;
- request.getSession().setAttribute("baseUrl", baseUrl);
- ModelMap modelMap = (ModelMap) tk.getBind();
- Long userUU = (Long) modelMap.get("userUU");
- if (modelMap.containsKey("spaceUU")) {
- spaceUU = (Long) modelMap.get("spaceUU");
- }
- if (app != null) {
- app = StringUtils.isEmpty(app.getUserControl()) ? app : appService.findOne(app.getUserControl());
- }
- if (app == null) {
- app = appService.findOne(AccountConfig.ACCOUNT_CENTER);
- }
- UserAccount userAccount = userAccountService.findOneByUserUU(app.getUid(), userUU, spaceUU);
- if (userAccount == null) {
- List<UserAccount> userAccounts = userAccountService.findByUserUU(app.getUid(), userUU);
- return success(getSpaceSelect(userAccounts, false));
- }
- return success(loginByUser(userAccount, returnUrl, false));
- }
- /**
- * uu互联更新token
- * @param token tokenId
- * @return 新token
- */
- @RequestMapping(value = "/updateToken", method = RequestMethod.GET)
- public ModelMap updateToken(String token) {
- Token oldToken = tokenService.findOne(token);
- oldToken.setExpires_in(7*24*60*60);
- tokenService.save(oldToken);
- return success(token);
- }
- @RequestMapping(value = "/mobile", method = RequestMethod.POST)
- public ModelMap getAllAccount(@RequestParam String mobile, String password) {
- User user = userService.findByMobile(mobile);
- List<ModelMap> allowedList = new ArrayList<ModelMap>();
- if (user == null) {
- return error("未找到用户信息");
- }
- // 校验密码
- userService.checkPasswordByMobile(mobile, password, false);
- userService.resetErrorCount(user.getUserUU());
- Long userUU = user.getUserUU();
- String userName = user.getVipName();
- List<ModelMap> spaces = new ArrayList<ModelMap>();
- Long imId = user.getImId() == null ? null : Long.valueOf(user.getImId());
- App b2b = appService.findOne("b2b");
- App uas = appService.findOne("uas");
- for (Userspace userspace : user.getUserSpaces()) {
- ModelMap space = new ModelMap();
- space.put("enuu", userspace.getSpaceUU());
- space.put("name", userspace.getSpaceName());
- space.put("businessCode", userspace.getBusinessCode());
- spaces.add(space);
- if (!StringUtils.isEmpty(userspace.getWebsite())) {
- ModelMap map = new ModelMap("platform", "ERP");
- map.put("account", user.getUserUU());
- map.put("master", "");
- map.put("name", userspace.getSpaceName());
- map.put("enuu", userspace.getSpaceUU());
- map.put("masterId", "");
- map.put("website", userspace.getWebsite()
- + (userspace.getWebsite() != null && !userspace.getWebsite().endsWith("/") ? "/" : ""));
- map.put("imid", imId);
- map.put("birthday", user.getBirthday());
- map.put("sex", user.getSex());
- map.put("businessCode", userspace.getBusinessCode());
- allowedList.add(map);
- }
- }
- Token token = new Token(new ModelMap("userUU", userUU), 7*24*60*60);
- tokenService.save(token);
- allowedList.add(new ModelMap("account", userUU).addAttribute("platform", "B2B").addAttribute("imid", imId).addAttribute("spaces", spaces).addAttribute("userName", userName));
- return new ModelMap("token", token.getId()).addAttribute("datalist", allowedList);
- }
- /**
- * 密码输错处理
- *
- * @param userRecord 用户登录记录
- * @return
- */
- private int inputErrorPwd(UserRecord userRecord) {
- // 密码输错次数+1
- int pwdErrorCount = userRecord.getPwdErrorCount();
- userRecord.setPwdErrorCount(++pwdErrorCount);
- userService.save(userRecord);
- // 设置返回值
- return pwdErrorCount;
- }
- /**
- * 根据用户名获得用户账号信息
- *
- * @param appId 应用
- * @param username 用户名
- * @return
- */
- private List<UserAccount> getUserAccountByUserName(String appId, String username) {
- String type = AccountTypeUtils.getAccountType(username);
- if (AccountTypeUtils.MOBILE.equals(type)) {
- // 手机号登录
- return userAccountService.findByMobile(appId, username);
- }
- if (AccountTypeUtils.EMAIL.equals(type)) {
- // 邮箱登录
- return userAccountService.findByEmail(appId, username);
- }
- if (AccountTypeUtils.UU_NUMBER.equals(type)) {
- // uu号登录
- return userAccountService.findByUserUU(appId, Long.valueOf(username));
- }
- // 其余情况
- return null;
- }
- /**
- * 根据用户名和企业uu找到用户信息
- *
- * @param appId 应用
- * @param username 用户名
- * @param spaceUU 企业uu号
- * @return
- */
- private UserAccount getUserAccountByUserName(String appId, String username, String spaceUU) {
- String type = AccountTypeUtils.getAccountType(username);
- if (AccountTypeUtils.MOBILE.equals(type)) {
- // 手机号登录
- return userAccountService.findOneByMobile(appId, username, Long.valueOf(spaceUU));
- }
- if (AccountTypeUtils.EMAIL.equals(type)) {
- // 邮箱登录
- return userAccountService.findOneByEmail(appId, username, Long.valueOf(spaceUU));
- }
- if (AccountTypeUtils.UU_NUMBER.equals(type)) {
- // uu号登录
- return userAccountService.findOneByUserUU(appId, Long.valueOf(username), Long.valueOf(spaceUU));
- }
- // 其余情况
- return null;
- }
- /**
- * 用户信息没问题,直接登录
- *
- * @param userAccount 用户账号信息
- * @param returnUrl 跳转url
- * @param isLoginAll 是否登录默认应用
- * @return
- */
- private ModelMap loginByUser(UserAccount userAccount, String returnUrl, boolean isLoginAll) {
- /*
- * 设置登录 Cookie 最后一个参数 true 时添加 cookie 同时销毁当前 JSESSIONID
- * 创建信任的 JSESSIONID
- */
- String baseUrl = (String) request.getSession().getAttribute("baseUrl");
- baseUrl = HttpUtil.decodeURL(baseUrl);
- SSOToken st = new SSOToken(request, userAccount.getMobile());
- st.setData(JSON.toJSONString(userAccount));
- SSOHelper.setSSOCookie(request, response, st, true);
- // 设置登录时间,并将密码输错次数设为0,为空则不设置
- UserRecord userRecord = new UserRecord(userAccount.getUserUU());
- userRecord.setLastLoginTime(System.currentTimeMillis());
- userService.save(userRecord);
- // 设置返回值,通知各个应用用户已经登录
- ModelMap data = new ModelMap();
- data = addOtherAppRequestData(userAccount, data, baseUrl, isLoginAll);
- data.put("returnUrl", HttpUtil.decodeURL(returnUrl));
- return data;
- }
- private ModelMap addOtherAppRequestData(UserAccount userAccount, ModelMap data, Object loginUrl,
- boolean isLoginAll) {
- List<App> apps = appService.findAll();
- List<String> loginUrls = new ArrayList<>();
- boolean hasLoginUrl = false;
- if (isLoginAll) {
- for (App app : apps) {
- if (StringUtils.isEmpty(app.getLoginUrl())) {
- continue;
- }
- if (app.getLoginUrl().equals(loginUrl)) {
- hasLoginUrl = true;
- }
- loginUrls.add(app.getLoginUrl());
- }
- }
- // 添加baseUrl
- if (!hasLoginUrl && !StringUtils.isEmpty(loginUrl)) {
- loginUrls.add(loginUrl.toString());
- }
- data.put("loginUrls", loginUrls);
- data.put("currentUrl", loginUrl);
- // 添加传递数据
- JSONObject jsonObject = JSON.parseObject(JSON.toJSONString(userAccount));
- Integer maxage = (Integer) request.getAttribute(SSOConfig.SSO_COOKIE_MAXAGE);
- jsonObject.put("maxage", maxage);
- data.put("data", jsonObject);
- return data;
- }
- /**
- * 获取选择企业信息(id:企业uu号,name:名称)
- *
- * @param userAccounts 用户账户信息
- * @param personalEnable 该应用是否允许个人账户
- * @return
- */
- private ModelMap getSpaceSelect(List<UserAccount> userAccounts, boolean personalEnable) {
- List<Map<String, Object>> spaces = new ArrayList<Map<String, Object>>();
- Map<String, Object> space = null;
- // 设置带企业账号
- for (UserAccount userAccount : userAccounts) {
- space = new HashMap<String, Object>(2);
- space.put("id", userAccount.getSpaceUU());
- space.put("name", userAccount.getSpaceName());
- spaces.add(space);
- }
- // 设置个人账号
- if (personalEnable) {
- space = new HashMap<String, Object>(2);
- space.put("id", Const.SPACEUU_PERSONAL);
- space.put("name", String.format("%s(个人)", userAccounts.get(0).getVipName()));
- spaces.add(space);
- }
- return new ModelMap("spaces", spaces);
- }
- @RequestMapping(value = "/checkCode", method = RequestMethod.GET)
- public void checkCode() {
- try {
- // 获取验证码
- CaptchaUtil.outputCaptcha(request, response, LOGIN_CAPTCHA);
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- /**
- * 获得密码输错次数
- *
- * @param username 用户名
- * @return
- */
- @RequestMapping(value = "/getPwdErrorCount", method = RequestMethod.GET)
- public ModelMap getPwdErrorCount(String username) {
- if (StringUtils.isEmpty(username)) {
- return error("用户名不能为空");
- }
- return success(userService.getPwdErrorCount(username.trim()));
- }
- /**
- * 退出接口,测试接口
- * @return
- */
- @RequestMapping(value = "/logoutAccount", method = RequestMethod.GET)
- public ModelMap logoutAccount() {
- SSOHelper.clearLogin(request, response);
- return success();
- }
- /**
- * 判断是否登录, 测试接口
- * @return
- */
- @RequestMapping(value = "/isLogin", method = RequestMethod.GET)
- public ModelMap isLogin() {
- SSOToken token = SSOHelper.getToken(request);
- return success(new ModelMap("isLogin", token != null));
- }
- /**
- * 页面样式
- * @param appId 应用id
- * @return
- */
- @RequestMapping(value = "/page/style", method = RequestMethod.GET)
- public ModelMap getPageStyle(@RequestParam(defaultValue = "sso") String appId) {
- App app = appService.findOne(appId);
- App defaultApp = appService.findOne("sso");
- PageStyle pageStyle = app == null ? defaultApp.getPageStyle() : app.getPageStyle();
- if (pageStyle != null) {
- BeanUtil.copyProperties(pageStyle, defaultApp.getPageStyle(), true);
- }
- return success(defaultApp.getPageStyle());
- }
- /**
- * 跨域询问,回复子系统是否登录
- *
- * @throws IOException
- */
- @RequestMapping("/ask")
- public void replyAsk() throws IOException {
- String callback = request.getParameter("callback");
- SSOToken token = SSOHelper.getToken(request);
- if (token != null) {
- String askData = request.getParameter("askData");
- if (!StringUtils.isEmpty(askData)) {
- // 下面开始验证票据,签名新的票据每一步都必须有。
- AuthToken at = SSOHelper.replyCiphertext(request, askData);
- if (at != null) {
- App app = appService.findOne(at.getApp());
- if (app != null && StringUtils.isEmpty(app.getPublicKey()) && !StringUtils.isEmpty(app.getUserControl())) {
- app = appService.findOne(app.getUserControl());
- }
- if (app == null) {
- printJsonP(callback, error("403", "非法签名"));
- return;
- }
- // 对应系统公钥验证签名
- at = at.verify(app.getPublicKey());
- if (at != null) {
- at.setUid(token.getUid());// 设置绑定用户ID
- at.setTime(token.getTime());// 设置登录时间
- // 更安全的做法是使用at.getUuid() 作为 key 设置 authToken
- // 至分布式缓存中,然后 这里根据UUID验证和赋值
- at.setData(token.getData());
- // 2、SSO 的私钥签名
- at.sign(SSOConfig.getInstance().getCenterPrivateKey());
- // 3、生成回复密文票据
- printJsonP(callback, success(at.encryptAuthToken()));
- } else {
- // 非法签名, 可以重定向至无权限界面,App自己处理
- printJsonP(callback, error("403", "非法签名"));
- }
- } else {
- // 非法签名, 可以重定向至无权限界面,App自己处理
- printJsonP(callback, error("403", "非法签名"));
- }
- }
- } else {
- // 未登录
- printJsonP(callback, error("404", "未登录"));
- }
- }
- /**
- * 跨域切换企业
- * @param spaceUU 企业uu号
- * @throws IOException
- */
- @RequestMapping(value = "/change/userspace", method = RequestMethod.GET)
- @ResponseBody
- public void changeUserSpace(Long spaceUU) throws IOException {
- String callback = request.getParameter("callback");
- response.setContentType("text/html;charset=UTF-8");
- SSOToken token = SSOHelper.getToken(request);
- if (token != null) {
- SSOToken st = SSOHelper.getToken(request);
- UserAccount user = JSON.parseObject(st.getData(), UserAccount.class);
- user = userAccountService.findOneByUserUU(user.getAppId(), user.getUserUU(), spaceUU);
- if (user == null) {
- printJsonP(callback, error("403", "切换账号失败"));
- }
- st.setData(JSON.toJSONString(user));
- SSOHelper.setSSOCookie(request, response, st, true);
- printJsonP(callback, success());
- } else {
- // 未登录
- printJsonP(callback, error("404", "未登录"));
- }
- }
- /**
- * 发送手机验证码
- * @param mobile 手机号
- * @return
- */
- @RequestMapping(value = "/sendSmsCode", method = RequestMethod.GET)
- public ModelMap sendSmsCode(String mobile) {
- Assert.hasText(mobile, "手机号不能为空");
- mobile = StringUtils.trimAllWhitespace(mobile);
- // 校验手机号是否被注册
- boolean hasRegister = userService.mobileHasRegistered(mobile);
- if (!hasRegister) {
- return error("该手机号未注册,请先注册");
- }
- // 随机获得验证码
- String code = StringUtil.getRandomNumber(6);
- Token token = new Token(code, 10 * 60);
- System.out.println(code);
- // 设置绑定手机,防止获取验证码之后修改手机号
- token.setMobile(mobile);
- tokenService.save(token);
- // 发送短信
- MessageUtils.sendSms("templateForSendSmsWhenLogin", mobile, code);
- // 返回tokenId
- ModelMap returnData = new ModelMap();
- returnData.put("token", token.getId());
- return success(returnData);
- }
- /**
- * 根据手机号验证码登录
- * @return
- */
- @RequestMapping(value = "/sms", method = RequestMethod.POST)
- public ModelMap loginBySms(String code, String token) {
- // 获取登录信息
- WafRequestWrapper wr = new WafRequestWrapper(request);
- String appId = wr.getParameter("appId");
- String spaceUU = wr.getParameter("spaceUU");
- String mobile = StringUtils.trimAllWhitespace(wr.getParameter("mobile"));
- String returnUrl = wr.getParameter("returnUrl");
- String baseUrl = wr.getParameter("baseUrl");
- appId = StringUtils.isEmpty(appId) ? AccountConfig.ACCOUNT_CENTER : appId;
- // 校验手机号是否被注册
- boolean hasRegister = userService.mobileHasRegistered(mobile);
- if (!hasRegister) {
- return error("该手机号未注册,请先注册");
- }
- // 设置baseUrl
- if (!StringUtils.isEmpty(baseUrl)) {
- request.getSession().setAttribute("baseUrl", baseUrl);
- }
- // 校验token
- Assert.hasText(token, "请先获取验证码");
- Token existToken = tokenService.findOne(token);
- if (existToken == null || existToken.isExpired()) {
- return error("验证码已过期,请重新获取");
- }
- if (!StringUtils.isEmpty(existToken.getMobile()) && !existToken.getMobile().equals(mobile)) {
- return error("手机号被修改,请重新获取验证码");
- }
- if (StringUtils.isEmpty(code) || !code.equals(existToken.getBind())) {
- return error("验证码错误");
- }
- // 获取登录用户
- User user = userService.findByMobile(mobile);
- if (user == null) {
- return error("该手机号未注册");
- }
- return success(login(user.getUserUU(), appId, spaceUU, returnUrl));
- }
- /**
- * 登录处理
- * @param userUU 用户uu号
- * @param appId 应用id
- * @param spaceUU 企业uu号
- * @param returnUrl 跳转地址
- * @return
- */
- private ModelMap login(Long userUU, String appId, String spaceUU, String returnUrl) {
- // 登录
- appId = StringUtils.isEmpty(appId) ? AccountConfig.ACCOUNT_CENTER : appId;
- App app = appService.findOne(appId);
- if (app == null) {
- throw new VerifyError("应用不存在");
- }
- App controlApp = StringUtils.isEmpty(app.getUserControl()) ? app : appService.findOne(app.getUserControl());
- boolean personalEnable = Const.YES == controlApp.getPersonalEnable();
- if (StringUtils.isEmpty(spaceUU)) {
- /*企业uu号为空,让用户选择企业*/
- // 找到用户账号信息
- List<UserAccount> userAccounts = userAccountService.findByUserUU(controlApp.getUid(), userUU);
- // 没有记录
- if (CollectionUtils.isEmpty(userAccounts)) {
- // 没有记录如果当前应用允许个人账号的话,查找个人账号
- UserAccount userAccount = personalAccountService.findOneByUserUU(controlApp.getUid(), userUU);
- if (!personalEnable) {
- // 不支持个人账号则跳转优软云
- returnUrl = HOME_PAGE;
- }
- return loginByUser(userAccount, returnUrl, true);
- }
- // 应用允许个人账号,并且账号未绑定企业,或者只绑定了一个企业,直接登录
- if (userAccounts.size() == 1) {
- return loginByUser(userAccounts.get(0), returnUrl, true);
- }
- // 返回企业id和名称
- return getSpaceSelect(userAccounts, personalEnable);
- } else if (personalEnable && Long.valueOf(spaceUU).equals(Const.SPACEUU_PERSONAL)) {
- // 使用个人账号登录
- UserAccount userAccount = personalAccountService.findOneByUserUU(controlApp.getUid(), userUU);
- return loginByUser(userAccount, returnUrl, true);
- } else {
- // 带企业登录
- UserAccount userAccount = userAccountService.findOneByUserUU(controlApp.getUid(), userUU, Long.valueOf(spaceUU));
- return loginByUser(userAccount, returnUrl, true);
- }
- }
- /**
- * 微信获取code
- * @param code 获取用户信息的code
- * @param state 验证请求
- * @return
- */
- @RequestMapping(value = "/wxqrLogin", method = RequestMethod.POST)
- public ModelMap wxqrLogin(String code, String state) {
- // TODO 校验state
- // 获取用户信息
- OAuthInfo oAuthInfo = weChatService.getOAuthInfoByCode(code);
- User user = null;
- if (oAuthInfo == null || StringUtils.isEmpty(oAuthInfo.getAccess_token())) {
- Long userUU = (Long) request.getSession().getAttribute("userUU");
- if (userUU == null) {
- return error("验证信息过期,请重新扫码登录");
- }
- user = new User(userUU);
- } else {
- user = userService.findByWxUnionid(oAuthInfo.getUnionid());
- if (user == null) {
- // 提示前端用户微信未绑定账号
- Token token = new Token(oAuthInfo.getUnionid(), oAuthInfo.getExpires_in());
- ModelMap data = new ModelMap("hasRegister", false);
- data.put("token", token.getId());
- return success(data);
- }
- request.getSession().setAttribute("userUU", user.getUserUU());
- }
- // 登录
- WafRequestWrapper wr = new WafRequestWrapper(request);
- String appId = wr.getParameter("appId");
- String spaceUU = wr.getParameter("spaceUU");
- String returnUrl = wr.getParameter("returnUrl");
- String baseUrl = wr.getParameter("baseUrl");
- request.getSession().setAttribute("baseUrl", baseUrl);
- return success(login(user.getUserUU(), appId, spaceUU, returnUrl));
- }
- }
|