项目资料收集&面试题SSM搭建二手市场交易平台网站

SSM搭建二手市场交易平台(七):用户登出,注册,校验功能实现

2019-01-21  本文已影响5人  啃饼小白

写在前面

本篇我们介绍用户登出,注册和校验功能这三者的实现。大家反映之前那种方式太难理解,好吧这里我们依旧采取把实现具体功能代码放在一块,一步一步的来的模式。

用户登出

打开UserController.java文件,在里面新增以下代码:

  /***
     * 用户退出
     * @author lenovo
     * */
    @RequestMapping(value = "logout.do",method = RequestMethod.GET)  //这里就是具体的每个方法的url链接
    @ResponseBody   //自动序列化json功能
    public ServerResponse<String> logout(HttpSession session){
        session.removeAttribute(Const.CURRENT_USER);
        return ServerResponse.createBySuccess();
    }

通过这段代码,我们就完成了用户登出的功能看,接来下是用户的注册功能。

用户注册

继续打开UserController.java文件,在里面新增以下代码:

@RequestMapping(value = "register.do",method = RequestMethod.GET)
@ResponseBody
public ServerResponse<String> register(User user){
    return null;
}

打开UserMapper.java文件,我们需要对前端用户注册的邮箱是否存在进行校验:

    int checkEmail(String email);    //这里找不到对应的实现类,所以应该去UserMapper.xml里面进行配置

这个和我们之前对于用户名的校验很相似,别忘了你这个方法需要去UserMapper.xml里面进行配置:

 <select id="checkEmail" resultType="int" parameterType="string">
     select count(1) from store_user
     where email = #{email}
    </select>

然后回到我们的UserServiceImpl.java文件,里面添加如下代码:

   /**
     * 实现注册的接口类
     * */
    public  ServerResponse<String> register(User user){
        int resultCount = userMapper.checkUsername(user.getUsername());  //检查注册时用户名是否存在
        if(resultCount >0){
            return ServerResponse.createByErrorMessage("该用户已存在");
        }

        resultCount = userMapper.checkEmail(user.getEmail());  //检查注册时邮箱是否存在
        if(resultCount >0){
            return ServerResponse.createByErrorMessage("该邮箱已存在");
        }

        user.setRole(Const.Role.ROLE_CUSTOMER);   //该注册用户为一般用户
        //密码加密(定义一个工具类)


    }

接下来我们需要定义一个对用户密码进行加密的工具类,在util包里新建一个工具类MD5Util.java,里面的代码如下:

package top.store.util;

import java.security.MessageDigest;

public class MD5Util {
    private static String byteArrayToHexString(byte b[]) {
        StringBuffer resultSb = new StringBuffer();
        for (int i = 0; i < b.length; i++)
            resultSb.append(byteToHexString(b[i]));

        return resultSb.toString();
    }

    private static String byteToHexString(byte b) {
        int n = b;
        if (n < 0)
            n += 256;
        int d1 = n / 16;
        int d2 = n % 16;
        return hexDigits[d1] + hexDigits[d2];
    }

    /**
     * 返回大写 MD5
     *

     */
    private static String MD5Encode(String origin, String charsetname) {
        String resultString = null;
        try {
            resultString = new String(origin);
            MessageDigest md = MessageDigest.getInstance("MD5");
            if (charsetname == null || "".equals(charsetname))
                resultString = byteArrayToHexString(md.digest(resultString.getBytes()));
            else
                resultString = byteArrayToHexString(md.digest(resultString.getBytes(charsetname)));
        } catch (Exception exception) {
        }
        return resultString.toUpperCase();
    }

    public static String MD5EncodeUtf8(String origin) {
        return MD5Encode(origin, "utf-8");
    }


    private static final String hexDigits[] = {"0", "1", "2", "3", "4", "5",
            "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};
}

我们继续回到UserServiceImpl.java文件:

    /**
     * 实现注册的接口类
     * */
    public  ServerResponse<String> register(User user){
        int resultCount = userMapper.checkUsername(user.getUsername());  //检查注册时用户名是否存在
        if(resultCount >0){
            return ServerResponse.createByErrorMessage("该用户已存在");
        }

        resultCount = userMapper.checkEmail(user.getEmail());  //检查注册时邮箱是否存在
        if(resultCount >0){
            return ServerResponse.createByErrorMessage("该邮箱已存在");
        }

        user.setRole(Const.Role.ROLE_CUSTOMER);   //该注册用户为一般用户
        //密码加密(定义一个工具类)

        user.setPassword(MD5Util.MD5EncodeUtf8(user.getPassword()));

        resultCount =userMapper.insert(user);
        if(resultCount == 0){
            return ServerResponse.createByErrorMessage("注册失败");  //说明可能是数据库错误
        }
        return ServerResponse.createBySuccessMassage("注册成功");
    }

看到这里就有疑问了,你注册时候都对密码进行加密了,你前面登录却还用明文进行比较,对,所以我们现在就要对此进行修改:

 //用户名登录MD5
String md5Password = MD5Util.MD5EncodeUtf8(password);
User user =userMapper.selectLogin(username,md5Password);

经过这样修改,我们就可以进行加密后的密码验证了。接下来我们打开IUserService.java文件,把刚才的用于实现注册的接口类放置到里面:

ServerResponse<String> register(User user);

这样我们UserController就能使用它了:

