|  | @ -118,10 +118,12 @@ public class WlyyUserDetailsService extends JdbcDaoSupport implements UserDetail
 | 
												
													
														
															|  |         } else if ("2".equals(loginType)) {//2.为医生账号
 |  |         } else if ("2".equals(loginType)) {//2.为医生账号
 | 
												
													
														
															|  |             //解除锁定
 |  |             //解除锁定
 | 
												
													
														
															|  |             this.getJdbcTemplate().update("update base_doctor d set d.login_failure_count = 0, d.locked = 0 where d.mobile = ? or d.idcard = ?", username, username);
 |  |             this.getJdbcTemplate().update("update base_doctor d set d.login_failure_count = 0, d.locked = 0 where d.mobile = ? or d.idcard = ?", username, username);
 | 
												
													
														
															|  |         } else if ("3".equals(loginType) || "4".equals(loginType)) { //3.患者账号
 |  | 
 | 
												
													
														
															|  | 
 |  |         } else if ("3".equals(loginType)) { //3.患者账号
 | 
												
													
														
															|  |             //解除锁定
 |  |             //解除锁定
 | 
												
													
														
															|  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 5, p.locked = 0 where p.mobile = ? or p.idcard = ?", username, username);
 |  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 5, p.locked = 0 where p.mobile = ? or p.idcard = ?", username, username);
 | 
												
													
														
															|  |         } //...
 |  | 
 | 
												
													
														
															|  | 
 |  |         } else if("4".equals(loginType)){
 | 
												
													
														
															|  | 
 |  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 5, p.locked = 0 where p.mobile = ? or p.idcard = ?", username, getIdcard());
 | 
												
													
														
															|  | 
 |  |         }//...
 | 
												
													
														
															|  |     }
 |  |     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  |     /**
 |  |     /**
 | 
												
											
												
													
														
															|  | @ -155,98 +157,175 @@ public class WlyyUserDetailsService extends JdbcDaoSupport implements UserDetail
 | 
												
													
														
															|  |                 redisTemplate.delete(BespeakRegist + username);
 |  |                 redisTemplate.delete(BespeakRegist + username);
 | 
												
													
														
															|  |             }
 |  |             }
 | 
												
													
														
															|  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_STATEMENT, new BeanPropertyRowMapper(WlyyUserDetails.class), username, username);
 |  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_STATEMENT, new BeanPropertyRowMapper(WlyyUserDetails.class), username, username);
 | 
												
													
														
															|  |             // 去i健康查询用户
 |  | 
 | 
												
													
														
															|  | 
 |  |             // 第三方同步居民,端查询用户
 | 
												
													
														
															|  |         }else if("4".equals(loginType)){
 |  |         }else if("4".equals(loginType)){
 | 
												
													
														
															|  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_IDCARD_STATEMENT, new BeanPropertyRowMapper(WlyyUserDetails.class), getIdcard());
 |  | 
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  |             if ((null == users || users.size() == 0) && "4".equals(loginType)) {
 |  | 
 | 
												
													
														
															|  |                 List<NameValuePair> params = new ArrayList<>();
 |  | 
 | 
												
													
														
															|  |                 params.add(new BasicNameValuePair("clientId", getClientId()));
 |  | 
 | 
												
													
														
															|  |                 ClientDetails clientDetails = clientDetailsService.loadClientByClientId(getClientId());
 |  | 
 | 
												
													
														
															|  |                 params.add(new BasicNameValuePair("clientSecret", clientDetails.getClientSecret()));
 |  | 
 | 
												
													
														
															|  |                 params.add(new BasicNameValuePair("code", username));
 |  | 
 | 
												
													
														
															|  |                 params.add(new BasicNameValuePair("openid", getOpenid()));
 |  | 
 | 
												
													
														
															|  |                 String res = null;
 |  | 
 | 
												
													
														
															|  |                 try{
 |  | 
 | 
												
													
														
															|  |                     res = httpClientUtil.post(iHealthUserInfoUrl, params, "UTF-8");
 |  | 
 | 
												
													
														
															|  |                 }catch (Exception e){
 |  | 
 | 
												
													
														
															|  |                     logger.error("远程请求i健康用户信息异常:" + e.getMessage());
 |  | 
 | 
												
													
														
															|  |                     return users;
 |  | 
 | 
												
													
														
															|  |                 }
 |  | 
 | 
												
													
														
															|  |                 if(null == res){
 |  | 
 | 
												
													
														
															|  |                     return users;
 |  | 
 | 
												
													
														
															|  |                 }
 |  | 
 | 
												
													
														
															|  |                 JSONObject patient = JSONObject.parseObject(res);
 |  | 
 | 
												
													
														
															|  |                 if(patient.getInteger("status") == -1){
 |  | 
 | 
												
													
														
															|  |                     logger.error("去i健康查询用户信息失败:" + patient.getString("error"));
 |  | 
 | 
												
													
														
															|  |                     return users;
 |  | 
 | 
												
													
														
															|  |                 }
 |  | 
 | 
												
													
														
															|  |                 try {
 |  | 
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  |                     String salt = randomString(5);
 |  | 
 | 
												
													
														
															|  |                     String idcard = patient.getString("idcard");
 |  | 
 | 
												
													
														
															|  |                     String pw = idcard.substring(idcard.length()-6);
 |  | 
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  |                     this.getJdbcTemplate().update(DEFAULT_PATIENT_INSERT_STATEMENT,
 |  | 
 | 
												
													
														
															|  |                             new Object[]{patient.getString("code"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("photo"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("idcard"),
 |  | 
 | 
												
													
														
															|  |                                     MD5.md5Hex(pw + "{" + salt + "}"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("salt"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("name"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getDate("birthday"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getInteger("sex"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("mobile"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("province"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("provinceName"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("city"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("cityName"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("town"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("townName"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("street"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("streetName"),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("address"),
 |  | 
 | 
												
													
														
															|  |                                     1,
 |  | 
 | 
												
													
														
															|  |                                     0,
 |  | 
 | 
												
													
														
															|  |                                     1,
 |  | 
 | 
												
													
														
															|  |                                     0,
 |  | 
 | 
												
													
														
															|  |                                     new Date()
 |  | 
 | 
												
													
														
															|  |                             }
 |  | 
 | 
												
													
														
															|  |                     );
 |  | 
 | 
												
													
														
															|  |                 }catch (Exception e){
 |  | 
 | 
												
													
														
															|  |                     logger.error("将i健康居民数据同步到互联网医院居民表失败:" + e.getMessage());
 |  | 
 | 
												
													
														
															|  |                     return users;
 |  | 
 | 
												
													
														
															|  |                 }
 |  | 
 | 
												
													
														
															|  |                 try {
 |  | 
 | 
												
													
														
															|  |                     this.getJdbcTemplate().update(PATIENT_INSERT_WEHCAT,
 |  | 
 | 
												
													
														
															|  |                             new Object[]{
 |  | 
 | 
												
													
														
															|  |                                     UUID.randomUUID().toString(),
 |  | 
 | 
												
													
														
															|  |                                     getWechatId(),
 |  | 
 | 
												
													
														
															|  |                                     patient.getString("code"),
 |  | 
 | 
												
													
														
															|  |                                     getOpenid(),
 |  | 
 | 
												
													
														
															|  |                                     new Date()
 |  | 
 | 
												
													
														
															|  |                             }
 |  | 
 | 
												
													
														
															|  |                     );
 |  | 
 | 
												
													
														
															|  |                 }catch (Exception e){
 |  | 
 | 
												
													
														
															|  |                     logger.error("将i健康居民微信openid数据同步到互联网医院居民微信关联表失败:" + e.getMessage());
 |  | 
 | 
												
													
														
															|  |                     return users;
 |  | 
 | 
												
													
														
															|  |                 }
 |  | 
 | 
												
													
														
															|  | 
 |  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_STATEMENT, new BeanPropertyRowMapper(WlyyUserDetails.class),username,getIdcard());
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |             if (null == users || users.size() == 0) {
 | 
												
													
														
															|  | 
 |  |                 //厦门I健康账号同步
 | 
												
													
														
															|  | 
 |  |                 if("xm_ihealth_wx".equals(getWechatId())){
 | 
												
													
														
															|  | 
 |  |                     List<NameValuePair> params = new ArrayList<>();
 | 
												
													
														
															|  | 
 |  |                     params.add(new BasicNameValuePair("clientId", getClientId()));
 | 
												
													
														
															|  | 
 |  |                     ClientDetails clientDetails = clientDetailsService.loadClientByClientId(getClientId());
 | 
												
													
														
															|  | 
 |  |                     params.add(new BasicNameValuePair("clientSecret", clientDetails.getClientSecret()));
 | 
												
													
														
															|  | 
 |  |                     params.add(new BasicNameValuePair("code", username));
 | 
												
													
														
															|  | 
 |  |                     params.add(new BasicNameValuePair("openid", getOpenid()));
 | 
												
													
														
															|  | 
 |  |                     String res = null;
 | 
												
													
														
															|  | 
 |  |                     try{
 | 
												
													
														
															|  | 
 |  |                         res = httpClientUtil.post(getSynPath(getWechatId()), params, "UTF-8");
 | 
												
													
														
															|  | 
 |  |                     }catch (Exception e){
 | 
												
													
														
															|  | 
 |  |                         logger.error("远程请求i健康用户信息异常:" + e.getMessage());
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  |                     if(null == res){
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  |                     JSONObject patient = JSONObject.parseObject(res);
 | 
												
													
														
															|  | 
 |  |                     if(patient.getInteger("status") == -1){
 | 
												
													
														
															|  | 
 |  |                         logger.error("去i健康查询用户信息失败:" + patient.getString("error"));
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  |                     try {
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |                         String salt = randomString(5);
 | 
												
													
														
															|  | 
 |  |                         String idcard = patient.getString("idcard");
 | 
												
													
														
															|  | 
 |  |                         String pw = idcard.substring(idcard.length()-6);
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |                         this.getJdbcTemplate().update(DEFAULT_PATIENT_INSERT_STATEMENT,
 | 
												
													
														
															|  | 
 |  |                                 new Object[]{patient.getString("code"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("photo"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("idcard"),
 | 
												
													
														
															|  | 
 |  |                                         MD5.md5Hex(pw + "{" + salt + "}"),
 | 
												
													
														
															|  | 
 |  |                                         salt,
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("name"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getDate("birthday"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getInteger("sex"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("mobile"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("province"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("provinceName"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("city"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("cityName"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("town"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("townName"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("street"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("streetName"),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("address"),
 | 
												
													
														
															|  | 
 |  |                                         1,
 | 
												
													
														
															|  | 
 |  |                                         0,
 | 
												
													
														
															|  | 
 |  |                                         1,
 | 
												
													
														
															|  | 
 |  |                                         0,
 | 
												
													
														
															|  | 
 |  |                                         new Date()
 | 
												
													
														
															|  | 
 |  |                                 }
 | 
												
													
														
															|  | 
 |  |                         );
 | 
												
													
														
															|  | 
 |  |                     }catch (Exception e){
 | 
												
													
														
															|  | 
 |  |                         logger.error("将i健康居民数据同步到互联网医院居民表失败:" + e.getMessage());
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  |                     try {
 | 
												
													
														
															|  | 
 |  |                         this.getJdbcTemplate().update(PATIENT_INSERT_WEHCAT,
 | 
												
													
														
															|  | 
 |  |                                 new Object[]{
 | 
												
													
														
															|  | 
 |  |                                         UUID.randomUUID().toString(),
 | 
												
													
														
															|  | 
 |  |                                         getWechatId(),
 | 
												
													
														
															|  | 
 |  |                                         patient.getString("code"),
 | 
												
													
														
															|  | 
 |  |                                         getOpenid(),
 | 
												
													
														
															|  | 
 |  |                                         new Date()
 | 
												
													
														
															|  | 
 |  |                                 }
 | 
												
													
														
															|  | 
 |  |                         );
 | 
												
													
														
															|  | 
 |  |                     }catch (Exception e){
 | 
												
													
														
															|  | 
 |  |                         logger.error("将i健康居民微信openid数据同步到互联网医院居民微信关联表失败:" + e.getMessage());
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |                     WlyyUserDetails user = new WlyyUserDetails();
 | 
												
													
														
															|  | 
 |  |                     user.setName(patient.getString("name"));
 | 
												
													
														
															|  | 
 |  |                     user.setPassword(patient.getString("password"));
 | 
												
													
														
															|  | 
 |  |                     if(patient.getInteger("sex") == 1){
 | 
												
													
														
															|  | 
 |  |                         user.setGender(WlyyUserDetails.Gender.male);
 | 
												
													
														
															|  | 
 |  |                     }else if(patient.getInteger("sex") == 2){
 | 
												
													
														
															|  | 
 |  |                         user.setGender(WlyyUserDetails.Gender.female);
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  |                     user.setId(username);
 | 
												
													
														
															|  | 
 |  |                     user.setIdcard(patient.getString("idcard"));
 | 
												
													
														
															|  | 
 |  |                     user.setMobile(patient.getString("mobile"));
 | 
												
													
														
															|  | 
 |  |                     user.setEnabled(true);
 | 
												
													
														
															|  | 
 |  |                     user.setLocked(false);
 | 
												
													
														
															|  | 
 |  |                     user.setLockedDate(null);
 | 
												
													
														
															|  | 
 |  |                     users.add(user);
 | 
												
													
														
															|  | 
 |  |                 }else if("xm_zsyy_wx".equals(getWechatId())){
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |                     JSONObject jsonObject=new JSONObject();
 | 
												
													
														
															|  | 
 |  |                     jsonObject.put("openId",getOpenid());
 | 
												
													
														
															|  | 
 |  |                     String res = null;
 | 
												
													
														
															|  | 
 |  |                     try{
 | 
												
													
														
															|  | 
 |  |                         res = httpClientUtil.sendPost(getSynPath("xm_zsyy_wx"), jsonObject.toString());
 | 
												
													
														
															|  | 
 |  |                     }catch (Exception e){
 | 
												
													
														
															|  | 
 |  |                         logger.error("远程请求中山医院用户信息异常:" + e.getMessage());
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  |                     if(null == res){
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |                     JSONObject object1 = JSONObject.parseObject(res);
 | 
												
													
														
															|  | 
 |  |                     if (null != object1&&null!=object1.get("status") && "200".equals(object1.get("status").toString())) {
 | 
												
													
														
															|  | 
 |  |                         JSONObject patient = object1.getJSONObject("userinfo");
 | 
												
													
														
															|  | 
 |  |                         String salt = randomString(5);
 | 
												
													
														
															|  | 
 |  |                         String mobile = patient.getString("mobile");
 | 
												
													
														
															|  | 
 |  |                         String pw = mobile.substring(mobile.length()-6);
 | 
												
													
														
															|  | 
 |  |                         try {
 | 
												
													
														
															|  | 
 |  |                             this.getJdbcTemplate().update(DEFAULT_PATIENT_INSERT_STATEMENT,
 | 
												
													
														
															|  | 
 |  |                                     new Object[]{patient.getString("id"),
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             patient.getString("idcard"),
 | 
												
													
														
															|  | 
 |  |                                             MD5.md5Hex(pw + "{" + salt + "}"),
 | 
												
													
														
															|  | 
 |  |                                             salt,
 | 
												
													
														
															|  | 
 |  |                                             patient.getString("name"),
 | 
												
													
														
															|  | 
 |  |                                             patient.getDate("birthday"),
 | 
												
													
														
															|  | 
 |  |                                             patient.getInteger("sex"),
 | 
												
													
														
															|  | 
 |  |                                             mobile,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             null,
 | 
												
													
														
															|  | 
 |  |                                             1,
 | 
												
													
														
															|  | 
 |  |                                             0,
 | 
												
													
														
															|  | 
 |  |                                             1,
 | 
												
													
														
															|  | 
 |  |                                             0,
 | 
												
													
														
															|  | 
 |  |                                             new Date()
 | 
												
													
														
															|  | 
 |  |                                     }
 | 
												
													
														
															|  | 
 |  |                             );
 | 
												
													
														
															|  | 
 |  |                         }catch (Exception e){
 | 
												
													
														
															|  | 
 |  |                             logger.error("将中山医院居民数据同步到互联网医院居民表失败:" + e.getMessage());
 | 
												
													
														
															|  | 
 |  |                             return users;
 | 
												
													
														
															|  | 
 |  |                         }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |                         WlyyUserDetails user = new WlyyUserDetails();
 | 
												
													
														
															|  | 
 |  |                         user.setName(patient.getString("name"));
 | 
												
													
														
															|  | 
 |  |                         user.setPassword(MD5.md5Hex(pw + "{" + salt + "}"));
 | 
												
													
														
															|  | 
 |  |                         if(patient.getInteger("sex") == 1){
 | 
												
													
														
															|  | 
 |  |                             user.setGender(WlyyUserDetails.Gender.male);
 | 
												
													
														
															|  | 
 |  |                         }else if(patient.getInteger("sex") == 2){
 | 
												
													
														
															|  | 
 |  |                             user.setGender(WlyyUserDetails.Gender.female);
 | 
												
													
														
															|  | 
 |  |                         }
 | 
												
													
														
															|  | 
 |  |                         user.setId(patient.getString("id"));
 | 
												
													
														
															|  | 
 |  |                         user.setIdcard(patient.getString("idcard"));
 | 
												
													
														
															|  | 
 |  |                         user.setMobile(patient.getString("mobile"));
 | 
												
													
														
															|  | 
 |  |                         user.setEnabled(true);
 | 
												
													
														
															|  | 
 |  |                         user.setLocked(false);
 | 
												
													
														
															|  | 
 |  |                         user.setLockedDate(null);
 | 
												
													
														
															|  | 
 |  |                         users.add(user);
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |                     }else{
 | 
												
													
														
															|  | 
 |  |                         logger.error("远程请求中山医院用户信息异常:" + res.toString());
 | 
												
													
														
															|  | 
 |  |                         return users;
 | 
												
													
														
															|  | 
 |  |                     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  |                 WlyyUserDetails user = new WlyyUserDetails();
 |  | 
 | 
												
													
														
															|  |                 user.setName(patient.getString("name"));
 |  | 
 | 
												
													
														
															|  |                 user.setPassword(patient.getString("password"));
 |  | 
 | 
												
													
														
															|  |                 if(patient.getInteger("sex") == 1){
 |  | 
 | 
												
													
														
															|  |                     user.setGender(WlyyUserDetails.Gender.male);
 |  | 
 | 
												
													
														
															|  |                 }else if(patient.getInteger("sex") == 2){
 |  | 
 | 
												
													
														
															|  |                     user.setGender(WlyyUserDetails.Gender.female);
 |  | 
 | 
												
													
														
															|  |                 }
 |  |                 }
 | 
												
													
														
															|  |                 user.setId(username);
 |  | 
 | 
												
													
														
															|  |                 user.setIdcard(patient.getString("idcard"));
 |  | 
 | 
												
													
														
															|  |                 user.setMobile(patient.getString("mobile"));
 |  | 
 | 
												
													
														
															|  |                 user.setEnabled(true);
 |  | 
 | 
												
													
														
															|  |                 user.setLocked(false);
 |  | 
 | 
												
													
														
															|  |                 user.setLockedDate(null);
 |  | 
 | 
												
													
														
															|  |                 users.add(user);
 |  | 
 | 
												
													
														
															|  |             }
 |  |             }
 | 
												
													
														
															|  |         }
 |  |         }
 | 
												
													
														
															|  |         return users;
 |  |         return users;
 | 
												
											
												
													
														
															|  | @ -313,6 +392,8 @@ public class WlyyUserDetailsService extends JdbcDaoSupport implements UserDetail
 | 
												
													
														
															|  |             result = this.getJdbcTemplate().queryForMap("select d.login_failure_count,d.last_login_failure_time from base_doctor d where d.mobile = ? or d.idcard = ?", username, username);
 |  |             result = this.getJdbcTemplate().queryForMap("select d.login_failure_count,d.last_login_failure_time from base_doctor d where d.mobile = ? or d.idcard = ?", username, username);
 | 
												
													
														
															|  |         } else if ("3".equals(loginType)) { //3.患者账号
 |  |         } else if ("3".equals(loginType)) { //3.患者账号
 | 
												
													
														
															|  |             result = this.getJdbcTemplate().queryForMap("select p.login_failure_count,p.last_login_failure_time from base_patient p where p.mobile = ? or p.idcard = ?", username, username);
 |  |             result = this.getJdbcTemplate().queryForMap("select p.login_failure_count,p.last_login_failure_time from base_patient p where p.mobile = ? or p.idcard = ?", username, username);
 | 
												
													
														
															|  | 
 |  |         } else if ("4".equals(loginType)) { //4.第三方患者账号
 | 
												
													
														
															|  | 
 |  |             result = this.getJdbcTemplate().queryForMap("select p.login_failure_count,p.last_login_failure_time from base_patient p where p.mobile = ? or p.idcard = ?", username, getIdcard());
 | 
												
													
														
															|  |         }
 |  |         }
 | 
												
													
														
															|  |         return result;
 |  |         return result;
 | 
												
													
														
															|  |     }
 |  |     }
 | 
												
											
												
													
														
															|  | @ -333,7 +414,10 @@ public class WlyyUserDetailsService extends JdbcDaoSupport implements UserDetail
 | 
												
													
														
															|  |         } else if ("3".equals(loginType)) { //3.患者账号
 |  |         } else if ("3".equals(loginType)) { //3.患者账号
 | 
												
													
														
															|  |             //账号锁定
 |  |             //账号锁定
 | 
												
													
														
															|  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 5, p.locked = 1, p.locked_date = ?  where p.mobile = ? or p.idcard = ?", new Date(), username, username);
 |  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 5, p.locked = 1, p.locked_date = ?  where p.mobile = ? or p.idcard = ?", new Date(), username, username);
 | 
												
													
														
															|  |         } //...
 |  | 
 | 
												
													
														
															|  | 
 |  |         }else if ("4".equals(loginType)) { //3.同步的患者账号
 | 
												
													
														
															|  | 
 |  |             //账号锁定
 | 
												
													
														
															|  | 
 |  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 5, p.locked = 1, p.locked_date = ?  where p.mobile = ? or p.idcard = ?", new Date(), username, getIdcard());
 | 
												
													
														
															|  | 
 |  |         }  //...
 | 
												
													
														
															|  |     }
 |  |     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  |     /**
 |  |     /**
 | 
												
											
												
													
														
															|  | @ -353,6 +437,9 @@ public class WlyyUserDetailsService extends JdbcDaoSupport implements UserDetail
 | 
												
													
														
															|  |         } else if ("3".equals(loginType)) { //3.患者账号
 |  |         } else if ("3".equals(loginType)) { //3.患者账号
 | 
												
													
														
															|  |             //更新失败次数
 |  |             //更新失败次数
 | 
												
													
														
															|  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = ? ,p.last_login_failure_time = ? where p.mobile = ? or p.idcard = ?", loginFailureCount, new Date(), username, username);
 |  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = ? ,p.last_login_failure_time = ? where p.mobile = ? or p.idcard = ?", loginFailureCount, new Date(), username, username);
 | 
												
													
														
															|  | 
 |  |         } else if ("4".equals(loginType)) { //4.第三方同步患者账号
 | 
												
													
														
															|  | 
 |  |             //更新失败次数
 | 
												
													
														
															|  | 
 |  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = ? ,p.last_login_failure_time = ? where p.mobile = ? or p.idcard = ?", loginFailureCount, new Date(), username, getIdcard());
 | 
												
													
														
															|  |         } //...
 |  |         } //...
 | 
												
													
														
															|  |     }
 |  |     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
											
												
													
														
															|  | @ -392,7 +479,7 @@ public class WlyyUserDetailsService extends JdbcDaoSupport implements UserDetail
 | 
												
													
														
															|  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_STATEMENT, new BeanPropertyRowMapper(WlyyUserSimple.class), username, username);
 |  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_STATEMENT, new BeanPropertyRowMapper(WlyyUserSimple.class), username, username);
 | 
												
													
														
															|  |         } else if("4".equals(loginType)){
 |  |         } else if("4".equals(loginType)){
 | 
												
													
														
															|  |             //更新登录时间
 |  |             //更新登录时间
 | 
												
													
														
															|  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 0, p.login_date = ? where p.mobile = ? or p.idcard = ?", new Date(), username, username);
 |  | 
 | 
												
													
														
															|  | 
 |  |             this.getJdbcTemplate().update("update base_patient p set p.login_failure_count = 0, p.login_date = ? where p.mobile = ? or p.idcard = ?", new Date(), username, getIdcard());
 | 
												
													
														
															|  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_IDCARD_STATEMENT, new BeanPropertyRowMapper(WlyyUserSimple.class), getIdcard());
 |  |             users = this.getJdbcTemplate().query(DEFAULT_PATIENT_DETAILS_IDCARD_STATEMENT, new BeanPropertyRowMapper(WlyyUserSimple.class), getIdcard());
 | 
												
													
														
															|  |         }
 |  |         }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
											
												
													
														
															|  | @ -485,6 +572,19 @@ public class WlyyUserDetailsService extends JdbcDaoSupport implements UserDetail
 | 
												
													
														
															|  |         this.getJdbcTemplate().update("update base_patient p set p.openid = ? where p.id= ?", openid, userId);
 |  |         this.getJdbcTemplate().update("update base_patient p set p.openid = ? where p.id= ?", openid, userId);
 | 
												
													
														
															|  |     }
 |  |     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |     public String getSynPath(String wxId){
 | 
												
													
														
															|  | 
 |  |         String sql = "SELECT w.syn_path AS sysPath FROM wx_wechat w WHERE w.id ='"+wxId+"'";
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |         List<Map<String,Object>> list = this.getJdbcTemplate().queryForList(sql);
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  | 
 |  |         if(list!=null&&list.size()>0){
 | 
												
													
														
															|  | 
 |  |             return (String)list.get(0).get("sysPath");
 | 
												
													
														
															|  | 
 |  |         }else{
 | 
												
													
														
															|  | 
 |  |             logger.error("getSynPath error");
 | 
												
													
														
															|  | 
 |  |         }
 | 
												
													
														
															|  | 
 |  |         return "";
 | 
												
													
														
															|  | 
 |  |     }
 | 
												
													
														
															|  | 
 |  | 
 | 
												
													
														
															|  |     public String randomString(int length) {
 |  |     public String randomString(int length) {
 | 
												
													
														
															|  |         String str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
 |  |         String str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
 | 
												
													
														
															|  |         StringBuffer buffer = new StringBuffer();
 |  |         StringBuffer buffer = new StringBuffer();
 |