sprongboot mysql登录注册_后端开发:SpringBoot实现注册与登录功能
這次實現(xiàn)的注冊與登錄功能需要進行數(shù)據(jù)庫的基本操作,而且是前后端分離式開發(fā)。總的來說就是首先進行數(shù)據(jù)庫的設計,然后根據(jù)數(shù)據(jù)庫進行編寫服務端API接口,接著來到客戶端或移動端,進行登錄與注冊的界面設計,接收服務端提供的數(shù)據(jù)并顯示在界面上。本文章主要進行后端API接口設計。后面會進行前端框架數(shù)據(jù)交互設計。
一、數(shù)據(jù)庫設計
根據(jù)一般登錄與注冊的需求,數(shù)據(jù)庫的用戶表結構如下:
二、服務端API接口設計
1、首先進行持久化映射,生成用戶表的模型類
(1)、找到Persistence一欄,選中項目,鼠標右鍵,點擊最底下一個選項。
(2)、選擇模型類的位置,選中用戶表的所有字段,點擊OK。
(3)、找到生成的模型類Users,添加主鍵生成器。在注解@Id下方添加以下代碼:
//指定生成器名稱
@GeneratedValue(generator = "uuid2" )
@GenericGenerator(name = "uuid2", strategy = "org.hibernate.id.UUIDGenerator" )
2、創(chuàng)建DAO層,新建接口類UsersDao。代碼如下:
package edu.ynmd.cms.dao;
import edu.ynmd.cms.model.Users;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import java.util.List;
public interface UsersDao extends JpaRepository {
@Query("select u from Users u where u.username=:username and u.pass=:pass")
List getUsersByUsernameAndPass(@Param("username")String username, @Param("pass") String pass);
}
3、編寫server
(1)、ManageService里面進行增刪查改方法的定義。
//用戶表
Users saveUser(Users users);
boolean deleteUser(String id);
Users getUser(String id);
Users getUserByUserNameAndPass(String username,String pass);
(2)、MangeServiceImpl里面進行具體方法的實現(xiàn)。
//*****************************用戶表增刪查改開始*********************************
@Override
public Users saveUser(Users users) {
try {
return usersDao.save(users);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
@Override
public boolean deleteUser(String id) {
try {
usersDao.deleteById(id);
return true;
} catch (Exception e) {
e.printStackTrace();
}
return false;
}
@Override
public Users getUser(String id) {
Optional temp=usersDao.findById(id);
return temp.isPresent()?temp.get():null;
}
@Override
public Users getUserByUserNameAndPass(String username, String pass) {
List ul=usersDao.getUsersByUsernameAndPass(username,pass);
if(ul.size()>0){
return ul.get(0);
}
return null;
}
4、來到PublicAction,編寫API接口
//用戶登錄方法
@PostMapping("/login")
@ResponseBody
public HashMap login(
@RequestBody Account account) throws IOException {
Users u=manageService.getUserByUserNameAndPass(account.username,account.password); //獲取用戶表的用戶名和密碼
if(u!=null){
String jwt= JwtUtil.generateToken(u.getRoleid(),u.getUsersid()); //獲取用戶角色和用戶ID
return new HashMap(){{
put("msg","ok");
put("token",jwt);
put("role",u.getRoleid());
// put("role","admin");
}};
}
else {
return new HashMap(){{
put("msg","error");
put("token","error");
}};
}
}
public static class Account{
public String username;
public String password;
}
//用戶注冊
@PostMapping("saveUser")
@ResponseBody
public HashMap saveUser(@RequestBody Users users) throws Exception{
HashMap m=new HashMap();
try {
users.setRoleid("member");
manageService.saveUser(users);
m.put("msg","ok");
} catch (Exception e) {
e.printStackTrace();
m.put("msg","error");
}
return m;
}
最后,啟動項目進行測試。
三、使用postman進行注冊與登錄測試
1、postman注冊測試
2、查看數(shù)據(jù)庫內容,可以看到剛剛已經(jīng)注冊成功
3、postman登錄測試
4、輸入一個錯誤密碼,測試能不能登錄
到此,服務端API接口已經(jīng)實現(xiàn),后面會寫關于客戶端和移動端與API接口進行數(shù)據(jù)交互的文章,敬請期待!
總結
以上是生活随笔為你收集整理的sprongboot mysql登录注册_后端开发:SpringBoot实现注册与登录功能的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ios html 禁止下拉,ios禁止页
- 下一篇: iptables 配置后连接不上数据库_