模擬Linux文件管理員系統-shell實現

来源:https://www.cnblogs.com/waluna/archive/2023/08/22/17646887.html
-Advertisement-
Play Games

[toc] # 模擬Linux文件管理員系統-shell實現 **註:此腳本僅供學習使用,具體需要根據實際情況進行測試調整。** ## 1 系統要求 ![](https://img2023.cnblogs.com/blog/3262925/202308/3262925-202308211934402 ...


目錄

模擬Linux文件管理員系統-shell實現

註:此腳本僅供學習使用,具體需要根據實際情況進行測試調整。

1 系統要求

2 腳本執行效果

2.1 管理員登錄效果

2.2 普通用戶登錄效果

2.3 密碼文件格式

用空格隔開,從左往右依次為:
用戶名 密碼 是否為管理員(1為管理員0為普通用戶) 是否被鎖定(1被鎖定0為解鎖)

3 實現腳本

[root@waluna ~]# cat Log_in.sh
#!/bin/bash
#
#**************************************************
#Author:                Xan_Yum
#QQ:                    7993167
#Email:                 [email protected]
#Version:               1.0
#Date:                  2022-06-12
#FileName:              Log_in.sh
#Description:           The test script
#URL:                   https://blog.waluna.top
#Copyroght (C):         2022 ALL rights reserved
#**************************************************

############################## 函數區 ###############################

# 參數獲取
ARGS(){
    USER_PASSWD=`grep -E "^${USER} " auth.pass`
    USERR=`echo $USER_PASSWD | cut -d' ' -f1`
    PASSWDR=`echo $USER_PASSWD | cut -d' ' -f2`
    ADMIN=`echo $USER_PASSWD | cut -d' ' -f3`
    LOCK=`echo $USER_PASSWD | cut -d' ' -f4`
}

# 創建新用戶
NEW_USER(){
    read -p "請輸入要創建的用戶名:" USER
    ARGS
    if [ -n "$USERR" ];then
        echo "用戶已存在"
        if [ -d $USER ];then
            echo "${USER} `date +%F_%T`" > ${USER}/${USER}.log
        else
            mkdir $USER
            echo "${USER} `date +%F_%T`" > ${USER}/${USER}.log
        fi
    else
        read -sp "請輸入新用戶的密碼:" PASSWD
        echo "${USER} ${PASSWD} 0 0" >> auth.pass
        if [ -d $USER ];then
            echo "${USER} `date +%F_%T`" > ${USER}/${USER}.log
        else
            mkdir $USER
            echo "${USER} `date +%F_%T`" > ${USER}/${USER}.log
        fi
        echo "${USER}用戶創建完成"
    fi
}

# 刪除舊用戶
DEL_USER(){
    read -p "請輸入要刪除的用戶名:" USER
    ARGS
    if [ -n "$USERR" ];then
        sed -ri.bak "/^${USER}/d" auth.pass
        rm -rf ${USER}
        echo "${USER}用戶已刪除"
    else
        echo "${USER}用戶不存在"
    fi
}

# 解鎖用戶
UNLOCK_USER(){
    read -p "請輸入要解鎖的用戶名:" USER
    ARGS
    if [ -n "$USERR" ];then
        if [ ${LOCK} -eq 1 ];then
            sed -ri.bak "s/^(${USERR}.* )1$/\10/" auth.pass
            echo "${USERR}用戶已解鎖"
        else
            echo "${USERR}用戶沒有被鎖定"
        fi
    else
        echo "您輸入的用戶名不存在"
    fi
}

# 許可權管理
PRI_MAN(){
    read -p "請輸入要設置許可權的用戶名:" USER
    ARGS
    if [ -z "${USER}" ];then
        echo "用戶名不能為空!"
    elif [ "${USER}" = "admin" ];then
        echo "admin用戶不允許更改"
    elif [ -n "$USERR" ];then
        read -p "請輸入要設置的許可權(0為普通用戶,1為管理員):" PRI
        if [ -z "$PRI" ];then
            echo "請輸入 0|1 "
        elif [ ${PRI} -eq 0 ];then
            sed -ri.bak "s/^(${USERR}.*) . (.)$/\1 0 \2/" auth.pass
            echo "已將${USERR}用戶設置為普通用戶"
        elif [ ${PRI} -eq 1 ];then
            sed -ri.bak "s/^(${USERR}.*) . (.)$/\1 1 \2/" auth.pass
            echo "已將${USERR}用戶設置為管理員用戶"
        else
            echo "請輸入 0|1 "
        fi
    else
        echo "您輸入的用戶名不存在"
    fi
}

