java怎么实现用户登录和注册,java实现用户登陆
一、前言在爪哇开发过程中,实现用户的注册功能是最基本的,用户通过手机号或者邮箱作为注册账号也是非常常见的操作方式,不管是通过手机号注册或者邮箱注册,原理都差不多,那么本文就来分享一下在爪哇开发过程中的用户注册账号的功能实现。
二、准备工作1、通过爪哇语言来实现用户注册登录的后台功能;
2、使用环境有JDK6、Eclipse、Oracle10G、Tomcat等;
三、具体实现思路及核心步骤1、数据库设计
数据库的表名称以及要求:
表名:用户主键:id
字段名称:id:用户id,用户名:用户名称,密码:密码,group_id:用户类型id 创建数据表,创建主、外键,创建序列,新加测试数据
2、使用黯然失色创建网项目用户演示
3、给项目工程添加春天、冬眠等支持,并且正确引入集成到项目中,以及配置
4、创建数据持久化类,以及对应的映射文件,让用户类型和用户之间建立双向一对多的关系
5、新建接口以及实现类,使用春天数据库对象实现对应数据库的操作
6、创建服务接口以及实现类,并且实现对应的业务逻辑
7、创建行为类,并引入接口和访问器,完成配置文件
8、新建春天配置文件,实现对应的对象声明和配置
9、前端部分的界面搭建,以及接口联调
10、测试环节:调试运行成功之后将对应的相关数据库对象导出结构化查询语言文件,以及用户注册数据的备份机制处理,完成测试,实现用户注册登录的功能。
四、核心代码1、UserService.java文件的核心代码公共接口用户服务{
/**
* 用户注册
*
* @param userId
* @param dto
* @抛出异常
*/
void userRegister(Long userId,UserRegisterDTO dto)抛出异常;
/**
* 忘记密码
*
* @param userId
* @param dto
* @抛出异常
*/
void updatePassword(Long userId,UpdatePasswordDTO)抛出异常;
/**
* 通过邮箱发送验证码
*
* @param userId
* @param电子邮件
* @抛出商业异常
*/
void sendVerificationCode(长用户Id,字符串电子邮件)抛出商业异常
/**
* 通过用户名密码获取用户
*
* @param登录名称
* @param loginPwd
* @返回
* @抛出商业异常
*/
用户getUser(String loginName,String loginPwd)抛出商业异常
}2、UserController.java文件的核心代码@RestController
@Slf4j
公共类用户控制器扩展基本控制器{
私有最终用户服务用户服务;
@自动连线
公共用户控制器(用户服务用户服务){
this.userService=userService
}
/**
* 会员注册
*
* @param dto
* @param请求
* @返回
* @抛出异常
*/
@ApiOperation(value=会员注册,produces=application/json )
@ API响应({ @ API响应(code=Ajax return .成功,消息=注冊成功,response=AjaxReturn.class)})
@ post映射(path={ /user-save })
公共Ajax返回用户注册(@ model属性user registerdto,HttpServletRequest请求)引发异常{
日志。信息(dto。tostring());
Long userId=getAuthentication(请求);
if(字符串实用程序。为空(dto。get mobile())string utils。为空(dto。获取电子邮件()){
抛出新的BusinessException(请输入手机号或邮箱);
}
if(字符串实用程序。isnotblank(dto。获取移动())!字符串实用程序。isnumeric(dto。获取手机()){
抛出新的BusinessException(请输入正确的手机号);
}
if(字符串实用程序。isnotblank(dto。getemail())!字符串实用程序。isemail(dto。getemail()){
抛出新的BusinessException(请输入正确的邮箱);
}
if(字符串实用程序。为空(dto。getloginpwd()){
抛出新的BusinessException("密码不得为空");
}
//密码讯息摘要5加密
dto。setloginpwd(digestutils。MD 5十六进制(dto。getloginpwd()));
if(字符串实用程序。为空(dto。getverificationcode()){
抛出新的BusinessException("验证码不得为空");
}
用户服务。用户注册(userId,dto);
返回AjaxReturn.builder().build();
}
/**
* 忘记密码
*
* @param dto
* @param请求
* @返回
* @抛出异常
*/
@ApiOperation(value=忘记密码,produces=application/json )
@ API响应({ @ API响应(code=Ajax return .成功,消息=更新密码成功,response=AjaxReturn.class)})
@ post映射(path={ /user-password-forget })
公共Ajax返回更新密码(@ model属性updatepasswordto,HttpServletRequest请求)引发异常{
Long userId=getAuthentication(请求);
if(字符串实用程序。为空(dto。get mobile())string utils。为空(dto。获取电子邮件()){
抛出新的BusinessException(请输入手机号或邮箱);
}
if(字符串实用程序。isnotblank(dto。获取移动())!字符串实用程序。isnumeric(dto。获取手机()){
抛出新的BusinessException(请输入正确的手机号);
}
if(字符串实用程序。isnotblank(dto。getemail())!字符串实用程序。isemail(dto。获取手机()){
抛出新的BusinessException(请输入正确的邮箱);
}
if(字符串实用程序。为空(dto。getloginpwd()){
抛出新的BusinessException("密码不得为空");
}
//密码讯息摘要5加密
dto。setloginpwd(digestutils。MD 5十六进制(dto。getloginpwd()));
if(字符串实用程序。为空(dto。getverificationcode()){
抛出新的BusinessException("验证码不得为空");
}
用户服务。更新密码(userId,dto);
返回AjaxReturn.builder().build();
}
/**
* 通过邮件发送验证码
*
* @param电子邮件
* @param请求
* @返回
* @抛出商业异常
*/
@ApiOperation(value=通过邮件发送验证码,produces=application/json )
@ API响应({ @ API响应(code=Ajax return .成功,消息=通过邮件发送验证码成功,response=AjaxReturn.class)})
@ post映射(path={ /验证码-发送 })
公共Ajax返回sendVerificationCode(@ API param(name= email ,value=邮箱,required=true)@ request param字符串email,HttpServletRequest)抛出BusinessException {
Long userId=getAuthentication(请求);
用户服务。sendverificationcode(userId,email);
返回AjaxReturn.builder().build();
}
}3、登录控制器文件
五、注意事项1、注意代码的书写、命名规范;
2、在关键代码处加注解,方便后期维护;
3、考虑控件摆放整齐,留意界面美观;
4、在操作数据库的时候需要注意必要的异常处理,建立容错机制。
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。