Browse Source

图片验证码校验,短信验证码校验接口

gaodm 6 years ago
parent
commit
fb8f594ec5

+ 399 - 0
common/src/main/java/com/diagbot/util/IdcardValidator.java

@@ -0,0 +1,399 @@
+package com.diagbot.util;
+
+import java.text.ParseException;
+import java.text.SimpleDateFormat;
+import java.util.Calendar;
+import java.util.Date;
+
+/**
+ * @Description: 身份证合法性校验
+ * --15位身份证号码:第7、8位为出生年份(两位数),第9、10位为出生月份,第11、12位代表出生日期,第15位代表性别,奇数为男,偶数为女。
+ * --18位身份证号码:第7、8、9、10位为出生年份(四位数),第11、第12位为出生月份,第13、14位代表出生日期,第17位代表性别,奇数为男,偶数为女。
+ *    最后一位为校验位
+ * @author: gaodm
+ * @time: 2018/9/6 13:35
+ */
+public class IdcardValidator {
+
+    /**
+     * <pre>
+     * 省、直辖市代码表:
+     *     11 : 北京  12 : 天津  13 : 河北       14 : 山西  15 : 内蒙古
+     *     21 : 辽宁  22 : 吉林  23 : 黑龙江  31 : 上海  32 : 江苏
+     *     33 : 浙江  34 : 安徽  35 : 福建       36 : 江西  37 : 山东
+     *     41 : 河南  42 : 湖北  43 : 湖南       44 : 广东  45 : 广西      46 : 海南
+     *     50 : 重庆  51 : 四川  52 : 贵州       53 : 云南  54 : 西藏
+     *     61 : 陕西  62 : 甘肃  63 : 青海       64 : 宁夏  65 : 新疆
+     *     71 : 台湾
+     *     81 : 香港  82 : 澳门
+     *     91 : 国外
+     * </pre>
+     */
+    private static String cityCode[] = { "11", "12", "13", "14", "15", "21",
+            "22", "23", "31", "32", "33", "34", "35", "36", "37", "41", "42",
+            "43", "44", "45", "46", "50", "51", "52", "53", "54", "61", "62",
+            "63", "64", "65", "71", "81", "82", "91" };
+
+    /**
+     * 每位加权因子
+     */
+    private static int power[] = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5,
+            8, 4, 2 };
+
+    /**
+     * 验证所有的身份证的合法性
+     *
+     * @param idcard
+     *            身份证
+     * @return 合法返回true,否则返回false
+     */
+    public static boolean isValidatedAllIdcard(String idcard) {
+        if (idcard == null || "".equals(idcard)) {
+            return false;
+        }
+        if (idcard.length() == 15) {
+            return validate15IDCard(idcard);
+        }
+        return validate18Idcard(idcard);
+    }
+
+    /**
+     * <p>
+     * 判断18位身份证的合法性
+     * </p>
+     * 根据〖中华人民共和国国家标准GB11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。
+     * 排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
+     * <p>
+     * 顺序码: 表示在同一地址码所标识的区域范围内,对同年、同月、同 日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配 给女性。
+     * </p>
+     * <p>
+     * 1.前1、2位数字表示:所在省份的代码; 2.第3、4位数字表示:所在城市的代码; 3.第5、6位数字表示:所在区县的代码;
+     * 4.第7~14位数字表示:出生年、月、日; 5.第15、16位数字表示:所在地的派出所的代码;
+     * 6.第17位数字表示性别:奇数表示男性,偶数表示女性;
+     * 7.第18位数字是校检码:也有的说是个人信息码,一般是随计算机的随机产生,用来检验身份证的正确性。校检码可以是0~9的数字,有时也用x表示。
+     * </p>
+     * <p>
+     * 第十八位数字(校验码)的计算方法为: 1.将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7 9 10 5 8 4
+     * 2 1 6 3 7 9 10 5 8 4 2
+     * </p>
+     * <p>
+     * 2.将这17位数字和系数相乘的结果相加。
+     * </p>
+     * <p>
+     * 3.用加出来和除以11,看余数是多少
+     * </p>
+     * 4.余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字。其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3
+     * 2。
+     * <p>
+     * 5.通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的Ⅹ。如果余数是10,身份证的最后一位号码就是2。
+     * </p>
+     *
+     * @param idcard
+     * @return
+     */
+    public static boolean validate18Idcard(String idcard) {
+        if (idcard == null) {
+            return false;
+        }
+
+        // 非18位为假
+        if (idcard.length() != 18) {
+            return false;
+        }
+        // 获取前17位
+        String idcard17 = idcard.substring(0, 17);
+
+        // 前17位全部为数字
+        if (!isDigital(idcard17)) {
+            return false;
+        }
+
+        String provinceid = idcard.substring(0, 2);
+        // 校验省份
+        if (!checkProvinceid(provinceid)) {
+            return false;
+        }
+
+        // 校验出生日期
+        String birthday = idcard.substring(6, 14);
+
+        SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
+
+        try {
+            Date birthDate = sdf.parse(birthday);
+            String tmpDate = sdf.format(birthDate);
+            if (!tmpDate.equals(birthday)) {// 出生年月日不正确
+                return false;
+            }
+
+        } catch (ParseException e1) {
+
+            return false;
+        }
+
+        // 获取第18位
+        String idcard18Code = idcard.substring(17, 18);
+
+        char c[] = idcard17.toCharArray();
+
+        int bit[] = converCharToInt(c);
+
+        int sum17 = 0;
+
+        sum17 = getPowerSum(bit);
+
+        // 将和值与11取模得到余数进行校验码判断
+        String checkCode = getCheckCodeBySum(sum17);
+        if (null == checkCode) {
+            return false;
+        }
+        // 将身份证的第18位与算出来的校码进行匹配,不相等就为假
+        if (!idcard18Code.equalsIgnoreCase(checkCode)) {
+            return false;
+        }
+
+        return true;
+    }
+
+    /**
+     * 校验15位身份证
+     *
+     * <pre>
+     * 只校验省份和出生年月日
+     * </pre>
+     *
+     * @param idcard
+     * @return
+     */
+    public static boolean validate15IDCard(String idcard) {
+        if (idcard == null) {
+            return false;
+        }
+        // 非15位为假
+        if (idcard.length() != 15) {
+            return false;
+        }
+
+        // 15全部为数字
+        if (!isDigital(idcard)) {
+            return false;
+        }
+
+        String provinceid = idcard.substring(0, 2);
+        // 校验省份
+        if (!checkProvinceid(provinceid)) {
+            return false;
+        }
+
+        String birthday = idcard.substring(6, 12);
+
+        SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
+
+        try {
+            Date birthDate = sdf.parse(birthday);
+            String tmpDate = sdf.format(birthDate);
+            if (!tmpDate.equals(birthday)) {// 身份证日期错误
+                return false;
+            }
+
+        } catch (ParseException e1) {
+
+            return false;
+        }
+
+        return true;
+    }
+
+    /**
+     * 将15位的身份证转成18位身份证
+     *
+     * @param idcard
+     * @return
+     */
+    public static String convertIdcarBy15bit(String idcard) {
+        if (idcard == null) {
+            return null;
+        }
+
+        // 非15位身份证
+        if (idcard.length() != 15) {
+            return null;
+        }
+
+        // 15全部为数字
+        if (!isDigital(idcard)) {
+            return null;
+        }
+
+        String provinceid = idcard.substring(0, 2);
+        // 校验省份
+        if (!checkProvinceid(provinceid)) {
+            return null;
+        }
+
+        String birthday = idcard.substring(6, 12);
+
+        SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
+
+        Date birthdate = null;
+        try {
+            birthdate = sdf.parse(birthday);
+            String tmpDate = sdf.format(birthdate);
+            if (!tmpDate.equals(birthday)) {// 身份证日期错误
+                return null;
+            }
+
+        } catch (ParseException e1) {
+            return null;
+        }
+
+        Calendar cday = Calendar.getInstance();
+        cday.setTime(birthdate);
+        String year = String.valueOf(cday.get(Calendar.YEAR));
+
+        String idcard17 = idcard.substring(0, 6) + year + idcard.substring(8);
+
+        char c[] = idcard17.toCharArray();
+        String checkCode = "";
+
+        // 将字符数组转为整型数组
+        int bit[] = converCharToInt(c);
+
+        int sum17 = 0;
+        sum17 = getPowerSum(bit);
+
+        // 获取和值与11取模得到余数进行校验码
+        checkCode = getCheckCodeBySum(sum17);
+
+        // 获取不到校验位
+        if (null == checkCode) {
+            return null;
+        }
+        // 将前17位与第18位校验码拼接
+        idcard17 += checkCode;
+        return idcard17;
+    }
+
+    /**
+     * 校验省份
+     *
+     * @param provinceid
+     * @return 合法返回TRUE,否则返回FALSE
+     */
+    private static boolean checkProvinceid(String provinceid) {
+        for (String id : cityCode) {
+            if (id.equals(provinceid)) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    /**
+     * 数字验证
+     *
+     * @param str
+     * @return
+     */
+    private static boolean isDigital(String str) {
+        return str.matches("^[0-9]*$");
+    }
+
+    /**
+     * 将身份证的每位和对应位的加权因子相乘之后,再得到和值
+     *
+     * @param bit
+     * @return
+     */
+    private static int getPowerSum(int[] bit) {
+
+        int sum = 0;
+
+        if (power.length != bit.length) {
+            return sum;
+        }
+
+        for (int i = 0; i < bit.length; i++) {
+            for (int j = 0; j < power.length; j++) {
+                if (i == j) {
+                    sum = sum + bit[i] * power[j];
+                }
+            }
+        }
+        return sum;
+    }
+
+    /**
+     * 将和值与11取模得到余数进行校验码判断
+     *
+     * @param checkCode
+     * @param sum17
+     * @return 校验位
+     */
+    private static String getCheckCodeBySum(int sum17) {
+        String checkCode = null;
+        switch (sum17 % 11) {
+            case 10:
+                checkCode = "2";
+                break;
+            case 9:
+                checkCode = "3";
+                break;
+            case 8:
+                checkCode = "4";
+                break;
+            case 7:
+                checkCode = "5";
+                break;
+            case 6:
+                checkCode = "6";
+                break;
+            case 5:
+                checkCode = "7";
+                break;
+            case 4:
+                checkCode = "8";
+                break;
+            case 3:
+                checkCode = "9";
+                break;
+            case 2:
+                checkCode = "x";
+                break;
+            case 1:
+                checkCode = "0";
+                break;
+            case 0:
+                checkCode = "1";
+                break;
+        }
+        return checkCode;
+    }
+
+    /**
+     * 将字符数组转为整型数组
+     *
+     * @param c
+     * @return
+     * @throws NumberFormatException
+     */
+    private static int[] converCharToInt(char[] c) throws NumberFormatException {
+        int[] a = new int[c.length];
+        int k = 0;
+        for (char temp : c) {
+            a[k++] = Integer.parseInt(String.valueOf(temp));
+        }
+        return a;
+    }
+
+    public static void main(String[] args) throws Exception {
+        String idcard15 = "130321860311519";
+        String idcard18 = "210102198617083732";//
+        // 15位身份证
+        System.out.println(isValidatedAllIdcard(idcard15));
+        // 18位身份证
+        System.out.println(isValidatedAllIdcard(idcard18));
+        // 15位身份证转18位身份证
+        System.out.println(convertIdcarBy15bit(idcard15));
+    }
+}

+ 54 - 0
common/src/main/java/com/diagbot/util/RegexValidateUtil.java

@@ -0,0 +1,54 @@
+package com.diagbot.util;
+
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+/**
+ * @Description: 使用正则表达式验证输入格式
+ * @author: gaodm
+ * @time: 2018/9/6 13:25
+ */
+public class RegexValidateUtil {
+    /**
+     * 验证邮箱
+     *
+     * @param email
+     * @return
+     */
+    public static boolean checkEmail(String email) {
+        boolean flag = false;
+        try {
+            String check = "^([a-z0-9A-Z]+[-|_|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$";
+            Pattern regex = Pattern.compile(check);
+            Matcher matcher = regex.matcher(email);
+            flag = matcher.matches();
+        } catch (Exception e) {
+            flag = false;
+        }
+        return flag;
+    }
+
+    /**
+     * 验证手机号码
+     *
+     * @param mobileNumber 手机号码
+     * @return
+     */
+    public static boolean checkMobileNumber(String mobileNumber) {
+        boolean flag = false;
+        try {
+            Pattern regex = Pattern.compile("^(((13[0-9])|(15([0-3]|[5-9]))|(18[0,5-9]))\\d{8})|(0\\d{2}-\\d{8})|(0\\d{3}-\\d{7})$");
+            Matcher matcher = regex.matcher(mobileNumber);
+            flag = matcher.matches();
+        } catch (Exception e) {
+            flag = false;
+        }
+        return flag;
+    }
+
+    public static void main(String[] args) {
+        System.out.println(checkEmail("14_8@qw.df"));
+        System.out.println(checkMobileNumber("139247001"));
+        System.out.println(checkMobileNumber("13529600202"));
+    }
+}

+ 3 - 1
user-service/src/main/java/com/diagbot/config/ResourceServerConfigurer.java

@@ -27,7 +27,9 @@ public class ResourceServerConfigurer extends ResourceServerConfigurerAdapter {
                 .authorizeRequests()
                 .authorizeRequests()
                 .regexMatchers(".*swagger.*",".*v2.*",".*webjars.*","/user/login.*","/user/registry.*","/user/test.*","/druid.*","/actuator.*","/hystrix.*","/hi.*","/test.*").permitAll()
                 .regexMatchers(".*swagger.*",".*v2.*",".*webjars.*","/user/login.*","/user/registry.*","/user/test.*","/druid.*","/actuator.*","/hystrix.*","/hi.*","/test.*").permitAll()
                 .antMatchers("/userver/getImgVerification").permitAll()
                 .antMatchers("/userver/getImgVerification").permitAll()
-                .antMatchers("/userver/verImgVerification").permitAll()
+                .antMatchers("/userver/verifyImgVerification").permitAll()
+                .antMatchers("/userver/getSmsVerification").permitAll()
+                .antMatchers("/userver/verifySmsVerification").permitAll()
                 .antMatchers("/**").authenticated();
                 .antMatchers("/**").authenticated();
 //        .antMatchers("/**").permitAll();
 //        .antMatchers("/**").permitAll();
     }
     }