# 管理員菜單
ADMIN_MENU(){
    # 這裡使用select迴圈,導致實現功能後不會自動列印菜單,需要回車後才能顯示。
    PS3="請輸入(1-5,直接回車會重新列印菜單):"
    select MENU in 創建新用戶 刪除舊用戶 解鎖用戶 許可權管理 退出;do
    case $REPLY in
    1)
        NEW_USER
        ;;
    2)
        DEL_USER
        ;;
    3)
        UNLOCK_USER
        ;;
    4)
        PRI_MAN
        ;;
    5)
        exit
        ;;
    *)
        echo "輸入錯誤,請重新輸入!"
        ;;
    esac
    done
}

# 新建文本文件
NEW_FILE(){
    read -p "請輸入要創建的文件名:" FILENAME
    if [ -z ${FILENAME} ];then
        echo "文件名不能為空!"
    elif [ -d ${FILENAME} ];then
        echo "${FILENAME}是一個目錄"
        if [ -f ${FILENAME}/${FILENAME} ];then
            echo "文件已存在!"
        else
            touch ${FILENAME}/${FILENAME}
            echo "${FILENAME}/${FILENAME}文本文件創建完成"
        fi
    elif [ -f ${FILENAME} ];then
        echo "文件已存在!"
    else
        touch ${FILENAME}
        echo "${FILENAME}文本文件創建完成"
    fi
}

# 新建目錄
NEW_DIR(){
    read -p "請輸入要創建的目錄名:" DIRNAME
    if [ -z ${DIRNAME} ];then
        echo "目錄名不能為空!"
    elif [ -d ${DIRNAME} ];then
        echo "目錄已存在!"
    else
        mkdir ${DIRNAME}
        echo "${DIRNAME}目錄創建完成"
    fi
}

# 統計文檔信息
ARCHIVE_FILE(){
    read -p "請輸入要統計的文件名:" FILENAME
    if [ -z ${FILENAME} ];then
        echo "文件名不能為空!"
    elif [ -f ${FILENAME} ];then
        echo "${FILENAME}文件的行數為`wc -l ${FILENAME}|cut -d' ' -f1`"
        echo "${FILENAME}文件的單詞數為`wc -w ${FILENAME}|cut -d' ' -f1`"
        echo "${FILENAME}文件的字元數為`wc -c ${FILENAME}|cut -d' ' -f1`"
    else
        echo "${FILENAME}文件不存在"
    fi
}

# 許可權查看
PRI_VIEW(){
    read -p "請輸入要查看的文件名:" FILENAME
    if [ -z ${FILENAME} ];then
        echo "文件名不能為空!"
    elif [ -f ${FILENAME} ];then
        if [ -r ${FILENAME} -a -w ${FILENAME} -a -x ${FILENAME} ];then
            echo "Readable & Writeable & Executable"
        elif [ -r ${FILENAME} -a -x ${FILENAME} ];then
            echo "Readable & Executable"
        else
            echo "其他許可權"
        fi
    else
        echo "${FILENAME}文件不存在"
    fi
}

# 普通用戶菜單
USER_MENU(){
    PS3="請輸入(1-5,直接回車會重新列印菜單):"
    select MENU in 新建文本文件 新建目錄 統計文檔信息 許可權查看 退出;do
    case $REPLY in
    1)
        NEW_FILE
        ;;
    2)
        NEW_DIR
        ;;
    3)
        ARCHIVE_FILE
        ;;
    4)
        PRI_VIEW
        ;;
    5)
        exit
        ;;
    *)
        echo "輸入錯誤,請重新輸入!"
        ;;
    esac
    done
}

# 判斷是否為管理員
ADMIN_JUDGE(){
    if [ ${ADMIN} -eq 1 ];then
        echo "當前角色為管理員"
        ADMIN_MENU
    elif [ ${ADMIN} -eq 0 ];then
        echo "當前角色為普通用戶"
        USER_MENU
    fi
}

# 判斷用戶密碼是否正確
PASSWD_JUDGE(){
    if [ "${PASSWD}" = "${PASSWDR}" ];then
        echo "登錄成功!!!"
        ADMIN_JUDGE
    else
        echo "密碼或用戶名錯誤"
    fi
}

# 判斷用戶賬號是否鎖定
LOCK_JUDGE(){
    if [ ${LOCK} -eq 1 ];then
        echo "${USER}用戶已被鎖定,請聯繫管理員!!!"
        exit 1
    elif [ ${LOCK} -eq 0 ];then
        #echo "${USER}用戶可以正常登錄"
        PASSWD_JUDGE
    fi
}

# 判斷用戶是否存在
EXIST_JUDGE(){
    if [ -z ${USERR} ];then
        echo "用戶不存在,請先創建用戶!"
        exit 1
    else
        LOCK_JUDGE
    fi
}

