首頁 > Java > java教程 > springboot如何實現使用者名稱查找使用者功能

springboot如何實現使用者名稱查找使用者功能

王林
發布: 2023-05-13 08:58:05
轉載
1267 人瀏覽過

為了實現根據使用者名稱查詢使用者功能,我們需要在spring boot框架當中編寫幾個類別:

1、UserEnetity類別

它是根據資料庫表的實體類,用於封裝使用者的基本資訊。在這個表當中,需要定義與使用者相關的屬性,並提供getter和setter方法。

public class UserEntity {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int id;
 
    private String name;
 
 
    public String getUsername() {
        return username;
    }
 
    public void setUsername(String username) {
        this.username = username;
    }
 
    private String username;
 
 
    private int role;
    private String avatar;
    private int status;
    private String password;
 
 
    public UserEntity(int id, String name, int role, String avatar, int status, String password,String username,String token) {
        this.id = id;
        this.name = name;
        this.role = role;
        this.avatar = avatar;
        this.status = status;
        this.password = password;
        this.username = username;
    }
 
    public UserEntity() {
 
    }
 
 
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
 
 
    public int getRole() {
        return role;
    }
 
    public void setRole(int role) {
        this.role = role;
    }
 
    public String getAvatar() {
        return avatar;
    }
 
    public void setAvatar(String avatar) {
        this.avatar = avatar;
    }
 
    public int getStatus() {
        return status;
    }
 
    public void setStatus(int status) {
        this.status = status;
    }
 
    public String getPassword() {
        return password;
    }
 
    public void setPassword(String password) {
        this.password = password;
    }
}
登入後複製

2、UserMapper類別

它是基於MyBatis的接口,用於定義資料庫操作的方法,例如查詢使用者、新增使用者、更新使用者等。

@Mapper
public interface UserMapper extends BaseMapper {
    List<UserEntity> findAllUser();
 
    UserDTO getUserByUsername(String subject);
}
登入後複製

3、UserService類別

它是業務邏輯層,主要負責協調UserMapper類別和User Entity類別之間的關係,實現業務邏輯的處理。在這個類別中,需要定義根據使用者名稱查詢使用者的方法,並呼叫UserMapper類別的方法實作查詢操作。

   //用户名查询用户
    public ResultResponse findByUsername(String name) {
        QueryWrapper<UserEntity> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("name", name);
        UserEntity user = (UserEntity) userMapper.selectOne(queryWrapper);
        if (user != null) {
            return ResultResponse.returnToken(ResultResponse.success("查询成功", user));
        } else {
            return ResultResponse.returnToken(ResultResponse.fail("查询失败,该用户不存在"));
        }
    }
登入後複製

4、UserController類別

它是控制器層,用於處理使用者請求,傳回對應的結果。在這個類別中,需要定義請求處理方法,例如根據使用者名稱查詢使用者的方法,以及傳回JSON格式的資料。

   //根据用户名查询用户--查询结果分每页十条显示
    @GetMapping("user/findByUsername")
    public ResultResponse<IPage<UserEntity>> findByUsername(@RequestParam String username,
                                                            @RequestParam Integer pageNumber,
                                                            @RequestParam Integer pageSize) {
        Page<UserEntity> userPage = new Page<>(pageNumber, pageSize);
//        IPage<UserEntity> user = (IPage<UserEntity>) userService.selectByUsername(userPage, username);
        UserEntity user = userService.selectByUsername(userPage,username);
 
        if (user == null) {
            return ResultResponse.error("没有找到匹配的用户");
        }
        return ResultResponse.ok("查询成功",user);
    }
登入後複製

總之,這四個類別都是需要寫的,而且它們之間的關係也需要設計好。其中,User Entity類別與UserMapper類別與資料庫之間的關係較緊密,UserService類別則是作為業務邏輯層的核心,而UserController類別則是作為控制器層的核心,負責處理使用者請求和回傳回應結果。

5、postman測試結果

springboot如何實現使用者名稱查找使用者功能

#

以上是springboot如何實現使用者名稱查找使用者功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板