|  | @ -0,0 +1,564 @@
 | 
	
		
			
				|  |  | package com.yihu.wlyy.web.common.account;
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | import com.yihu.wlyy.entity.login.LoginLog;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.entity.patient.Patient;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.entity.patient.SocialSecurityInfo;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.entity.security.Token;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.logs.BusinessLogs;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.repository.patient.PatientDao;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.repository.patient.SocialSecurityInfoDao;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.service.app.family.FamilyMemberService;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.service.app.family.FamilyService;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.service.common.SMSService;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.service.common.account.AccessTokenService;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.service.common.account.PatientService;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.service.common.account.TokenService;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.service.common.login.LoginLogService;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.task.PushMsgTask;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.util.HttpUtil;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.util.IdcardValidator;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.util.MD5;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.util.RSAUtils;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.web.WeixinBaseController;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.wechat.util.WeiXinOpenIdUtils;
 | 
	
		
			
				|  |  | import com.yihu.wlyy.wechat.util.WeiXinTagUtil;
 | 
	
		
			
				|  |  | import io.swagger.annotations.Api;
 | 
	
		
			
				|  |  | import org.apache.commons.lang3.StringUtils;
 | 
	
		
			
				|  |  | import org.json.JSONObject;
 | 
	
		
			
				|  |  | import org.springframework.beans.factory.annotation.Autowired;
 | 
	
		
			
				|  |  | import org.springframework.http.MediaType;
 | 
	
		
			
				|  |  | import org.springframework.stereotype.Controller;
 | 
	
		
			
				|  |  | import org.springframework.web.bind.annotation.RequestMapping;
 | 
	
		
			
				|  |  | import org.springframework.web.bind.annotation.RequestMethod;
 | 
	
		
			
				|  |  | import org.springframework.web.bind.annotation.RequestParam;
 | 
	
		
			
				|  |  | import org.springframework.web.bind.annotation.ResponseBody;
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | import java.net.URLDecoder;
 | 
	
		
			
				|  |  | import java.util.*;
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | /**
 | 
	
		
			
				|  |  |  * @author calvin
 | 
	
		
			
				|  |  |  */
 | 
	
		
			
				|  |  | @Controller
 | 
	
		
			
				|  |  | @RequestMapping(value = "/weixin", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
 | 
	
		
			
				|  |  | @Api(description = "微信端用户注册")
 | 
	
		
			
				|  |  | public class WechatController extends WeixinBaseController {
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private PatientService patientService;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private TokenService tokenService;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private SMSService smsService;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private SocialSecurityInfoDao socialSecurityInfoDao;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private PatientDao patientDao;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private FamilyService familyService;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private LoginLogService loginLogService;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private FamilyMemberService familyMemberService;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     WeiXinOpenIdUtils weiXinOpenIdUtils;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     AccessTokenService accessTokenService;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     HttpUtil HttpUtil;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private PushMsgTask pushMsgTask;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private WeiXinTagUtil weiXinTagUtil;
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 获取验证码发送的手机号码
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param idCard
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     @RequestMapping(value = "getMobile", method = RequestMethod.POST)
 | 
	
		
			
				|  |  |     @ResponseBody
 | 
	
		
			
				|  |  |     public String getPatientInfoByIdCard(@RequestParam(value = "idCard", required = true) String idCard) {
 | 
	
		
			
				|  |  |         Patient temp = patientService.findByIdcard(idCard);
 | 
	
		
			
				|  |  |         getAccessToken();
 | 
	
		
			
				|  |  |         if (temp == null) {
 | 
	
		
			
				|  |  |             return error(-1, "用户未注册");
 | 
	
		
			
				|  |  |         } else {
 | 
	
		
			
				|  |  |             if (StringUtils.isBlank(temp.getMobile())) {
 | 
	
		
			
				|  |  |                 return error(-2, "用户未绑定手机号");
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 JSONObject object = new JSONObject();
 | 
	
		
			
				|  |  |                 object.put("mobile", temp.getMobile());
 | 
	
		
			
				|  |  |                 return write(200, "获取成功", "data", object);
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 注册信息验证
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param name   姓名
 | 
	
		
			
				|  |  |      * @param idcard 身份证号
 | 
	
		
			
				|  |  |      * @param ssc    社保卡号
 | 
	
		
			
				|  |  |      * @param mobile 手机号
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     @RequestMapping(value = "/check_regist_info", method = RequestMethod.POST)
 | 
	
		
			
				|  |  |     @ResponseBody
 | 
	
		
			
				|  |  |     public String checkRegistInfo(String name, String idcard, String ssc, String mobile) {
 | 
	
		
			
				|  |  |         try {
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(name)) {
 | 
	
		
			
				|  |  |                 return error(-1, "姓名不允许为空");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(idcard)) {
 | 
	
		
			
				|  |  |                 return error(-1, "身份证号不允许为空");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(ssc)) {
 | 
	
		
			
				|  |  |                 return error(-1, "社保卡号不允许为空");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(mobile)) {
 | 
	
		
			
				|  |  |                 return error(-1, "手机号不允许为空");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             //if (patientService.findByMobile(mobile) != null) {
 | 
	
		
			
				|  |  |             //    return error(-1, "该手机号已被注册");
 | 
	
		
			
				|  |  |             //}
 | 
	
		
			
				|  |  |             // 解密身份证号
 | 
	
		
			
				|  |  |             idcard = RSAUtils.getInstance(patientService).decryptString(idcard);
 | 
	
		
			
				|  |  |             idcard = URLDecoder.decode(idcard, "UTF-8");
 | 
	
		
			
				|  |  |             idcard = StringUtils.reverse(idcard);
 | 
	
		
			
				|  |  |             // 校验身份证号
 | 
	
		
			
				|  |  |             IdcardValidator validator = new IdcardValidator();
 | 
	
		
			
				|  |  |             if (validator.isValidatedAllIdcard(idcard)) {
 | 
	
		
			
				|  |  |                 if (idcard.length() == 15) {
 | 
	
		
			
				|  |  |                     idcard = validator.convertIdcarBy15bit(idcard);
 | 
	
		
			
				|  |  |                     if (StringUtils.isEmpty(idcard)) {
 | 
	
		
			
				|  |  |                         return error(-1, "请输入正确的身份证号");
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 return error(-1, "请输入正确的身份证号");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             SocialSecurityInfo socialSecurityInfo = socialSecurityInfoDao.findBySfzh18Max(idcard);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             if (socialSecurityInfo != null) {
 | 
	
		
			
				|  |  |                 if (name.compareTo(socialSecurityInfo.getXming0() == null ? "" : socialSecurityInfo.getXming0()) != 0) {
 | 
	
		
			
				|  |  |                     return error(-1, "身份证号与姓名不一致,请检查后重新输入");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 if (ssc.compareTo(socialSecurityInfo.getCardno() == null ? "" : socialSecurityInfo.getCardno()) != 0 && ssc.compareTo(socialSecurityInfo.getCard16() == null ? "" : socialSecurityInfo.getCard16()) != 0) {
 | 
	
		
			
				|  |  |                     return error(-1, "身份证号与医保卡号不一致,请检查后重新输入");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 return error(-1, "对不起,暂不支持16年6月份之后办理的医保卡注册");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             Patient patient = patientDao.findByIdcard(idcard);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             if (patient != null) {
 | 
	
		
			
				|  |  |                 if (!StringUtils.isEmpty(patient.getMobile())) {
 | 
	
		
			
				|  |  |                     return error(-2, "该身份证已被注册");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             return write(200, "验证成功");
 | 
	
		
			
				|  |  |         } catch (Exception e) {
 | 
	
		
			
				|  |  |             return error(-1, "验证失败");
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 患者注册
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param idcard  身份證號
 | 
	
		
			
				|  |  |      * @param mobile  登录手机号
 | 
	
		
			
				|  |  |      * @param captcha 手机验证码
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     @RequestMapping(value = "regist", method = RequestMethod.POST)
 | 
	
		
			
				|  |  |     @ResponseBody
 | 
	
		
			
				|  |  |     public String regist(@RequestParam(value = "name", required = true) String name,
 | 
	
		
			
				|  |  |                          @RequestParam(value = "idcard", required = true) String idcard,
 | 
	
		
			
				|  |  |                          @RequestParam(value = "ssc", required = true) String ssc,
 | 
	
		
			
				|  |  |                          @RequestParam(value = "mobile", required = true) String mobile,
 | 
	
		
			
				|  |  |                          @RequestParam(value = "captcha", required = true) String captcha,
 | 
	
		
			
				|  |  |                          @RequestParam(value = "openid", required = true) String openid,
 | 
	
		
			
				|  |  |                          @RequestParam(value = "password", required = true) String password) {
 | 
	
		
			
				|  |  |         try {
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(name)) {
 | 
	
		
			
				|  |  |                 return error(-1, "姓名不允许为空!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(idcard)) {
 | 
	
		
			
				|  |  |                 return error(-1, "身份证号不允许为空!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(ssc)) {
 | 
	
		
			
				|  |  |                 return error(-1, "社保卡号不允许为空!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             if (StringUtils.isEmpty(mobile)) {
 | 
	
		
			
				|  |  |                 return error(-1, "手机号不允许为空!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             //if (patientService.findByMobile(mobile) != null) {
 | 
	
		
			
				|  |  |             //    return error(-1, "该手机号已被注册!");
 | 
	
		
			
				|  |  |             //}
 | 
	
		
			
				|  |  |             // 对验证码进行校验
 | 
	
		
			
				|  |  |             int res = smsService.check(mobile, 1, captcha);
 | 
	
		
			
				|  |  |             switch (res) {
 | 
	
		
			
				|  |  |                 case -2:
 | 
	
		
			
				|  |  |                     return error(-1, "验证码已过期!");
 | 
	
		
			
				|  |  |                 case -1:
 | 
	
		
			
				|  |  |                     return error(-1, "请输入正确的验证码!");
 | 
	
		
			
				|  |  |                 case 0:
 | 
	
		
			
				|  |  |                     return error(-1, "验证码无效!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             // 未绑定openid,查询是否绑定其他账号
 | 
	
		
			
				|  |  | //			if (patientService.countByOpenid(openid) > 0) {
 | 
	
		
			
				|  |  | //				return error(-1, "该微信号已绑定其他手机号!");
 | 
	
		
			
				|  |  | //			}
 | 
	
		
			
				|  |  |             // 解密身份证号
 | 
	
		
			
				|  |  |             idcard = RSAUtils.getInstance(patientService).decryptString(idcard);
 | 
	
		
			
				|  |  |             idcard = URLDecoder.decode(idcard, "UTF-8");
 | 
	
		
			
				|  |  |             idcard = StringUtils.reverse(idcard);
 | 
	
		
			
				|  |  |             // 校验身份证号
 | 
	
		
			
				|  |  |             IdcardValidator validator = new IdcardValidator();
 | 
	
		
			
				|  |  |             if (validator.isValidatedAllIdcard(idcard)) {
 | 
	
		
			
				|  |  |                 if (idcard.length() == 15) {
 | 
	
		
			
				|  |  |                     idcard = validator.convertIdcarBy15bit(idcard);
 | 
	
		
			
				|  |  |                     if (StringUtils.isEmpty(idcard)) {
 | 
	
		
			
				|  |  |                         return error(-1, "请输入正确的身份证号!");
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 return error(-1, "请输入正确的身份证号!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             SocialSecurityInfo socialSecurityInfo = socialSecurityInfoDao.findBySfzh18Max(idcard);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             if (socialSecurityInfo != null) {
 | 
	
		
			
				|  |  |                 if (name.compareTo(socialSecurityInfo.getXming0() == null ? "" : socialSecurityInfo.getXming0()) != 0) {
 | 
	
		
			
				|  |  |                     return error(-1, "身份证号与姓名不一致<br/>请检查后重新输入");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 if (ssc.compareTo(socialSecurityInfo.getCardno() == null ? "" : socialSecurityInfo.getCardno()) != 0) {
 | 
	
		
			
				|  |  |                     if (ssc.compareTo(socialSecurityInfo.getCard16() == null ? "" : socialSecurityInfo.getCard16()) != 0) {
 | 
	
		
			
				|  |  |                         return error(-1, "身份证号与医保卡号不一致,请检查后重新输入");
 | 
	
		
			
				|  |  |                     } else {
 | 
	
		
			
				|  |  |                         ssc = socialSecurityInfo.getCardno();//统一只存英文字母开头的医保卡
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 return error(-1, "对不起,暂不支持16年6月份之后办理的医保卡注册");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             Patient patient = patientDao.findByIdcard(idcard);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             if (patient == null) {
 | 
	
		
			
				|  |  |                 patient = new Patient();
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 if (!StringUtils.isEmpty(patient.getMobile())) {
 | 
	
		
			
				|  |  |                     return error(-2, "该身份证已被注册!");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             patient.setName(name);
 | 
	
		
			
				|  |  |             patient.setIdcard(idcard);
 | 
	
		
			
				|  |  |             patient.setMobile(mobile);
 | 
	
		
			
				|  |  |             //增加密码
 | 
	
		
			
				|  |  |             String salt = UUID.randomUUID().toString().replace("-", "");
 | 
	
		
			
				|  |  |             patient.setSalt(salt);
 | 
	
		
			
				|  |  |             password = RSAUtils.getInstance(patientService).decryptString(password);
 | 
	
		
			
				|  |  |             password = StringUtils.reverse(password);
 | 
	
		
			
				|  |  |             patient.setPassword(MD5.GetMD5Code(password + salt));
 | 
	
		
			
				|  |  |             patient.setSsc(ssc);
 | 
	
		
			
				|  |  |             if (!org.springframework.util.StringUtils.isEmpty(openid)) {
 | 
	
		
			
				|  |  |                 patient.setOpenid(openid);
 | 
	
		
			
				|  |  |                 patient.setOpenidTime(new Date());
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             JSONObject json = patientService.register(idcard, ssc, name, mobile, MD5.GetMD5Code(password + salt)
 | 
	
		
			
				|  |  |                     , salt, openid, 3);
 | 
	
		
			
				|  |  |             if (json != null) {
 | 
	
		
			
				|  |  |                 try {
 | 
	
		
			
				|  |  |                     Patient p = patientDao.findByIdcard(idcard);
 | 
	
		
			
				|  |  |                     BusinessLogs.info(BusinessLogs.BusinessType.register, p.getCode(), p.getCode(), new JSONObject(p));
 | 
	
		
			
				|  |  |                 } catch (Exception e) {
 | 
	
		
			
				|  |  |                     e.printStackTrace();
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 // 注册成功
 | 
	
		
			
				|  |  |                 return write(200, "注册成功!", "data", json);
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 // 注册失败
 | 
	
		
			
				|  |  |                 return error(-1, "注册失败!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |         } catch (Exception e) {
 | 
	
		
			
				|  |  |             error(e);
 | 
	
		
			
				|  |  |             return error(-1, "注册失败!");
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 患者微信登录接口
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param captcha  短信号
 | 
	
		
			
				|  |  |      * @param mobile   电话号码
 | 
	
		
			
				|  |  |      * @param password 登录密码
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     @RequestMapping(value = "login", method = RequestMethod.POST)
 | 
	
		
			
				|  |  |     @ResponseBody
 | 
	
		
			
				|  |  |     public String login(
 | 
	
		
			
				|  |  |             @RequestParam(required = false) String mobile,
 | 
	
		
			
				|  |  |             @RequestParam(required = false) String captcha,
 | 
	
		
			
				|  |  |             @RequestParam(required = false) String password,
 | 
	
		
			
				|  |  |             String openid) {
 | 
	
		
			
				|  |  |         System.out.println("login openid : " + openid);
 | 
	
		
			
				|  |  |         String errorMessage;
 | 
	
		
			
				|  |  |         LoginLog loginLog = new LoginLog();
 | 
	
		
			
				|  |  |         loginLog.setCreateTime(new Date());
 | 
	
		
			
				|  |  |         loginLog.setPhone(mobile);
 | 
	
		
			
				|  |  |         loginLog.setType("2");
 | 
	
		
			
				|  |  |         loginLog.setUserType("1");
 | 
	
		
			
				|  |  |         try {
 | 
	
		
			
				|  |  |             //账号登录 mobile可能是电话号也可能是身份证
 | 
	
		
			
				|  |  |             if (StringUtils.isNoneEmpty(mobile) && StringUtils.isNoneEmpty(password)) {
 | 
	
		
			
				|  |  |                 Patient p = patientService.findByIdcard(mobile);
 | 
	
		
			
				|  |  |                 if (p == null) {
 | 
	
		
			
				|  |  |                     List<Patient> patients = patientService.findByMobile(mobile);
 | 
	
		
			
				|  |  |                     if (patients.size() > 1) {
 | 
	
		
			
				|  |  |                         return error(-1, "此手机号码存在多个用户,请用身份证进行登录!");
 | 
	
		
			
				|  |  |                     } else if (patients.size() == 1) {
 | 
	
		
			
				|  |  |                         p = patients.get(0);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 loginLog.setLoginType("2");
 | 
	
		
			
				|  |  |                 if (p == null) {
 | 
	
		
			
				|  |  |                     if (mobile.length() == 11) {
 | 
	
		
			
				|  |  |                         errorMessage = "该手机号暂未注册账号,请确认后重新输入!";
 | 
	
		
			
				|  |  |                     } else {
 | 
	
		
			
				|  |  |                         errorMessage = "该身份证号暂未注册账号,请确认后重新输入!";
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                 } else if (p.getStatus() == 0) {
 | 
	
		
			
				|  |  |                     if (mobile.length() == 11) {
 | 
	
		
			
				|  |  |                         errorMessage = "该手机号已被禁止使用!";
 | 
	
		
			
				|  |  |                     } else {
 | 
	
		
			
				|  |  |                         errorMessage = "该身份证号已被禁止使用!";
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                 } else if (p.getStatus() == 2) {
 | 
	
		
			
				|  |  |                     errorMessage = "该账号正在审核中,请确认审核通过后再登录,“如有疑问,拨打400-6677-400转2人工客服”";
 | 
	
		
			
				|  |  |                     loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                 } else if (StringUtils.isEmpty(openid)) {
 | 
	
		
			
				|  |  |                     errorMessage = "无效的OpenID!";
 | 
	
		
			
				|  |  |                     loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 loginLog.setUserCode(p.getCode());
 | 
	
		
			
				|  |  |                 //解密
 | 
	
		
			
				|  |  |                 password = RSAUtils.getInstance(patientService).decryptString(password);
 | 
	
		
			
				|  |  |                 password = StringUtils.reverse(password);
 | 
	
		
			
				|  |  |                 //生成MD5
 | 
	
		
			
				|  |  |                 String loginPassword = MD5.GetMD5Code(password + p.getSalt());
 | 
	
		
			
				|  |  |                 //判断d登录密码是否正确
 | 
	
		
			
				|  |  |                 if (loginPassword.equals(p.getPassword())) {
 | 
	
		
			
				|  |  |                     // 绑定用户手机号和openid
 | 
	
		
			
				|  |  |                     if (!StringUtils.equals(p.getOpenid(), openid) && !"undefined".equals(openid)) {//undefined不更新数据库
 | 
	
		
			
				|  |  |                         //patient.setOpenid(openid);
 | 
	
		
			
				|  |  |                         patientService.updatePatient(p, openid);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                     // 用户校验通过,生成token
 | 
	
		
			
				|  |  |                     Token token = tokenService.newTxToken(p.getCode(), openid);
 | 
	
		
			
				|  |  |                     Map<Object, Object> map = new HashMap<Object, Object>();
 | 
	
		
			
				|  |  |                     map.put("id", p.getId());
 | 
	
		
			
				|  |  |                     map.put("uid", p.getCode());
 | 
	
		
			
				|  |  |                     map.put("name", p.getName());
 | 
	
		
			
				|  |  |                     map.put("token", token.getToken());
 | 
	
		
			
				|  |  |                     map.put("photo", p.getPhoto());
 | 
	
		
			
				|  |  |                     if (StringUtils.isNoneEmpty(openid)) {
 | 
	
		
			
				|  |  |                         //发送微信模板
 | 
	
		
			
				|  |  |                         familyService.sendWXMessage(p);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                     loginLog.setLoginType("1");
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     //判断是否打过标签
 | 
	
		
			
				|  |  |                    //if (!(Patient.isWchatTage.yes.getValue() == p.getIsWxtag())) {
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                     //给患者打微信标签
 | 
	
		
			
				|  |  |                     weiXinTagUtil.addTagWithOpenid(openid, p.getCode(), p.getName());
 | 
	
		
			
				|  |  |                     //}
 | 
	
		
			
				|  |  |                     return write(200, "登录成功", "data", map);
 | 
	
		
			
				|  |  |                 } else {
 | 
	
		
			
				|  |  |                     errorMessage = "密码错误,登录失败";
 | 
	
		
			
				|  |  |                     loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             //短信登录
 | 
	
		
			
				|  |  |             if (StringUtils.isNoneEmpty(mobile) && StringUtils.isNoneEmpty(captcha)) {
 | 
	
		
			
				|  |  |                 List<Patient> patients = patientService.findByMobile(mobile);
 | 
	
		
			
				|  |  |                 if (patients.size() > 1) {
 | 
	
		
			
				|  |  |                     return error(-1, "此手机存在多个用户,请用身份证和密码登录!");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 // 对验证码进行校验
 | 
	
		
			
				|  |  |                 int res = smsService.check(mobile, 4, captcha);
 | 
	
		
			
				|  |  |                 switch (res) {
 | 
	
		
			
				|  |  |                     case -2: {
 | 
	
		
			
				|  |  |                         errorMessage = "验证码已过期!";
 | 
	
		
			
				|  |  |                         loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                         loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                         return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     case -1: {
 | 
	
		
			
				|  |  |                         errorMessage = "请输入正确的验证码!";
 | 
	
		
			
				|  |  |                         loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                         loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                         return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     case 0: {
 | 
	
		
			
				|  |  |                         errorMessage = "验证码无效!";
 | 
	
		
			
				|  |  |                         loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                         loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                         return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                 loginLog.setLoginType("1");
 | 
	
		
			
				|  |  |                 if (patients == null || patients.size() == 0) {
 | 
	
		
			
				|  |  |                     if (mobile.length() == 11) {
 | 
	
		
			
				|  |  |                         errorMessage = "该手机号暂未注册账号,请确认后重新输入!";
 | 
	
		
			
				|  |  |                     } else {
 | 
	
		
			
				|  |  |                         errorMessage = "该身份证号暂未注册账号,请确认后重新输入!";
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                 } else {
 | 
	
		
			
				|  |  |                     Patient p = null;
 | 
	
		
			
				|  |  |                     if (patients.size() == 1) {
 | 
	
		
			
				|  |  |                         p = patients.get(0);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     if (p.getStatus() == 0) {
 | 
	
		
			
				|  |  |                         if (mobile.length() == 11) {
 | 
	
		
			
				|  |  |                             errorMessage = "该手机号已被禁止使用!";
 | 
	
		
			
				|  |  |                         } else {
 | 
	
		
			
				|  |  |                             errorMessage = "该身份证号已被禁止使用!";
 | 
	
		
			
				|  |  |                         }
 | 
	
		
			
				|  |  |                         loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                         loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                         return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                     } else if (p.getStatus() == 2) {
 | 
	
		
			
				|  |  |                         errorMessage = "该账号正在审核中,请确认审核通过后再登录,“如有疑问,拨打400-6677-400转2人工客服”";
 | 
	
		
			
				|  |  |                         loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                         loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                         return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                     } else if (StringUtils.isEmpty(openid)) {
 | 
	
		
			
				|  |  |                         errorMessage = "无效的OpenID!";
 | 
	
		
			
				|  |  |                         loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |                         loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                         return error(-1, errorMessage);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     loginLog.setUserCode(p.getCode());
 | 
	
		
			
				|  |  |                     // 绑定用户手机号和openid
 | 
	
		
			
				|  |  |                     if (!StringUtils.equals(p.getOpenid(), openid) && !"undefined".equals(openid)) {//undefined不更新数据库
 | 
	
		
			
				|  |  |                         //patient.setOpenid(openid);
 | 
	
		
			
				|  |  |                         patientService.updatePatient(p, openid);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     // 用户校验通过,生成token
 | 
	
		
			
				|  |  |                     Token token = tokenService.newTxToken(p.getCode(), openid);
 | 
	
		
			
				|  |  |                     Map<Object, Object> map = new HashMap<Object, Object>();
 | 
	
		
			
				|  |  |                     map.put("id", p.getId());
 | 
	
		
			
				|  |  |                     map.put("uid", p.getCode());
 | 
	
		
			
				|  |  |                     map.put("name", p.getName());
 | 
	
		
			
				|  |  |                     map.put("token", token.getToken());
 | 
	
		
			
				|  |  |                     map.put("photo", p.getPhoto());
 | 
	
		
			
				|  |  |                     if (StringUtils.isNoneEmpty(openid)) {
 | 
	
		
			
				|  |  |                         //发送微信模板
 | 
	
		
			
				|  |  |                         familyService.sendWXMessage(p);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     loginLog.setType("1");
 | 
	
		
			
				|  |  |                     loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |                     //判断是否打过标签
 | 
	
		
			
				|  |  |                     //if (!(Patient.isWchatTage.yes.getValue() == p.getIsWxtag())) {
 | 
	
		
			
				|  |  |                         //给患者打微信标签
 | 
	
		
			
				|  |  |                         weiXinTagUtil.addTagWithOpenid(openid, p.getCode(), p.getName());
 | 
	
		
			
				|  |  |                     //}
 | 
	
		
			
				|  |  |                     return write(200, "登录成功", "data", map);
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             return error(-1, "登录失败");
 | 
	
		
			
				|  |  |         } catch (Exception e) {
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |             errorMessage = "系统异常,登录失败";
 | 
	
		
			
				|  |  |             loginLog.setErrorMessage(errorMessage);
 | 
	
		
			
				|  |  |             loginLogService.saveLog(loginLog);
 | 
	
		
			
				|  |  |             error(e);
 | 
	
		
			
				|  |  |             return error(-1, "系统异常,登录失败");
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 获取签名signature
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param pageUrl 需要签名的页面全地址(?后的也需要除了#后的不需要)
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     @RequestMapping(value = "getSign", method = RequestMethod.POST)
 | 
	
		
			
				|  |  |     @ResponseBody
 | 
	
		
			
				|  |  |     public String getSign(String pageUrl) {
 | 
	
		
			
				|  |  |         try {
 | 
	
		
			
				|  |  |             String ticket = getJsapi_ticketByToken();
 | 
	
		
			
				|  |  |             if (ticket != null) {
 | 
	
		
			
				|  |  |                 String noncestr = UUID.randomUUID().toString();
 | 
	
		
			
				|  |  |                 long timestamp = System.currentTimeMillis() / 1000;
 | 
	
		
			
				|  |  |                 String url = pageUrl;
 | 
	
		
			
				|  |  |                 String str = "jsapi_ticket=" + ticket + "&noncestr=" + noncestr + "×tamp=" + timestamp + "&url=" + url;
 | 
	
		
			
				|  |  |                 // sha1加密
 | 
	
		
			
				|  |  |                 String signature = SHA1(str);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                 Map<Object, Object> map = new HashMap<Object, Object>();
 | 
	
		
			
				|  |  |                 map.put("noncestr", noncestr);
 | 
	
		
			
				|  |  |                 map.put("timestamp", timestamp);
 | 
	
		
			
				|  |  |                 map.put("signature", signature);
 | 
	
		
			
				|  |  |                 return write(200, "获取签名成功", "data", map);
 | 
	
		
			
				|  |  |             } else
 | 
	
		
			
				|  |  |                 return error(-1, "获取签名失败");
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |         } catch (Exception e) {
 | 
	
		
			
				|  |  |             error(e);
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         return error(-1, "获取签名失败");
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 获取微信openid
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param code
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     @RequestMapping(value = "getOpenidByCode", method = {RequestMethod.POST, RequestMethod.GET})
 | 
	
		
			
				|  |  |     @ResponseBody
 | 
	
		
			
				|  |  |     public String getOpenidByCode(String code) {
 | 
	
		
			
				|  |  |         try {
 | 
	
		
			
				|  |  |             String openid = super.getOpenidByCode(code);
 | 
	
		
			
				|  |  |             if (!StringUtils.isEmpty(openid)) {
 | 
	
		
			
				|  |  |                 return write(200, "获取openid成功!", "openid", openid);
 | 
	
		
			
				|  |  |             } else {
 | 
	
		
			
				|  |  |                 return error(-1, "获取openid失败!");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |         } catch (Exception e) {
 | 
	
		
			
				|  |  |             error(e);
 | 
	
		
			
				|  |  |             return error(-1, "获取openid失败!");
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | }
 |