首页 > 编程语言 >JAVA-Springboot实践项目-用户注册

JAVA-Springboot实践项目-用户注册

时间:2023-08-02 17:36:40浏览次数:29  
标签:mapper Mapper 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进行一些关于逻辑上的判断,比较方便

当然了对于相关变量一定要注意驼峰命名法

//任何实体类get和set方法、equals和hashcode()方法、toString方法 在UserMapper中不建议使用@Mapper,因为一个程序中会有很多的@Mapper 因此在StoreApplication中使用MapperScan //MapperScan注解指定当前项目中的Mapper接口路径的位置,在项目启动的时候会自动加载所有的接口
@MapperScan("com.cy.mapper")

标签:mapper,Mapper,JAVA,Springboot,用户注册,创建,接口,参数,方法
From: https://www.cnblogs.com/smiling-weeping-zhr/p/17543206.html

相关文章

  • java报错:unable to find valid certification path to requested target
    问题发现unabletofindvalidcertificationpathtorequestedtarget当我使用java代码访问某个URL的时候,报了这个错误,经过查询发现需要安装证书到java环境,所以记录一下。下载证书我使用的是chrome浏览器,点击地址栏左边小锁,选择第一个选项。然后选择证书有效。在弹出的......
  • Java实践项目 - 用户登录
    Smiling&Weeping----以花祈愿,祝你平安 当用户输入用户名和密码将数据提交给数据库进行查询,如果存在对应的用户名和密码,则表示登陆成功,登录成功之后跳转到系统的主页就是index.html页面,跳转在前端使用jQuery来完成1.登录-持久层1.......
  • Java编程-依据类图与流程图实现对应接口
    类图依据与流程图依据封装常见的HTTP状态码RegisterController接口register(Stringname,Stringpwd)login(Stringname,Stringpwd)NovelController接口addNovel()asdfasdfasdfasdfasdfasdfasdfasdfasdfasdfNovelContentController接口asdfasdfasdfasdfasdf......
  • 学习Java的第12天
    packageoperator;publicclassDemo04{publicstaticvoidmain(String[]args){//++--自增,自减一元运算符inta=3;intb=a++;//执行完这行代码后,先给b赋值,再自增//a=a+1System.out.println(a);//a=......
  • 2023年Java学习路线,史上最全Java学习路线-文中有送书福利
    小伙伴们大家好,这里是动力节点,我们从2009年开始一直在从事Java培训到今年已经整14年了,虽然现在不缺培训机构,更不缺Java培训,但是像我们这么多年专注这一件事的应该也不多。我们只希望在“专业”两个字上面不断精进,给每一位想学Java的同学带来更好的资源和学习规划。我们深知,有很多同......
  • idea查看java代码汇编指令
    将下列jar包放入到jre的bin目录下面   hsdis-amd64.dll指定java的jvm参数-server-Xcomp-XX:+UnlockDiagnosticVMOptions-XX:+PrintAssembly-XX:CompileCommand=compileonly,*VolitaleDemo.main运行......
  • java位运算及移位运算你还记得吗
    本文中所提到的运算都是基于整数来说的,因为只有整数(包括正数和负数)在操作系统中是以二进制的补码形式运算的,关于原码、反码、补码、位运算、移位运算的背景这里不再介绍,网上资料很多,感兴趣的可自行搜索。java中能表示整数数据类型的有byte、short、char、int、long,在计算机中占用......
  • Kotlin与Java语法对比学习
    定义变量//Kotlinvali:Int=10//定义一个整数变量vald:Double=10.0//定义一个双精度浮点数变量valb:Boolean=true//定义一个布尔变量valc:Char='a'//定义一个字符变量vals:String="Hello,World!"//定义一个字符串变量valarr:Array<I......
  • Java编程-目录整理、新建接口、集成mybatis plus以及数据库初始化
    数据库初始化新建对应调试库```#dockerps#dockerexec-it6d542566d077/bin/bashpostgres=#createdatabasenovel;```执行全量脚本......
  • Java是如何处理异常的?
    Java异常处理是通过五个关键字来完成的:try、catch、finally、throw和throws。try:这个块用来包裹可能会引发异常的代码。catch:这个块用来捕获异常。可以有多个catch块来捕获不同类型的异常。finally:这个块无论是否捕获到异常都会执行。通常用于关闭资源等。throw:用于手动抛......