SSM搭建二手市场交易平台(七):用户登出,注册,校验功能实现
写在前面
本篇我们介绍用户登出,注册和校验功能这三者的实现。大家反映之前那种方式太难理解,好吧这里我们依旧采取把实现具体功能代码放在一块,一步一步的来的模式。
用户登出
打开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){
....
}
所以大家对此有个认识以后,后面写代码心里就有数了。这样,我们本篇关于用户登出,注册,校验功能实现的介绍就到此为止了,感谢你的赏阅!