+ 3 - 1
user-service/src/main/java/com/diagbot/config/security/UrlAccessDecisionManager.java

@@ -41,7 +41,9 @@ public class UrlAccessDecisionManager implements AccessDecisionManager {
                 || matchers("/hi/**", request)
                 || matchers("/hi/**", request)
                 || matchers("/test/**", request)
                 || matchers("/test/**", request)
                 || matchers("/userver/getImgVerification", request)
                 || matchers("/userver/getImgVerification", request)
-                || matchers("/userver/verImgVerification", request)
+                || matchers("/userver/verifyImgVerification", request)
+                || matchers("/userver/getSmsVerification", request)
+                || matchers("/userver/verifySmsVerification", request)
                 || matchers("/", request)){
                 || matchers("/", request)){
                     return;
                     return;
                 } else {
                 } else {

+ 133 - 1
user-service/src/main/java/com/diagbot/facade/VerFacade.java

@@ -2,15 +2,24 @@ package com.diagbot.facade;
 
 
 import com.diagbot.dto.ImgVerCreatDTO;
 import com.diagbot.dto.ImgVerCreatDTO;
 import com.diagbot.entity.ImgVerInfo;
 import com.diagbot.entity.ImgVerInfo;
+import com.diagbot.entity.SwsVerInfo;
+import com.diagbot.entity.User;
 import com.diagbot.enums.VisibleIdTypeEnum;
 import com.diagbot.enums.VisibleIdTypeEnum;
+import com.diagbot.exception.CommonException;
+import com.diagbot.exception.ErrorCode;
 import com.diagbot.idc.VisibleIdCreater;
 import com.diagbot.idc.VisibleIdCreater;
 import com.diagbot.service.ImgVerService;
 import com.diagbot.service.ImgVerService;
 import com.diagbot.service.SmsVerService;
 import com.diagbot.service.SmsVerService;
 import com.diagbot.util.BeanUtil;
 import com.diagbot.util.BeanUtil;
-import com.diagbot.vo.ImgVerCreatVO;
+import com.diagbot.util.DateUtil;
+import com.diagbot.util.RegexValidateUtil;
+import com.diagbot.util.StringUtil;
 import com.diagbot.vo.ImgVerVerVO;
 import com.diagbot.vo.ImgVerVerVO;
+import com.diagbot.vo.SmsVerCreatVO;
+import com.diagbot.vo.SmsVerVerVO;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 import org.springframework.stereotype.Component;
+import springfox.documentation.annotations.ApiIgnore;
 
 
 /**
 /**
  * @Description: 用户验证业务层
  * @Description: 用户验证业务层
@@ -23,6 +32,8 @@ public class VerFacade {
     private ImgVerService imgVerService;
     private ImgVerService imgVerService;
     @Autowired
     @Autowired
     private SmsVerService smsVerService;
     private SmsVerService smsVerService;
+    @Autowired
+    private UserFacade userFacade;
 
 
     /**
     /**
      * 获取用户图片验证信息
      * 获取用户图片验证信息
@@ -42,6 +53,8 @@ public class VerFacade {
 
 
     /**
     /**
      * 验证用户图片验证码是否有效
      * 验证用户图片验证码是否有效
+     * @param imgVerVerVO 图片验证码验证输入信息
+     * @return 验证是否成功
      */
      */
     public Boolean verifyImgVerification(ImgVerVerVO imgVerVerVO){
     public Boolean verifyImgVerification(ImgVerVerVO imgVerVerVO){
         ImgVerInfo imgVerInfo = new ImgVerInfo();
         ImgVerInfo imgVerInfo = new ImgVerInfo();
@@ -49,5 +62,124 @@ public class VerFacade {
         return imgVerService.verifyImgVerification(imgVerInfo);
         return imgVerService.verifyImgVerification(imgVerInfo);
     }
     }
 
 
+    /**
+     * 获取短信验证码
+     * @param smsVerCreatVO 获取短信验证码输入参数
+     * @return 获取短信验证码是否成功
+     */
+    public Boolean getSmsVerification(SmsVerCreatVO smsVerCreatVO){
+        //参数验证
+        if (null == smsVerCreatVO){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "短信验证码创建信息不能为空!");
+        }
+        if (StringUtil.isBlank(smsVerCreatVO.getImgId())){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "图片验证码唯一标志不能为空!");
+        }
+        if (StringUtil.isBlank(smsVerCreatVO.getCode())){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "图片验证码不能为空!");
+        }
+        if (StringUtil.isBlank(smsVerCreatVO.getMobile())){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "用户电话不能为空!");
+        }
+        if (!RegexValidateUtil.checkMobileNumber(smsVerCreatVO.getMobile())){
+            throw new CommonException(ErrorCode.PARAM_IS_ERROR,
+                    "用户电话格式错误!");
+        }
+        //验证图片验证码
+        ImgVerInfo imgVerInfo = new ImgVerInfo();
+        BeanUtil.copyProperties(smsVerCreatVO, imgVerInfo);
+        Boolean imgVerRes = imgVerService.verifyImgVerification(imgVerInfo);
+        if (imgVerRes){
+            //todo 验证该用户是否被注册
+            Boolean isReg = false;
+            if (isReg){
+                throw new CommonException(ErrorCode.PARAM_IS_ERROR, "该号码已经被注册!");
+            }
+
+            //验证是否超过两分钟
+            SwsVerInfo swsVerInfoCheck = smsVerService.getSmsVerification(smsVerCreatVO.getMobile());
+            if (null != swsVerInfoCheck){
+                if (DateUtil.after(DateUtil.addMinutes(swsVerInfoCheck.getCreateTime(), 2),
+                        DateUtil.now())){
+                    throw new CommonException(ErrorCode.SMS_SEND_ERROR,
+                            "同一用户两分钟之内不能重复发送验证短信,请两分钟之后再次发送!");
+                }
+            }
+        } else {
+            throw new CommonException(ErrorCode.PARAM_IS_ERROR, "图片验证码错误!");
+        }
+
+        //发送短信
+        String smsTemplateCode = "SMS_143861902";
+        String code = smsVerService.smsSend(smsVerCreatVO.getMobile(), smsTemplateCode);
+
+        //创建用户短信验证信息,缓存到redis
+        SwsVerInfo swsVerInfo = new SwsVerInfo();
+        swsVerInfo.setMobile(smsVerCreatVO.getMobile());
+        swsVerInfo.setCode(code);
+        return smsVerService.createSmsVerification(swsVerInfo);
+    }
+
+    /**
+     * 验证短信码并且注册为新的用户
+     * @param smsVerVerVO 短信验证码验证输入信息
+     * @return 用户信息是否注册到数据库
+     */
+    public Boolean verifySmsVerification(SmsVerVerVO smsVerVerVO){
+        //参数验证
+        if (null == smsVerVerVO){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "短信验证码验证输入信息不能为空!");
+        }
+        if (StringUtil.isBlank(smsVerVerVO.getImgId())){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "图片验证码唯一标志不能为空!");
+        }
+        if (StringUtil.isBlank(smsVerVerVO.getCode())){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "图片验证码不能为空!");
+        }
+        if (StringUtil.isBlank(smsVerVerVO.getMobile())){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "用户电话不能为空!");
+        }
+        if (StringUtil.isBlank(smsVerVerVO.getSmsCode())){
+            throw new CommonException(ErrorCode.PARAM_IS_NULL,
+                    "短信验证码不能为空!");
+        }
+        if (!RegexValidateUtil.checkMobileNumber(smsVerVerVO.getMobile())){
+            throw new CommonException(ErrorCode.PARAM_IS_ERROR,
+                    "用户电话格式错误!");
+        }
+        //验证图片验证码
+        ImgVerInfo imgVerInfo = new ImgVerInfo();
+        BeanUtil.copyProperties(smsVerVerVO, imgVerInfo);
+        Boolean imgVerRes = imgVerService.verifyImgVerification(imgVerInfo);
+        if (imgVerRes){
+            //todo 验证该用户是否被注册
+            Boolean isReg = false;
+            if (isReg){
+                throw new CommonException(ErrorCode.PARAM_IS_ERROR, "该号码已经被注册!");
+            }
+        } else {
+            throw new CommonException(ErrorCode.PARAM_IS_ERROR, "图片验证码错误!");
+        }
+        //验证用户短信信息
+        SwsVerInfo swsVerInfo = new SwsVerInfo();
+        swsVerInfo.setMobile(smsVerVerVO.getMobile());
+        swsVerInfo.setCode(smsVerVerVO.getSmsCode());
+        Boolean smsVer = smsVerService.verifySmsVerification(swsVerInfo);
+        if (!smsVer){
+            throw new CommonException(ErrorCode.PARAM_IS_ERROR, "短信验证未通过!");
+        }
+        //todo 将用户信息加入数据库
+        Boolean registSuccess = true;
+        return registSuccess;
+    }
+
 
 
 }
 }

