模拟Linux文件管理员系统-shell实现

这篇具有很好参考价值的文章主要介绍了模拟Linux文件管理员系统-shell实现。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录
  • 模拟Linux文件管理员系统-shell实现
    • 1 系统要求
    • 2 脚本执行效果
      • 2.1 管理员登录效果
      • 2.2 普通用户登录效果
      • 2.3 密码文件格式
    • 3 实现脚本
    • 4 密码文件
    • 5 说明

模拟Linux文件管理员系统-shell实现

注:此脚本仅供学习使用,具体需要根据实际情况进行测试调整。

1 系统要求

模拟Linux文件管理员系统-shell实现

2 脚本执行效果

2.1 管理员登录效果

模拟Linux文件管理员系统-shell实现

2.2 普通用户登录效果

模拟Linux文件管理员系统-shell实现

2.3 密码文件格式

用空格隔开,从左往右依次为:
用户名 密码 是否为管理员(1为管理员0为普通用户) 是否被锁定(1被锁定0为解锁)

模拟Linux文件管理员系统-shell实现

3 实现脚本

[root@waluna ~]# cat Log_in.sh
#!/bin/bash
#
#**************************************************
#Author:                Xan_Yum
#QQ:                    7993167
#Email:                 waluna@qq.com
#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实现.文章来源地址https://www.toymoban.com/news/detail-664571.html

到了这里,关于模拟Linux文件管理员系统-shell实现的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • win10如何用管理员身份打开hosts文件

    1. 在右下角输入框输入cmd,选择“命令提示符(以管理员身份运行)”; 2. 在命令行窗口中输入“cd C:WindowsSystem32Driversetc” 3. 输入“notepad hosts” 随后便可以打开hosts文件并对其进行修改和保存。

    2024年02月11日
    浏览(41)
  • Inno Setup 打包的文件以管理员权限运行

    在 Inno Setup 安装目录中找到文件 SetupLdr.e32,用软件 ResourceHacker 打开。 如下图,点开清单,找到 改为 改完点击编译,然后再保存。 在Inno Setup 的打包编译脚本Setup节点中增加 PrivilegesRequired=admin 点击编译,这样编译出来的程序在安装时,就会自动提示获取管理员权限。

    2024年02月09日
    浏览(30)
  • linux环境minio安装启动,管理员登录,nginx代理

    一.下载minio 官网下载:  MinIO | Code and downloads to create high performance object storage  直接点击下载或者用wget https://dl.min.io/server/minio/release/linux-amd64/minio 最后都是得到一个文件minio(大概100M) 二.启动minio 1.创建文件夹,比如 2.将第一步得到的minio放到上面目录下 3.给该文件夹赋权限  

    2023年04月24日
    浏览(47)
  • dedecms关闭mysql错误日志生成文件功能(防止暴露后台与管理员)

    织梦程序在mysql错误时会自动在data文件夹里生成一个 mysql_error_trace.inc 文件记录错误信息,很多时候这个文件的错误信息里有后台目录和管理员账号信息在里面,我们其实大部分时候都不会去看这个文件的,所以关闭它生成很有必要! 关闭方法 打开 /include/dedesql.class.php 和

    2024年02月03日
    浏览(26)
  • Win10解决:系统管理员已阻止你运行此应用

    前言 Win10安装msi软件包时出现错误提示如下: 解决 按【win+R】快捷键打开运行,输入 gpedit.msc 回车 依次进入”Windows设置“—”安全设置“—”本地策略“–”安全选项“—”用户账户控制:以管理员批准模式运行所有管理员“—双击,设置为”已禁用“,应用确定。 重启电

    2024年02月12日
    浏览(35)
  • 银河麒麟高级服务器操作系统V10-系统管理员手册:04 安装和管理软件

    目录 第四章 安装和管理软件 4.1. 检查和升级软件包 4.1.1. 软件包升级检查 4.1.2. 升级软件包 4.1.3. 利用系统光盘与 dnf 离线升级系统 4.2. 管理软件包 4.2.1. 检索软件包 4.2.2. 安装包列表 4.2.3. 显示软件包信息 4.2.4. 安装软件包 4.2.5. 下载软件包 4.2.6. 删除软件包 4.3. 管理软件包组

    2024年02月03日
    浏览(38)
  • windows10系统如何解决“管理员已阻止你运行此应用“

    安装某些软件时偶尔遇到如下问题,解决方法作以记录。 Windows 10系统在安装驱动或程序时提示“ 管理员已阻止运行此应用 ”,要如何解决呢? 操作如下:(亲测第四条有效!) 1. 右击安装程序选择【以管理员身份运行】 2. 关闭防火墙和杀毒软件后,右击安装程序选择【以

    2024年02月13日
    浏览(32)
  • c++学习笔记-STL案例-机房预约系统4-管理员模块

    前言 衔接上一篇“c++学习笔记-STL案例-机房预约系统3-登录模块”,本文主要设计管理员模块,从管理员登录和注销、添加账号、显示账号、查看机房、清空预约五个功能进行分析和实现。 目录 7 管理员模块 7.1 管理员登录和注销 7.1.1 构造函数 ​编辑7.1.2 管理员子菜单 7.1.

    2024年01月19日
    浏览(29)
  • 解决命令提示符已被系统管理员停用的问题

    昨天,现场调试一个项目,以太网怎么也连不上,想用常用的PING来测试一下,结果CMD不正常, 幸亏我的电脑还装了虚拟机,在虚拟机里面解决了现场问题。今天,上网上搜了一下,记录下来,以备后续急用 方法一:修改注册表 1.在开始搜索框输入“regedit”命令来打开注册表

    2024年02月08日
    浏览(39)
  • ubuntu开机出现《系统出错且无法恢复,请联系系统管理员。》错误解决办法!

    背景: ubuntu22.04.2命令行,执行自动安装系统推荐显卡驱动命令,字体变大,重启后出现如下图错误,无法进入系统,无法通过CTRL+ALT+F1-F3进入TTY模式。 解决办法: 1.首先要想办法进入系统,能输入命令检查。 方法一:按CTRL+ALT+F1-3进入TTY模式,输入命令。(行不通) 方法二

    2024年04月23日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包