四月二号学习报告
linux基础-linux用户缺省权限管理
创建一个testme用户密码为123456
登录testme账号
发现大部分目录都能进入,lost+found 是不可进入的,要验证是否能进入
发现本目录只有访问权限
验证 /bin 目录也只有访问权限
发现/tmp可读写
发现根目录是完全控制的
linux基础-sed命令详解
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :直接在命令列模式上进行 sed 的动作编辑;
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
-r :sed 的动作支持延伸型正规表达式的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。
动作说明: [n1[,n2]]function
n1, n2 :可选选项,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则可以使用『 10,20 』作为参数。
function:
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d :删除,因为是删除,所以 d 后面通常不接任何内容;
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~
s :取代,可以直接进行取代的工作!通常s符号的动作可以搭配正规表达式!例如 1,20s/old/new/g
查看文件内容,删除第二第五行
sed 后面接的动作,请务必以 ‘’ 两个单引号括住。
只删除第二行,nl /etc/passwd | ‘2d’
要删除第 3 到最后一,nl /etc/passwd | sed ‘3,$d’
在第二行后,第三行前,加上『drink tea』字符串,nl /etc/passwd | sed ‘2a drink tea’
在第二行前添加『drink tea』字符串,执行,nl /etc/passwd | sed ‘2i drink tea’
将第2-5行的内容取代成为『Number 2-5』字符串,执行,nl /etc/passwd | sed ‘2,5c Number 2-5’
仅列出 /etc/passwd 文件内的第 5-7 行,nl /etc/passwd | sed -n ‘5,7p’
搜索 /etc/passwd有root关键字的行,nl /etc/passwd | sed -n ‘/root/p’
其中"/root/"是正则表达式。命令是输出所有行中有root字符串的行。sed命令并不影响nl的输出。
只打印匹配正则表达式的行。,nl /etc/passwd | sed -n ‘/root/p’
删除/etc/passwd所有包含root的行,其他行输出,nl /etc/passwd | sed ‘/root/d’
使用一条sed命令,删除/etc/passwd第三行到末尾的数据,并把bash替换为blueshell,nl /etc/passwd | sed -e ‘3,$d’ -e ‘s/bash/blueshell/’
-e表示多点编辑,第一个编辑命令删除/etc/passwd第三行到末尾的数据,第二条命令搜索bash替换为blueshell。
创建一个test.txt文本,利用 sed 将test.txt 内每一行结尾若为 '.'则换成 ‘!’
linux基础-uname命令参数及用法详解
uname 命令可用于大多数 UNIX 和类 UNIX 系统以及 Linux。
功能说明:uname用来获取电脑和操作系统的相关信息。
语 法:uname [-amnrsvpio][–help][–version]
补充说明:uname可显示linux主机所用的操作系统的版本、硬件的名称等基本信息。
参 数:
-a或–all 详细输出所有信息,依次为内核名称,主机名,内核版本号,内核版本,硬件名,处理器类型,硬件平台类型,操作系统名称
-m或–machine 显示主机的硬件(CPU)名
-n或-nodename 显示主机在网络节点上的名称或主机名称
-r或–release 显示linux操作系统内核版本号
-s或–sysname 显示linux内核名称
-v 显示显示操作系统是第几个 version 版本
-p 显示处理器类型或unknown
-i 显示硬件平台类型或unknown
-o 显示操作系统名
–help 获得帮助信息
–version 显示uname版本信息
最常用参数 uname -a
uname(注:单独使用uname命令时相当于uname -s。uname -s 显示内核名称)
使用uname –a命令可显示电脑主机名和系统内核操作系统详细信息
使用uname –m命令可显示主机的硬件类型
使用uname –n命令可显示主机名称
使用uname -r 命令可显示操作系统的内核版本号
使用uname -v命令可显示操作系统是第几个version版本
使用uname -p命令可显示处理器类型
使用uname -i命令可显示硬件平台类型
使用uname -o 命令可显示操作系统名
使用uname --version 命令可显示uname版本信息
使用uname –-help命令可获取帮助信息
使用uname -nr命令可查看主机名及系统内核版本号
linux基础-利用gpg进行加密解密
在生成之前执行rngd -r /dev/urandom
接着执行,gpg --gen-key
执行命令,gpg -k
执行命令
gpg -o testme.pri --export-secret-keys testme
gpg -o testme.pub --export testme
分别执行命令
echo “hello testme” >test.file
生成测试文件
cat test.file
查看文件内容
gpg -r testme -e test.file
对文件进行加密
ll test*
列当前目录,查看增加文件
发现增加了加密文件test.file.gpg
cat test.file.gpg
执行命令,gpg -r testme -d test.file.gpg,进入界面
中间需要输入保护pin 码,发现能够完整地解密
linux基础-文本编辑器VI基本使用
执行命令,which vi
执行命令,vi -h
用ls -l 命令查看文件
发现文件已存在,cat /tmp/hello
删除整行,先进入文档。vi hello
将光标移动到第二行,按两次dd,发现少了一行
复制整行,把第一行复制到最后一行,把光标移动到第一行,按两次yy,再把光标移动到最后一行,键入p,发现第一行已经被复制到最后一行了
插入字符到某一行前,想在第3行前面加1行,先把光标移动到第2行,然后键入o
然后还进入了编辑模式
查找文本,进入命令状态,输入/456
按一下n,转到第二个456
linux基础-文本编辑器VI的应用
vim用不同颜色来区别关键字,而vi则全部用黑色显示所编辑的内容。
先按ESC,然后shift+:,退出编辑状态
W-仅保存当前文档,不退出编辑状态
Q-退出vim,没有保存无法退出
X-保存当前文档并退出vi
ZZ-保存当前文档并退出vi
q!-不保存文档并退出vi
Wq-保存并退出
Wq!-保存并强制退出
set nu-每行前面加上行号,即显示行号
set nonu-取消每行前面的行号,即隐藏行号
一些常用的编辑命令
复制
yy-复制光标所在的行
nyy-复制从光标所在行算起的n行
复制从光标所在行开始的连续下面7行则用7yy
:1,7 co 10-将1到7行所有内容,复制到第10行
移动/剪切
先删除,再粘贴
ndd后移动光标,再按p/P,其中p粘贴在光标所在行后,P粘贴在光标所在行前
:1,7 mo 10-将第1行到第7行的所有内容,移到第10行的下一行
删除
dd-删除光标所在的行
ndd-删除从光标所在行开始的连续n行,等价于dnd
dG-删除从当前光标起到文件的末尾的所有内容。
D0-删除从光标所在处开始到本行的行首的所有内容。
d$-删除从光标所在处开始到本行的行尾的所有内容。
x/X-向后删除一个字符/向前删除一个字符。
delete-键-向后删除一个字符。
dw,d3w,d10w-删除一个字/向后删除3个字/向后删除10个字。
:1,5 d-删除第1行到第5行的所有内容。
粘贴
p-小写,粘贴到光标所在行的下一行。
P-大写,粘贴到光标所在行的上一行。
撤消
u-撤消上一次的操作
linux基础-查找命令
Linux的五个查找命令:find,locate.wheris ,whice,type
Find
find . -name “install*”(搜索当前目录中,所有文件名以install开头的文件。).
find . -name “install*” -ls(搜索当前目录中,所有文件名以install开头的文件,并显示它们的详细信息。)
Find . -type f -mmin -1(搜索当前目录中,所有过去1分钟中更新过的普通文件。如果不加-type f参数,则搜索普通文件+特殊文件+目录。)
Locate
locate命令其实是“find -name”的另一种写法,它不搜索具体目录,而是去搜索一个数据库,这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库.
locate /etc/sh(搜索etc目录下所有以sh开头的文件。)
locate ~/i(搜索用户主目录下,所有以i开头的文件。)
locate -i ~/i(搜索用户主目录下,所有以m开头的文件,并且忽略大小写)
whereis
Whereis grep
whereis命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息
which
Which grep
which命令的作用是,在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。也就是说,使用which命令,就可以看到某个系统命令是否存在,以及执行的到底是哪一个位置的命令。
type
type命令其实不能算查找命令,它是用来区分某个命令到底是由shell自带的,还是由shell外部的独立二进制文件提供的。如果一个命令是外部命令,那么使用-p参数,会显示该命令的路径,相当于which命令。
type cd(系统会提示,cd是shell的自带命令(build-in))
type grep(系统会提示,grep是一个外部命令,并显示该命令的路径。)
type -p grep(加上-p参数后,就相当于which命令。)