+ 0 - 16
user-service/src/main/java/com/diagbot/vo/ImgVerCreatVO.java

@@ -1,16 +0,0 @@
-package com.diagbot.vo;
-
-import lombok.Getter;
-import lombok.Setter;
-
-/**
- * @Description:
- * @author: gaodm
- * @time: 2018/9/4 19:26
- */
-@Getter
-@Setter
-public class ImgVerCreatVO {
-    //图片验证码唯一标志
-    private String imgId;
-}

+ 16 - 0
user-service/src/main/java/com/diagbot/vo/SmsVerCreatVO.java

@@ -0,0 +1,16 @@
+package com.diagbot.vo;
+
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * @Description: 获取短信验证码输入参数
+ * @author: gaodm
+ * @time: 2018/9/4 19:26
+ */
+@Getter
+@Setter
+public class SmsVerCreatVO extends ImgVerVerVO{
+    //用户电话
+    private String mobile;
+}

+ 18 - 0
user-service/src/main/java/com/diagbot/vo/SmsVerVerVO.java

@@ -0,0 +1,18 @@
+package com.diagbot.vo;
+
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * @Description: 短信验证码验证输入信息
+ * @author: gaodm
+ * @time: 2018/9/3 15:38
+ */
+@Getter
+@Setter
+public class SmsVerVerVO  extends ImgVerVerVO {
+    //用户电话
+    private String mobile;
+    //短信验证码
+    private String smsCode;
+}