  /***
     * 用户注册
     * @author lenovo
     * */
    @RequestMapping(value = "register.do",method = RequestMethod.GET)  //这里就是具体的每个方法的url链接
    @ResponseBody   //自动序列化json功能
    public ServerResponse<String> register(User user){
        return iUserService.register(user);
    }

接下来介绍值校验的功能,因为我们不光只有注册的时候需要校验,而且登录,修改密码,找回密码等也需要进行校验,最主要的就是每次校验的类型还不确定(言外之意就是校验的字段类型根据不同的业务场景进行变换)

校验功能

针对上面的情况,我们觉得有必要专门去写一个方法,去应对不同业务场景下面的字段验证问题,首先打开UserController,里面新增代码:

    /***
     * 用于值验证
     * */
    public ServerResponse<String> checkValid(String str,String type){
        return null;
    }

然后修改IUserService.java文件:

 ServerResponse<String> checkValid(String str,String type);

接着修改UserServiceImpl文件:


    /****
     *
     * 实现值校验的接口类
     */
    public ServerResponse<String>checkValid(String str,String type){
        if(StringUtils.isNoneBlank(type)){
            //开始校验
            if(Const.USERNAME.equals(type)){
                int resultCount = userMapper.checkUsername(str);  //检查用户名是否存在
                if(resultCount >0){
                    return ServerResponse.createByErrorMessage("该用户已存在");
                }
            }

            if(Const.EMAIL.equals(type)){
                int resultCount = userMapper.checkEmail(str);  //检查邮箱是否存在
                if(resultCount >0){
                    return ServerResponse.createByErrorMessage("该邮箱已存在");
                }
            }

        }else{
            return ServerResponse.createByErrorMessage("参数错误");
        }
        return ServerResponse.createBySuccessMassage("校验成功");
    }

好,现在既然有了这个校验方法,那么我们是否就可以对之前写的注册逻辑进行修改呢,答案是必须的,否则我们写这个方法干嘛呢!
我们将之前的注册的用户名和邮箱的校验方法进行修改,打开UserServiceImpl.java:

        ServerResponse validResponse =this.checkValid(user.getUsername(),Const.USERNAME);
        if(!validResponse.isSuccess()){   //检查注册时用户名是否存在
            return validResponse;
        }

        validResponse =this.checkValid(user.getEmail(),Const.EMAIL);
        if(!validResponse.isSuccess()){   //检查注册时邮箱是否存在
            return validResponse;
        }

贴上最后修改的代码:


    /**
     * 实现注册的接口类
     * */
    public  ServerResponse<String> register(User user){
//        int resultCount = userMapper.checkUsername(user.getUsername());  //检查注册时用户名是否存在
//        if(resultCount >0){
//            return ServerResponse.createByErrorMessage("该用户已存在");
//        }

//        resultCount = userMapper.checkEmail(user.getEmail());  //检查注册时邮箱是否存在
//        if(resultCount >0){
//            return ServerResponse.createByErrorMessage("该邮箱已存在");
//        }

        ServerResponse validResponse =this.checkValid(user.getUsername(),Const.USERNAME);
        if(!validResponse.isSuccess()){   //检查注册时用户名是否存在
            return validResponse;
        }

        validResponse =this.checkValid(user.getEmail(),Const.EMAIL);
        if(!validResponse.isSuccess()){   //检查注册时邮箱是否存在
            return validResponse;
        }


        user.setRole(Const.Role.ROLE_CUSTOMER);   //该注册用户为一般用户
        //密码加密(定义一个工具类)

        user.setPassword(MD5Util.MD5EncodeUtf8 (user.getPassword()));

        int resultCount =userMapper.insert(user);
        if(resultCount == 0){
            return ServerResponse.createByErrorMessage("注册失败");  //说明可能是数据库错误
        }
        return ServerResponse.createBySuccessMassage("注册成功");

    }

最后,我们还要回到UserController里面,进行路由的配置和方法的调用:

    /***
     * 用于值验证
     * */
    @RequestMapping(value = "check_valid.do",method = RequestMethod.GET)  //这里就是具体的每个方法的url链接
    @ResponseBody   //自动序列化json功能
    public ServerResponse<String> checkValid(String str,String type){
        return iUserService.checkValid(str,type);
    }

总结一下

不知道你发现没有,我们不同的功能的具体实现代码虽然不一样,但是我们都有一些共同的书写方式(其实就是书写顺序):UserController--->IUserService-->UserServiceImpl。而且你发现没有三者非常相似,除了访问修饰符的区别,其他的例如返回值类型,方法名,参数列表(包括参数的个数,类型,顺序一模一样),当然方法体肯定不同的啦(我们以register为例)(实际是除了第一个,后面2个是必须相同的,但一般我们都让三者相同)

这是UserController.java:

public ServerResponse<String> register(User user){
        ......
    }

这是IUserService.java:

ServerResponse<String> register(User user);

这是UserServiceImpl.java:

public  ServerResponse<String> register(User user){
....
}

所以大家对此有个认识以后,后面写代码心里就有数了。这样,我们本篇关于用户登出,注册,校验功能实现的介绍就到此为止了,感谢你的赏阅!

上一篇下一篇

猜你喜欢

热点阅读