<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          一套簡單通用的Java后臺管理系統(tǒng),拿來即用,非常方便(附項(xiàng)目地址...

          共 2191字,需瀏覽 5分鐘

           ·

          2020-07-25 20:14


          作者:huanzi-qch

          cnblogs.com/huanzi-qch/p/11534203.html

          前言

          這套Base Admin是一套簡單通用的后臺管理系統(tǒng),主要功能有:權(quán)限管理、菜單管理、用戶管理,系統(tǒng)設(shè)置、實(shí)時日志,實(shí)時監(jiān)控,API加密,以及登錄用戶修改密碼、配置個性菜單等

          技術(shù)棧

          前端:layui

          java后端:SpringBoot + Thymeleaf + WebSocket + Spring Security + SpringData-Jpa + MySql

          工程結(jié)構(gòu)說明

          java部分、html、js、css部分都是大目錄下面按單表一個子目錄存放

          f1457e7eafb236e46b6760ab52144695.webp

          50526c7a1b0aca7ce76f874932bc4881.webp

          運(yùn)行預(yù)覽

          效果先睹為快,具體介紹在下方,按功能點(diǎn)進(jìn)行詳情介紹

          640712d2ebd36fa95ebe18e9db20b412.webp

          功能演示

          登錄

          (為了方便演示,密碼輸入框的類型改成text)

          配置文件分支選擇,dev環(huán)境無需輸入驗(yàn)證碼

          15fa04bc4241f2be46f39cb33714aa9d.webp

          eed8502772f2982c5748258a8918ddbe.webp

          同時支持多種登錄限制

          允許/禁止賬號多人在線

          45ec81e3674ec9e5a1f64029bc6994bd.webp

          軟刪除

          b87091cdcd781a79d9ae78bdc95f5e5f.webp

          限制登錄IP地址

          fa6339a06c28ee150cc1086d59b4a811.webp

          賬號過期

          437e07588cc64a48441a7b18b26037ee.webp

          更多登錄限制,還可以繼續(xù)擴(kuò)展

          系統(tǒng)設(shè)置

          一下簡單的系統(tǒng)屬性設(shè)置,想支持更多的配置可自行擴(kuò)展(比如這里的:用戶管理初始、重置密碼)

          06d40dbdb19c95a53aa5953e28225600.webp

          系統(tǒng)設(shè)置新增部分功能,詳見文末“補(bǔ)充更新”。

          推薦閱讀:設(shè)計(jì)模式入門

          菜單管理

          菜單管理是一棵layui的Tree

          增刪改

          eb2a51537493afe1204733eec880c212.webp

          權(quán)限管理

          增刪改查

          9ace72f02a620bba336a881ef8626cf6.webp

          動態(tài)權(quán)限加載

          權(quán)限的加載并不是寫死在代碼,而是動態(tài)從數(shù)據(jù)庫讀取,每次調(diào)用save方法時更新權(quán)限集合

          1、妲己是ROLE_USER權(quán)限,權(quán)限內(nèi)容為空,無權(quán)訪問/sys/下面的路徑(http://localhost:8888/sys/sysUser/get/1)

          2、使用sa超級管理員進(jìn)行權(quán)限管理編輯,給ROLE_USER的權(quán)限內(nèi)容添加 /sys/**,妲己立即有權(quán)限訪問(http://localhost:8888/sys/sysUser/get/1)

          f070aa252303aee740a94dea78f87989.webp

          用戶管理

          主要包括用戶信息、登錄限制的維護(hù),菜單、權(quán)限的分配等

          1227c727878e3831b586479c0161a2f4.webp

          修改用戶權(quán)限是下一次登錄生效

          2f26a5793224bb7e1e8bc60347e63e99.webp

          修改用戶菜單是刷新系統(tǒng)即可生效

          f95463b737cd16f31a0f0b9dab16cb85.webp

          用戶管理新增“當(dāng)前在線用戶”管理,詳見文末“補(bǔ)充更新”。

          推薦閱讀設(shè)計(jì)模式入門

          登錄用戶信息

          基本信息

          登錄用戶只能修改部分信息,例如名稱、修改密碼

          03e51e207f4e42fd3dc3e232e0fa8b20.webp

          修改密碼

          密碼使用的是MD5加密并轉(zhuǎn)換為16進(jìn)制字符串存儲,用戶除了能主動修改密碼外,還能叫管理員重置密碼

          19d449c3f4770e5ba521bebd87bf5d31.webp

          0b252ad2cf116685ea7fdc764046f440.webp

          個性菜單

          用戶可以自行配置自己的個性化快捷菜單

          777d17ec5d39087a368e81a8c700df65.webp

          實(shí)時日志

          使用websocket,實(shí)時將日志輸出到web頁面,1秒刷新一次

          注意:這里的日志配置只配置了dev環(huán)境,prod環(huán)境尚未為空,發(fā)布生產(chǎn)環(huán)境前記得先配置,否則生成的日志文件將不會輸入日志內(nèi)容!

          5f18c7eead4edf687b4d1030b154657f.webp

          b45dec14731137061efadeca29b57174.webp

          實(shí)時監(jiān)控

          實(shí)時監(jiān)控的是系統(tǒng)硬件環(huán)境、以及jvm運(yùn)行時內(nèi)存,注:因本人暫無Linux環(huán)境,所以只測試了windows環(huán)境,有問題請及時反饋,謝謝!

          使用websocket,實(shí)時將數(shù)據(jù)輸出到web頁面,1秒刷新一次

          27e5f7503dad47a3935c74fdf7f68237.webp

          API加密

          請求參數(shù)加密

          ae30fa317ae067ff37ceb91fc9bbe04c.webp

          響應(yīng)數(shù)據(jù)加密

          17ea5412932bef7d878d17adb59e0416.webp

          1、系統(tǒng)設(shè)置新增API加密開關(guān),可一鍵關(guān)閉、開啟API加密;

          開啟API加密

          eda4df923b28e295c582340217a05584.webp

          關(guān)閉API加密

          70c0e7c9819acd23b7421360cc113659.webp

          關(guān)鍵點(diǎn)講解

          1、定制url訪問權(quán)限,動態(tài)權(quán)限讀取,需要自定義配置認(rèn)證數(shù)據(jù)源、認(rèn)證管理器、攔截器,詳情步驟請參考:

          https://www.jianshu.com/p/0a06496e75ea;

          2、API加密中,由于登錄校驗(yàn)是Spring Security做的,因此我們要在UsernamePasswordAuthenticationFilter獲取賬號、密碼之前完成解密操作,正好我們的校驗(yàn)驗(yàn)證碼操作就是在它之前,同時要做響應(yīng)數(shù)據(jù)的加密操作,所以登錄部分的API加密光按照我們之前的博客來還是不夠的,需要在CaptchaFilterConfig進(jìn)行解密操作,解密后new一個自定義RequestWrapper設(shè)置Parameter,并將這個新對象傳到doFilter交由下一步處理

          3、還是API加密問題,我們是在程序啟動的時候生成后端RSA秘鑰對,正常來說我們在訪問登錄頁面進(jìn)行登錄的時候前端獲取一下就可以了,但在開發(fā)環(huán)境中,我們通常開啟熱部署功能,改完代碼程序可能會自動重啟,但登錄用戶信息仍然保持在本地線程,系統(tǒng)依舊處于登錄狀態(tài)沒有跳轉(zhuǎn)到登錄頁面,導(dǎo)致后端公鑰已經(jīng)改變,但前端依舊用的是舊的后端公鑰,所有導(dǎo)致加解密失敗;解決:在訪問index首頁時也獲取一下后端公鑰,這樣在開發(fā)的時候idea熱部署后刷新頁面就可以了(已提交最新代碼,解決熱部署后刷新頁面還是API加解密失敗問題;現(xiàn)在熱部署后刷新頁面即可)

          更新

          1、新增百度富文本的使用,但還沒配置上傳接口:

          UEditor文檔: http://fex.baidu.com/ueditor/#start-start

          對應(yīng)字段類型,mysql要改成longtext

          810d54d7cd1fadf1d935d311768d00bb.webp

          2、新增“”記住我“”功能,也就是rememberMe,原理以及源碼探究請看這位大佬的博客:

          https://blog.csdn.net/qq_37142346/article/details/80114609

          039939311dae4bcc7d78983331110652.webp

          adeb2764a444e4d9edaec2342384a45b.webp

          3、系統(tǒng)設(shè)置新增系統(tǒng)顏色,頭部、左側(cè)菜單的顏色可按心情切換(SQL文件已同步更新)

          2e5480234e926b7c1338d6229d0fbcc7.webp

          4、用戶管理模塊新增“當(dāng)前在線用戶”管理,可實(shí)時查看當(dāng)前在線用戶,以及對當(dāng)前在線用戶進(jìn)行強(qiáng)制下線操作

          249a2cae09ebad780713dd0630294ae8.webp

          代碼地址獲取

          掃碼關(guān)注,我的另一個公眾號,回復(fù):code01

          (一定要回復(fù):code01)否則啥得不到

          沒錯,這是我的另一個公眾

          瀏覽 44
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評論
          圖片
          表情
          推薦
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  欧美日本一道本一区二区三区 | 亚洲图片欧美乱伦 | 亚洲第一国产 | 亚洲成人视频免费观看 | 精品视频一区二区 |