# 密碼數錯三次後鎖定賬號
LOCK_USER(){
    if [ "$USERR" = "admin" ];then
        sed -ri.bak "s/^(${USERR}.* )0$/\11/" auth.pass
        echo "已鎖定!!!"
        chmod 0 Log_in.sh
    else
        sed -ri.bak "s/^(${USERR}.* )0$/\11/" auth.pass
        echo "${USERR}用戶已被鎖定,請聯繫管理員!!!"
    fi
}



############################## 功能區 ###############################

i=0

read -p "請輸入登錄名:" USER

while ((i<3));do
    read -sp "請輸入密碼:" PASSWD
    echo

    if [ -z $USER ];then
        echo "請輸入登錄名!"
        exit 1
    fi

    if [ -z $PASSWD ];then
        echo "請輸入密碼!"
        exit 1
    fi

    ARGS
    EXIST_JUDGE

    let i++
done

LOCK_USER

[root@waluna ~]# 

4 密碼文件

[root@waluna ~]# cat auth.pass
admin 123456 1 0
waluna waluna 0 0
[root@waluna ~]# 

5 說明

此腳本還存在一些問題,比如密碼文件不提前創建會導致無法登錄而報錯;菜單使用select實現,不能自定義格式等。大家可以自行修改腳本,實現更完整的功能。


關於我
全網可搜《阿賢Linux》
CSDN、知乎、嗶哩嗶哩、博客園、51CTO、開源中國、思否、掘金、阿裡雲、騰訊雲、華為雲、今日頭條、GitHub、個人博客
公眾號:阿賢Linux
個人博客:blog.waluna.top
https://blog.waluna.top/


原文鏈接: 模擬Linux文件管理員系統-shell實現.


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

-Advertisement-
Play Games
更多相關文章
  • # What is Polymorphism 這個多態看中文確實有點費解,多態的英文是Polymorphism,它的翻譯含義是: n. 多態性 (可以看出是比較寬泛的) n. 多型現象 從翻譯也看不出啥, 我舉一個生活中的例子來引入多態: 生活中有很多常見的物體具有多態性。例如,一張紙可以用來寫字、 ...
  • # 個人博客-給文章添加上標簽 # 優化計劃 - [x] 置頂3個且可滾動或切換 - [x] 推薦改為4個,然後新增歷史文章,將推薦的載入更多放入歷史文章,按文章發佈時間降序排列。 - [x] 標簽功能,可以為文章貼上標簽 - [ ] 推薦點贊功能 本篇文章實現文章標簽功能 # 思路 > 首先需要新 ...
  • # .NET Evolve資料庫版本管理工具 ## 1.簡介 提到資料庫版本管理,`Java`領域開發首先會想到大名鼎鼎的`flyway`。但是它不適用`.NET`領域,那麼`.NET`領域也需要做資料庫版本管理,該用什麼工具?自行造輪子?`.NET`領域的解決方案就是`Evolve`,這是一個開源 ...
  • # Ocelot與路由共存 ### 引言 在Asp.Net Core中使用了Ocelot做網關之後,其自身的Api路由就不起作用了,尋了許久的解決方法,終於找到一個,主要是使用MapWhen判斷Ocelot的配置是否符合,是則走轉發路由,否則走自身路由,步驟如下: ### 1.先創建以下類 ``` ...
  • 上篇文章講述了[C#介面的知識點](https://mp.weixin.qq.com/s?__biz=MzI2NDE1MDE1MQ==&mid=2650851371&idx=1&sn=c630043f8d85816c660c53cbf6b3f218&chksm=f14565c3c632ecd5816 ...
  • # UGUI的Button(按鈕)組件的介紹及使用 ## 1. 什麼是UGUI的Button組件? UGUI(Unity GUI)是Unity引擎中的一套用戶界面系統,Button(按鈕)是其中的一個常用組件。Button組件可以用於創建可交互的按鈕,用戶點擊按鈕時可以觸發相應的事件。 ## 2. ...
  • 先決條件 Visual Studio 2019 v16.9 預覽版1或更高版本(通過WSL可選組件進行.NET調試)。若要檢查 WSL 組件,請選擇 “工具” > “獲取工具和功能” 。 在 Visual Studio 安裝程式中,選擇 “單個組件”,然後鍵入 “WSL” 搜索安裝組件 。 安裝WS ...
  • ## 中台框架後端項目 Admin.Core 的介紹與配置說明 > 中台admin是前後端分離許可權管理系統,Admin.Core為後端項目,基於.NET 7.0開發。 > 支持多租戶、數據許可權、動態 Api、任務調度、OSS 文件上傳、滑塊拼圖驗證、多資料庫,分散式緩存、分散式事務等 - 介面文檔一 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...