JAVA-Springboot实践项目-用户注册
Smiling & Weeping
----我本没喜欢的人,
见你的次数多了,
也就有了。
1.创建数据表
1.1.选中数据表:
use store
1.2.创建t_user表:
2创建用户实体类
2.1通过表的结构提取出表的公共字段,放在一个实体类的基类中,起名BaseEntity基类中
主要作用是声明变量(私有),再使用get和set(Alt+insert生成),注意驼峰命名法
2.2创建用户的实体类,需要继承BaseEntity基类
public class User extends BaseEntity implements Serializable{}
注意:一定要声明1.get和set方法 2.equals()和hashcode()方法 3.toString()方法
3.注册-持久层
通过MyBatis来操作数据库,在做mybatis开发的流程
3.1规划需要执行的SQL语句
3.1.1用户的注册功能,相当于在做数据的插入操作
insert into t_user(username , password) values(值列表)
3.1.2在用户注册时要去先查询当前的用户名是否存在,如果存在则不能注册相当于使用一条查询语句
select * from t_user where usename=?
3.2设计接口和方法
定义Mapper接口在项目的目录结构下首先创建一个mapper包,在这个包下再根据不同的功能模块创建mapper接口,创建一个UserMapper的接口(Interface)。要在接口中定义这两个SQL语句抽象方法。
在UserMapper中不建议使用@Mapper,因为一个程序中会有很多的@Mapper
因此在StoreApplication中使用MapperScan
//MapperScan注解指定当前项目中的Mapper接口路径的位置,在项目启动的时候会自动加载所有的接口
@MapperScan("com.cy.mapper")
3.3编写映射
3.3.1定义xml映射文件,与对应接口进行关联。所有的映射文件需要放置resources目录下,在这个目录下创建一个mapper文件夹,然后在这个文件夹下存放Mapper的映射文件。
配置文件:(在官网可以直接拿到https://mybatis.org/mybatis-3/zh/getting-started.html)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.mybatis.example.BlogMapper">
<select id="selectBlog" resultType="Blog">
select * from Blog where id = #{id}
</select>
//selct语句可以暂时删掉,自己进行声明
</mapper>
1 <?xml version="1.0" encoding="UTF-8" ?>
2 <!DOCTYPE mapper
3 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
4 "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
5 <!--namespace的属性:用于指定当前的映射文件和哪个接口进行映射,需要制定接口的文件路径,需要标注包的完整路径结构-->
6 <!--自定义映射规则:resultMap标签来完成映射规则的定义-->
7 <mapper namespace="com.cy.store.mapper.UserMapper">
8
9 <!--
10 id属性:表示给这个映射规则分配一个唯一的id值,对应的就是resultMap="id"属性的取值
11 type属性:取值是一个类,表示的是数据库中查询的结果与Java中哪个实体类进行结果集的映射
12 -->
13 <!--不能使用resultType是因为字段名称不一致-->
14 <resultMap id="UserEntityMap" type="com.cy.store.entity.User">
15 <!--只做一件事:将表的资源和类的属性不一致的字段进行匹配指定,名称一致的字段可以省略不写-->
16 <!--
17 配合完成名称不一致的映射
18 column属性:表示表中资源名称
19 property属性:表示类中的属性名称
20 -->
21 <!--在定义映射规则时主键是不可以省略的,不论名称是否一致-->
22 <id column="uid" property="uid"></id>
23 <result column="is_delete" property="isDelete"></result>
24 <result column="created_user" property="createdUser"></result>
25 <result column="created_time" property="createdTime"></result>
26 <result column="modified_user" property="modifiedUser"></result>
27 <result column="modified_time" property="modifiedTime"></result>
28 </resultMap>
29 <!--id属性:表示映射的接口中方法的名称,直接在标签的内部来编写SQL语句-->
30 <!--
31 useGeneratedKeys属性:表示开启某个字段的值递增(一般主键设置为递增)
32 keyProperty属性:表示将表中的哪个字段作为主键进行递增
33 -->
34 <insert id="insert" useGeneratedKeys="true" keyProperty="uid">
35 INSERT INTO t_user (
36 username,password,salt,phone,email,gender,avatar,is_delete,
37 created_user,created_time,modified_user,modified_time
38 )VALUES(
39 #{username},#{password},#{salt},#{phone},#{email},#{gender},#{avatar},#{isDelete},
40 #{createdUser},#{createdTime},#{modifiedUser},#{modifiedTime}
41 )
42 </insert>
43 <!--select语句在执行的时候,查询的是一个对象,多个对象-->
44 <!--
45 若是单个对象:
46 resultType:表示查询的结果集类型,只需要指定对应映射类的类型,并且包含完整包接口
47 resultMap:表示当表的资源和类的对象属性的字段名称不一致时,来自定义查询结果集的映射规则
48 -->
49 <select id="findByUsername" resultMap="UserEntityMap">
50 SELECT * FROM t_user WHERE username = #{username}
51 </select>
52 </mapper>
namespace属性:用于指定当前映射文件和哪个接口进行映射,需要指定接口的文件路径,需要标注包的完整路径接口
id属性:表示映射的接口中方法的名称,直接在标签的内部来编写SQL语句
比如com.cy.store.mapper.UserMapper
3.3.2创建接口对应的映射文件,遵循和接口的名称一致即可。创建UserMapper.xml
3.3.3配置接口方法对应上的SQL语句。需要借助标签来完成,insert、update、delete、select,对应的是SQL的增删改查操作
values后面是小括号
3.3.4将mapper文件位置注册到properties对应的配置文件中
mybatis.mapper-locations=classpath:mapper/*.xml
3.3.5单元测试:每个独立的层编写完毕之后需要编写单元测试方法,来测试当前的功能,在test包结构下创建一个mapper包,在这个包下在创建持久层的功能测试
4.注册-业务层
4.1规划异常
4.1.1用户在进行注册的时候可能会产生用户名被占用的错误,抛出一个异常:
正在执行数据插入操作的时候,服务器、数据库宕机。处于正在执行插入的过程中所产生的异常:insertException
RuntimeException异常,作为这类异常的子类,然后再去定义具体的异常类型来继承这个异常,业务层异常的基类,ServiceException异常,这个异常继承RuntimeException异常。
4.1.1异常E,接口I,implement
4.1.1根据业务层不同的功能来详细定义具体的异常的类型,统一的去继承ServiceException异常类
4.2设计接口和抽象方法
4.2.1创建一个实现类UserServicelmpl类,需要实现这个接口,并且实现抽象的方法
4.2.2单元测试包下创建一个UserServiceTests
4.2.3一定要保存盐值
5.注册-控制层
5.1创建响应
状态描述信息、数据。这部分功能封装一个类中,将这个类作为方法值,返回给前端浏览器
5.2设计相关的请求
依据当前的业务功能模块进行请求的设计
请求路径:/users/reg
请求参数:User user
请求类型:POST
响应结果:JsonResult<Void>
5.3处理请求
5.3.1创建一个控制层对应的类UserController类。依赖于业务层的接口。
5.4控制层优化设计
在控制抽离一个父类,在这个父类中统一的去处理关于异常的相关操作。编写一个Basecontroller类,统一处理异常。
6.前端业务开发
6.1在register页面中编写发送请求的方法,点击事件来完成。选选中对应的按钮(¥(“选择器”)),再去添加点击事件,$.ajax()函数发送异步请求
6.2JQUery封装了一个函数,称之为$.ajax函数通过对象来调用ajax函数,可以异步加载相关的请求。依靠的是JavaScript提供的一个对象XHR(XMLHTTPResponse),封装了这个对象
6.3ajax使用方式,语法结构:
需要传递一个方法体作为方法的参数来使用
$.ajax();
function fun(){
}
但一般不这么使用,一般:一对大括号称之为方法体,ajax接收多个参数,参数与参数之间要求使用逗号进行分割,每个参数使用:分割,参数的组成部分一个是参数的名称(不能随变定义),是参数的值,,参数的值要求使用字符串来表识:
$.ajax({
url:"",
type:"",
data:"",
dataType:"",
sucess:"",
sucess: function(){
},
error: function(){
}
});
ajax函数参数的含义:
url : 表示请求的地址(URL地址),不能包含参数列表部分的内容,例如:“localhost:8080/users/reg”
type : 请求类型(GET和POST请求的类型)。例如:type:"POST"
data : 向指定的请求URL地址发送数据。例如:data:"username=tom&pwd=123"
dataType : 提交的数据类型一般指定为JSON类型。dataType:“json”
success : 当服务器正常响应客户端时,会自动的调用succees参数方法,并将服务器返回的数据以参数的方式传递给这个方法的参数上
error : 当服务器未正常响应客户端时,会自动的调用error参数方法,并将服务器返回的数据以参数的方式传递给这个方法的参数上
6.5js代码可以独立存放在一个JS的文件里或者声明在一个script标签里
我们为了进行一些数据的控制,我们对基本类型我们使用包装类来完成,包装类中提供了一些相关的API,所以用的时候,可以调用一些相关的API进行一些关于逻辑上的判断,比较方便
当然了对于相关变量一定要注意驼峰命名法
@MapperScan("com.cy.mapper")
JAVA-Springboot实践项目-用户注册的更多相关文章
- Java SpringBoot 项目构建 Docker 镜像调优实践
PS:已经在生产实践中验证,解决在生产环境下,网速带宽小,每次推拉镜像影响线上服务问题,按本文方式构建镜像,除了第一次拉取.推送.构建镜像慢,第二.三-次都是几百K大小传输,速度非常快,构建.打包.推 ...
- 《Java 程序设计》课堂实践项目 课后学习总结
<Java 程序设计>课堂实践项目 课后学习总结 String类的使用(sort) 目录 Linux命令(sort) 课堂实践 课后思考 学习老师的代码之后的思考:int与Integer ...
- 《Java 程序设计》课堂实践项目汇总链接
1.<Java 程序设计>课堂实践项目-命令行参数 2.<Java 程序设计>课堂实践项目-mini dc 3.<Java 程序设计>课堂实践项目-Arrays和S ...
- 《Java 程序设计》课堂实践项目-类定义
<Java 程序设计>课堂实践项目类定义 课后学习总结 目录 改变 类定义实验要求 课堂实践成果 课后思考 改变 修改了博客整体布局,过去就贴个代码贴个图很草率,这次布局和内容都有修改. ...
- 《Java 程序设计》课堂实践项目-简易计算器
<Java 程序设计>课堂实践项目简易计算器 课后学习总结 目录 改变 简易计算器实验要求 课堂实践成果 课后思考 改变 修改了博客整体布局,过去就贴个代码贴个图很草率,这次布局和内容都有 ...
- 《Java 程序设计》课堂实践项目-Arrays和String单元测试
<Java 程序设计>课堂实践项目-Arrays和String单元测试 课后学习总结 目录 改变 Arrays和String单元测试实验要求 课堂实践成果 课后思考 改变 修改了博客整体布 ...
- 20155308 2016-2017-2《Java程序设计》课堂实践项目
20155308 2016-2017-2<Java程序设计>课堂实践项目 在java.lang包中有String.split()方法,返回是一个数组 我在应用中用到一些,给大家总结一下,仅 ...
- # 20155308 2016-2017-2《Java程序设计》课堂实践项目 5月17日
20155308 2016-2017-2<Java程序设计>课堂实践项目 5/17 本次因为git出现了问题,所以没有按时提交我的代码 问题一 在IDEA中对P145 MathTool.j ...
- 20155320 2016-2017-2《Java程序设计》第十二周课堂实践项目
20155320 2016-2017-2<Java程序设计>第十二周课堂实践项目 1.修改教材P98 Score2.java, 让执行结果数组填充是自己的学号: 2.在IDEA中以TDD的 ...
- 20155321 2016-2017-2《Java程序设计》课堂实践项目2
20155321 2016-2017-2<Java程序设计>课堂实践项目2 实践内容 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数: ...
随机推荐
- 代码随想录算法训练营Day14 二叉树
代码随想录算法训练营 代码随想录算法训练营Day14 二叉树|理论基础 递归遍历 基础知识 二叉树都是通过栈来实现的. 二叉树的种类 在我们解题过程中二叉树有两种主要的形式:满二叉树和完全二叉树. 满 ...
- 前端vue uni-app列表组件 list组件,简单好用
快速实现uni-app列表组件 list组件,简单好用; 下载完整代码请访问uni-app插件市场地址:https://ext.dcloud.net.cn/plugin?id=12675 效果图如下: ...
- 3. HelloWorld的实现
恐惧是本能,行动是信仰(在此感谢尚硅谷宋红康老师的教程) 1. 新建 Project - Class 选择"New Project": 指名工程名.使用的 JDK 版本等信息.如下 ...
- React后台管理系统(TypeScript、Redux状态管理)环境搭建01
搭建环境的时候,我们必须要先确保环境有node环境和npm环境,如下使用cmd命令 确保自己有了这两个环境之后我们就可以开始搭建项目,首先找一个文件夹,这个文件夹用来初始化当前环境,例如,我这里选 ...
- PostgreSQL 12 文档: 前言
前言 目录 1. 何为PostgreSQL? 2. PostgreSQL简史 2.1. 伯克利的POSTGRES项目 2.2. Postgres95 2.3. PostgreSQL 3. 约定 4. ...
- Spring MVC 前后台传递json格式数据 Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported
若使用默认的json转换器,则需要如下包: <mvc:annotation-driven /> 报错如下: Content type 'application/x-www-form-url ...
- 基于Surprise协同过滤实现短视频推荐
前言 前面一文介绍了通过基础的web项目结构实现简单的内容推荐,与其说那个是推荐不如说是一个排序算法.因为热度计算方式虽然解决了内容的时效质量动态化.但是相对用户而言,大家看到的都是几乎一致的内容 ...
- 从头学Java17-Lambda表达式
Lambda表达式 这一系列教程,旨在介绍 lambda 的概念,同时逐步教授如何在实践中使用它们. 回顾表达式.语句 表达式 表达式由变量.运算符和方法调用组成,其计算结果为单个值.您已经看到了表达 ...
- Istio 入门(三):体验 Istio、微服务部署、可观测性
本教程已加入 Istio 系列:https://istio.whuanle.cn 目录 3,快速入门 书店微服务 预先准备 details 应用 ratings 应用 reviews v1/v2/v3 ...
- jar包、war包项目部署
部署 部署 jar包 部署 war包 部署 jar包 环境准备 JDK Tomcat Linux 环境 1.将jar文件上传至服务器 2.编写脚本 启动脚本放在跟jar 一起的路径下,如果不放在同一路 ...