IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot+vue+实战项目之第4集 -> 正文阅读

[Java知识库]SpringBoot+vue+实战项目之第4集

1. 实现流程

在这里插入图片描述

2. 后端接口开发

2.1 完成DAO操作

  1. 创建实体类
	@Data
	@NoArgsConstructor
	@AllArgsConstructor
	@ApiModel(value = "User对象",description = "?户/买家信息")
	public class User {
		 private int userId;
		 private String username;
		 private String password;
		 private String nickname;
		 private String realname;
		 private String userImg;
		 private String userMobile;
		 private String userEmail;
		 private String userSex;
		 private Date userBirth;
		 private Date userRegtime;
		 private Date userModtime;
}
  1. 创建DAO接口、定义操作?法
public interface UserDAO {
 	//?户注册
	 public int insert(User user);
 
	 //根据?户名查询?户信息
	 public User query(String name);
};
  1. 创建DAO接口的mapper?件并完成配置
<mapper namespace="com.qfedu.fmmall.dao.UserDAO">
 	<insert id="insertUser">
 		insert into users(username,password,user_regtime,user_modtime)
					 values(#{username},#{password},#{userRegtime},#{userModtime})
 	</insert>
 	<resultMap id="userMap" type="User">
		 <id column="user_id" property="userId"/>
		 <result column="username" property="username"/>
		 <result column="password" property="password"/>
		 <result column="nickname" property="nickname"/>
		 <result column="realname" property="realname"/>
		 <result column="user_img" property="userImg"/>
		 <result column="user_mobile" property="userMobile"/>
		 <result column="user_email" property="userEmail"/>
		 <result column="user_sex" property="userSex"/>
		 <result column="user_birth" property="userBirth"/>
		 <result column="user_regtime" property="userRegtime"/>
		 <result column="user_modtime" property="userModtime"/>
 	</resultMap>
 	<select id="queryUserByName" resultMap="userMap">
 		select
			 user_id,
			 username,
			 password,
			 nickname,
			 realname,
			 user_img,
			 user_mobile,
			 user_email,
			 user_sex,
			 user_birth,
			 user_regtime,
			 user_modtime
		from users
		where username=#{name}
 	</select>
</mapper>

2.2 完成Service业务

  1. 创建service接口
	public interface UserService {
		 //?户注册
		 public ResultVO userResgit(String name, String pwd);
 		 //?户登录
 		 public ResultVO checkLogin(String name, String pwd);
}
  1. 创建service接口实现类,完成业务实现
@Service
public class UserServiceImpl implements UserService {

	 @Autowired
	 private UserDAO userDAO;
	 
 	@Transactional
 	public ResultVO userResgit(String name, String pwd) {
 		synchronized (this) {
 	//1.根据?户查询,这个?户是否已经被注册
		 User user = userDAO.queryUserByName(name);
    //2.如果没有被注册则进?保存操作
 		if (user == null) {
 			 String md5Pwd = MD5Utils.md5(pwd);
			 user = new User();
			 user.setUsername(name);
			 user.setPassword(md5Pwd);
			 user.setUserRegtime(new Date());
			 user.setUserModtime(new Date());
			 int i = userDAO.insertUser(user);
			 if (i > 0) {
			 	return new ResultVO(10000, "注册成功!", null);
			 } else {
			 	return new ResultVO(10002, "注册失败!", null);
			 }
			 } else {
			 	return new ResultVO(10001, "?户名已经被注册!", null);
			 }
		 }
		 @Override
		 public ResultVO checkLogin(String name, String pwd) {
 				User user = userDAO.queryUserByName(name);
				if(user == null){
					 return new ResultVO(10001,"登录失败,?户名不存在!",null);
				 }else{
				 String md5Pwd = MD5Utils.md5(pwd);
				 if(md5Pwd.equals(user.getPassword())){
				 	return new ResultVO(10000,"登录成功!",user);
				 }else{
					 return new ResultVO(10001,"登录失败,密码错误!",null);
	   }
 }

2.3 完成Controller提供接口

  1. 创建controller,调?service
  2. 添加接口注解
@RestController
@RequestMapping("/user")
@Api(value = "提供?户的登录和注册接?",tags = "?户管理")
	public class UserController {
		 @Resource
		 private UserService userService;
 		 @ApiOperation("?户登录接?")
 	     @ApiImplicitParams({
         @ApiImplicitParam(dataType = "string",name = "username", value = "?户登录账
号",required = true),
 		 @ApiImplicitParam(dataType = "string",name = "password", value = "?户登录密
码",required = true)
 })
 		 @GetMapping("/login")
 		 public ResultVO login(@RequestParam("username") String name,
    	 @RequestParam(value = "password") String pwd){
 		 ResultVO resultVO = userService.checkLogin(name, pwd);
         return resultVO;
      }
		 @ApiOperation("?户注册接?")
		 @ApiImplicitParams({
		 @ApiImplicitParam(dataType = "string",name = "username", value = "?户注册账
		号",required = true),
		 @ApiImplicitParam(dataType = "string",name = "password", value = "?户注册密
		码",required = true)
		})
 		@PostMapping("/regist")
	    public ResultVO regist(String username,String password){
 			ResultVO resultVO = userService.userResgit(username, password);
		    return resultVO;
    }
}

2.4 接口测试

基于swagger进行测试

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-09-10 23:55:15  更:2021-09-10 23:56:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 16:57:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码