我的第一個項目(五):(前後端)註冊用戶名查重

来源:https://www.cnblogs.com/FatTiger4399/archive/2022/12/02/16939674.html
-Advertisement-
Play Games

好家伙, bug終究還是來了,而且是很離譜的bug 來吧,發現問題,再解決問題 1.註冊無法檢測到用戶名重覆 也就是說一個用戶名可無限註冊, 來看bug(。。。) (看來是後端驗證邏輯出了問題) 要是這麼上線估計直接寄了 2.完成註冊用戶名查重 大概率是後端出了問題 這裡我們先去看看後端,從後端去改 ...


好家伙,

 

bug終究還是來了,而且是很離譜的bug

來吧,發現問題,再解決問題

 

1.註冊無法檢測到用戶名重覆

也就是說一個用戶名可無限註冊,

來看bug(。。。)

 (看來是後端驗證邏輯出了問題)

要是這麼上線估計直接寄了

 

 

2.完成註冊用戶名查重

大概率是後端出了問題

這裡我們先去看看後端,從後端去改寫

 

SysUserController.java文件:

來看看主要的註冊方法

@PostMapping("register")
//    zxcv1234
    //@RequestBody主要用來接收前端傳遞給後端的json字元串中的數據的(請求體中的數據的);
    public CommonResp register(@RequestBody  SysUserSaveReq req){
        //對密碼進行md5加密
        req.setPassword(DigestUtils.md5DigestAsHex(req.getPassword().getBytes()));
        //resp為返回數據
        CommonResp resp = new CommonResp<>();
        //真正的註冊
        SysUserSaveResp saveResp = sysUserService.register(req);
        return resp;

 

SysUserServiceImpl.java中重寫register方法:

    @Override
    public void register(SysUserSaveReq req) {
        //
        SysUserEntity user = CopyUtil.copy(req, SysUserEntity.class);
        //ObjectUtils.isEmpty判斷對象是否為空
        if(ObjectUtils.isEmpty(req.getId())){
            //查看該用戶是否已註冊
            SysUserEntity userDb = selectByLoginName(req.getLoginName());
            //用戶未被註冊
            if(ObjectUtils.isEmpty(userDb)){
                //用演算法給幫它設置一個新ID
                user.setId(snowFlake.nextId());
                //這步是真正的往資料庫里插數據了
                sysUserMapper.insert(user);
            }
        }        
    }

//查詢loginName是否被註冊
    public SysUserEntity selectByLoginName(String loginName){
        //QueryWrapper<>()
        QueryWrapper<SysUserEntity> wrapper = new QueryWrapper<>();
        //這句可真是太高級了
        //wrapper.lambda().eq()單表查詢,在"SysUserEntity::getLoginName"找一個指定的"loginName"
        //此處原公式為
        wrapper.lambda().eq(SysUserEntity::getLoginName,loginName);
        //BaseMapper的selectList()方法,根據id批量查詢
        List<SysUserEntity> userEntityList = sysUserMapper.selectList(wrapper);

//        List<SysUserEntity> userEntityList = sysUserMapper.selectList(wrapper.lambda().eq(SysUserEntity::getLoginName,loginName));
        //CollectionUtils.isEmpty()判斷集合是否為空
        if(CollectionUtils.isEmpty(userEntityList)){
            //若判斷為空,則返回null,意思是沒被註冊過
            return  null;
        }else {
            return userEntityList.get(0);
        }
    }

隨後我們就發現問題了,

 

能看出來,

這裡的業務邏輯只處理了"用戶名未被註冊"的情況,

而沒有處理"用戶名已註冊"的情況

 

所以我們加上就好了

SysUserServiceImpl.java中重寫register方法:

    //不知道返回什麼,隨便造個對象返回
    private SysUserSaveResp useless;


    @Override
    public SysUserSaveResp register(SysUserSaveReq req) {
        //
        SysUserEntity user = CopyUtil.copy(req, SysUserEntity.class);
        //ObjectUtils.isEmpty判斷對象是否為空
        if(ObjectUtils.isEmpty(req.getId())){
            //查看用戶名是否已註冊
            SysUserEntity userDb = selectByLoginName(req.getLoginName());
            //用戶名未被註冊
            if(ObjectUtils.isEmpty(userDb)){
                //用演算法給幫它設置一個新id
                user.setId(snowFlake.nextId());
                //這步是真正的往資料庫里插數據了
                sysUserMapper.insert(user);
                //哈哈,沒東西返回了
            }else{
                //用戶名已被註冊,返回null
                return null;
            }
        }
        return this.useless;
    }

 

在SysUserController.java文件中:

增加一個"註冊失敗"判定:

@PostMapping("register")
//    zxcv1234
    //@RequestBody主要用來接收前端傳遞給後端的json字元串中的數據的(請求體中的數據的);
    public CommonResp register(@RequestBody  SysUserSaveReq req){
        //對密碼進行md5加密
        req.setPassword(DigestUtils.md5DigestAsHex(req.getPassword().getBytes()));
        //resp為返回數據
        CommonResp resp = new CommonResp<>();
        //真正的註冊
        SysUserSaveResp saveResp = sysUserService.register(req);
        if(saveResp ==null){
            resp.setSuccess(false);
        }
        return resp;
    }

 

來到我們的前端,註冊檢驗部分的代碼:

同樣,我們增加對"註冊失敗"的判定

//檢驗註冊是否成功
                    if (data.success) {
                        //清空表單數據
                        this.ruleForm = {};
                        //發送成功通知
                        this.$message({
                            message: '恭喜你,註冊成功,點擊去登陸按鈕進行登陸吧!!!',
                            type: 'success'
                        });
                        this.$router.push({ path: '/login' })
                    }
                    //註冊失敗
                    if (!data.success) {
                        this.$message({
                            message: '註冊失敗,該用戶名已被註冊',
                            type: 'error'
                        });
                    }

 

然後就,搞定了

 

3.資料庫表

login_name必須是唯一值,要把unique點上

 

 

 

4.gitee倉庫拿源碼

(已更新,解決了註冊用戶名重覆的問題)

 https://gitee.com/tang-and-han-dynasties/login-entity.git


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 概要 在前端下載文件是個很通用的需求,一般後端會提供下載的方式有兩種: 直接返迴文件的網路地址(一般用在靜態文件上,比如圖片以及各種音視頻資源等) 返迴文件流(一般用在動態文件上,比如根據前端選擇,導出不同的統計結果 excel 等) 第一種方式比較簡單,但是使用場景有限。第二種方式通用性更好,最近 ...
  • 一、position 定位屬性和屬性值position 定位屬性,檢索對象的定位方式;語法:position:static /absolute/relative/fixed/sticky/unset/inherit(未設置是inherit和initial的結合)/initial(最初的,初始的)取值 ...
  • JQuery02 4.jQuery選擇器02 4.3過濾選擇器 4.3.1基礎過濾選擇器 $("li:first") //第一個li $("li:last") //最後一個li $("li:even") //挑選下標為偶數的li $("li:odd") //挑選下標為奇數的li $("li:eq(4 ...
  • 前言 之前在part2中說的添加自定義主題配色已經開發完成了,除此之外我還添加了一些的3d特效。 前期文章 這是part1的文章:https://www.cnblogs.com/xi12/p/16690119.html 這是part2的文章:https://www.cnblogs.com/xi12/ ...
  • 大家應該有發現最近幾天不少網站變成了黑白色,在哀悼日時,很多網站都需要全站變成黑白配色,今天對這個實現的技術做了一些探索性瞭解,在此進行一個記錄分享。 使用的樣式部分:下麵的css部分想必大家應該都可以看懂,主要是對主流的谷歌內核瀏覽器和小眾些的品牌瀏覽器做整體的網頁圖片處理,IE瀏覽器除了IE10 ...
  • 父組件向子組件 父組件向子組件傳參:父組件中的子組件標簽中增加 :param="param" 子組件中增加 props 接受參數(註意props需要與data同級) props: { param: { type: Object } }, data() { return { ... } }, 父組件調 ...
  • 大家都知道,當一些重大事件發生的時候,我們的網站,可能需要置灰,像是這樣: 當然,通常而言,全站置灰是非常簡單的事情,大部分前端同學都知道,僅僅需要使用一行 CSS,就能實現全站置灰的方式。 像是這樣,我們僅僅需要給 HTML 添加一個統一的濾鏡即可: html { filter: grayscal ...
  • 寫軟體和造樓房一樣需要設計,但是和建築行業嚴謹客觀的設計規範不同,軟體設計常常很主觀,且容易引發爭論。 設計模式被認為是軟體設計的“規範”,但是在互聯網快速發展的過程中,也暴露了一些問題。相比過程式代碼的簡單與易於修改,設計模式常常導致代碼複雜,增加理解與修改的成本,我們稱之為 “過度設計”。... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...