+ 31 - 5
user-service/src/main/java/com/diagbot/web/VerController.java

@@ -3,12 +3,14 @@ package com.diagbot.web;
 import com.diagbot.annotation.SysLogger;
 import com.diagbot.annotation.SysLogger;
 import com.diagbot.dto.RespDTO;
 import com.diagbot.dto.RespDTO;
 import com.diagbot.facade.VerFacade;
 import com.diagbot.facade.VerFacade;
-import com.diagbot.vo.ImgVerCreatVO;
 import com.diagbot.vo.ImgVerVerVO;
 import com.diagbot.vo.ImgVerVerVO;
+import com.diagbot.vo.SmsVerCreatVO;
+import com.diagbot.vo.SmsVerVerVO;
 import io.swagger.annotations.ApiOperation;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
 import org.springframework.web.bind.annotation.RestController;
 
 
@@ -37,12 +39,36 @@ public class VerController {
     /**
     /**
      * 验证图片验证码信息
      * 验证图片验证码信息
      * @param imgVerVerVO 验证图片验证码所需参数
      * @param imgVerVerVO 验证图片验证码所需参数
-     * @return
+     * @return 是否验证成功
      */
      */
     @ApiOperation(value = "验证图片验证码", notes = "图片验证码唯一标志后和验证码不能为空")
     @ApiOperation(value = "验证图片验证码", notes = "图片验证码唯一标志后和验证码不能为空")
-    @PostMapping("/verImgVerification")
-    @SysLogger("verImgVerification")
-    public RespDTO verImgVerification(ImgVerVerVO imgVerVerVO){
+    @PostMapping("/verifyImgVerification")
+    @SysLogger("verifyImgVerification")
+    public RespDTO verImgVerification(@RequestBody ImgVerVerVO imgVerVerVO){
         return   RespDTO.onSuc(verFacade.verifyImgVerification(imgVerVerVO));
         return   RespDTO.onSuc(verFacade.verifyImgVerification(imgVerVerVO));
     }
     }
+
+    /**
+     * 获取短信验证码
+     * @param smsVerCreatVO 获取短信验证码输入参数
+     * @return 获取短信验证码是否成功
+     */
+    @ApiOperation(value = "获取短信验证码", notes = "图片验证码唯一标志后,图形验证码,用户号码不能为空")
+    @PostMapping("/getSmsVerification")
+    @SysLogger("getSmsVerification")
+    public RespDTO getSmsVerification(@RequestBody SmsVerCreatVO smsVerCreatVO){
+        return   RespDTO.onSuc(verFacade.getSmsVerification(smsVerCreatVO));
+    }
+
+    /**
+     * 验证短信码并且注册为新的用户
+     * @param smsVerVerVO 短信验证码验证输入信息
+     * @return 用户信息是否注册到数据库
+     */
+    @ApiOperation(value = "验证短信验证码", notes = "图片验证码唯一标志后,图形验证码,用户号码,用户验证码不能为空")
+    @PostMapping("/verifySmsVerification")
+    @SysLogger("verifySmsVerification")
+    public RespDTO verifySmsVerification(@RequestBody SmsVerVerVO smsVerVerVO){
+        return RespDTO.onSuc(verFacade.verifySmsVerification(smsVerVerVO));
+    }
 }
 }