学习笔记0409----正则三剑客之grep

2022-01-11 10:39:30 浏览数 (1)

正则三剑客之grep

  • 预习内容
    • 1.grep 过滤指定关键词
      • 1.1 grep选项参数
      • 1.2 正则特殊符号作用
      • 1.3 grep与正则表达式的一起使用
  • 课后总结
    • 1. Linux 系统添加操作记录审计
    • 2.history 1 | { read x cmd; echo "$cmd"; }
    • 3.正则符号总结
    • 4.扩展正则符号

预习内容

任务列表 9.1 正则介绍_grep上 9.2 grep中 9.3 grep下 扩展 把一个目录下,过滤所有*.php文档中含有eval的行 grep -r --include="*.php" ‘eval’ /data/

1.grep 过滤指定关键词

1.1 grep选项参数

参数

作用

-c

计算符合范本样式的列数

-i

忽略字符大小写

-n

在显示符合范本样式的那一行之前,标示出该行的行号

-v

取反

-r

遍历所有子目录

-o

只显示符合RE的字符串

-A

后面跟数字,除了显示符合范本样式的那一行之外,并显示该行之后n行的内容

-B

后面跟数字,除了显示符合范本样式的那一行之外,并显示该行之前n行的内容

-C

后面跟数字,除了显示符合范本样式的那一行之外,并显示该行之前于之后n行的内容

1.2 正则特殊符号作用

代码语言:javascript复制
字符匹配:
.	任意单个字符
[]	指定范围内的任意单个字符
[^] 指定范围外的任意单个字符

次数匹配:
*:匹配其前一个字符任意次;
?: 匹配其前一个字符0或1次;
 : 匹配其前一个字符至少1次
{m}: 匹配其前一个字符m次;
{m,n}: 至少m次,至多n次
{m,}: 至少m次;
{0,n}:至多n次;

锚定:
^: 行首
$: 行尾
<, b: 词首
>, b:词尾

分组:
(): 分组
|: 或者, ac|bc
grep -E "con(C|c)at"  匹配conCat或concat

扩展阅读: 正则表达式全部符号解释 17个案例带你3分钟搞定Linux正则表达式

1.3 grep与正则表达式的一起使用

代码语言:javascript复制
[root@linux-01 ceshi]# grep 'r.o' passwd    //r.o中的点代表任意一个字符
代码语言:javascript复制
//  * 代表左边的字符重复0次或者任意次数
[root@linux-01 ceshi]# grep 'r*o' passwd   
#Root:x:0:0:root:/root:/bin/bash
#bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
xihaji:x:1000:1000::/home/xihaji:/bin/bash
xihaji2:x:1001:1001::/home/xihaji2:/bin/bash
readonly:x:1002:1002::/home/readonly:/bin/bash
roooooor
o1o
r?o
r-o
r5o
r=o
r.o
o111o
oo
user1:x:1003:100::/home/user1:/bin/bash

课后总结

1. Linux 系统添加操作记录审计

代码语言:javascript复制
1.mkdir -p /usr/local/domob/records/      //创建一个文件夹用于存储历史命令
 
  chmod 777 /usr/local/domob/records/   //给与这个文件夹777的权限
 
  chmod  t /usr/local/domob/records/     //给文件夹增加-t权限,防止删除
 
2.vim /etc/profile 在最后添加下面的代码
 

if [ ! -d  /usr/local/domob/records/${LOGNAME} ]   //查看这个文件夹是否存在
 
then
 
mkdir -p /usr/local/domob/records/${LOGNAME}    //不存在创建这个文件夹
 
chmod 300 /usr/local/domob/records/${LOGNAME}   //给文件夹300的权限
 
fi
 
export HISTORY_FILE="/usr/local/domob/records/${LOGNAME}/bash_history"   //创建一个变量
 
export PROMPT_COMMAND='{ date " %Y-%m-%d %T ##### $(who am i |awk "{print $1" "$2" "$5}") #### $(history 1 | { read x cmd; echo "$cmd"; })"; } >>$HISTORY_FILE' 
//上面这条命令是在每个操作前执行,把history的最后一条命令写入到一个文件当中。
// date " %Y-%m-%d %T   时间
//$(who am i |awk "{print $1" "$2" "$5}")   用户,登录地址
//(history 1 | { read x cmd; echo "$cmd"; })    历史命令
代码语言:javascript复制
测试结果如下:
[root@linux-01 ceshi]# mkdir -p /usr/local/domob/records/ 
[root@linux-01 ceshi]# chmod 777 /usr/local/domob/records/ 
[root@linux-01 ceshi]# chmod  t /usr/local/domob/records/ 
[root@linux-01 ceshi]# vim /etc/profile

重新开启一个终端
Connecting to 192.168.141.128:22...
Connection established.
To escape to local shell, press 'Ctrl Alt ]'.

WARNING! The remote SSH server rejected X11 forwarding request.
Last login: Thu Mar 21 04:34:04 2019
[xihaji@linux-01 ~]$ 
[xihaji@linux-01 ~]$ pwd
/home/xihaji
[xihaji@linux-01 ~]$ ll
总用量 0
-rw-rw-r--. 1 xihaji xihaji 0 3月  21 04:34 1.txt
[xihaji@linux-01 ~]$ mkdir ceshi ;touch 123
[xihaji@linux-01 ~]$ ll
总用量 0
-rw-rw-r--. 1 xihaji xihaji 0 4月  10 16:07 123
-rw-rw-r--. 1 xihaji xihaji 0 3月  21 04:34 1.txt
drwxrwxr-x. 2 xihaji xihaji 6 4月  10 16:07 ceshi
[xihaji@linux-01 ~]$ 

在第一个终端查看历史命令
[root@linux-01 ceshi]# cat /usr/local/domob/records/xihaji/bash_history 
2019-04-10 16:06:00 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:06:00 exit
2019-04-10 16:06:22 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:06:21 pwd
2019-04-10 16:06:23 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:06:23 ll
2019-04-10 16:07:27 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:07:27 mkdir ceshi ;touch 123
2019-04-10 16:07:29 ##### xihaji pts/0 (192.168.141.1) #### 19/04/10 16:07:29 ll
[root@linux-01 ceshi]# 

2.history 1 | { read x cmd; echo “$cmd”; }

详解:

  • read命令,后面跟的是变量名,可以是1个,也可以是多个,用空格分隔。回车后,输入的字符就是在给这些变量赋值,输入的字符串也需要用空格分隔,如果和上面的变量名一个一个地对应,那么这样就一个一个地赋值了。
  • 如果没有对应呢?通过上面的命令也可以发现,如果值比变量多,它只对应前面的。例如,变量只有x和y,而值是1 2 3,则它把x赋值1,后面的2 3一股脑赋值给最后面的变量y。
  • 管道前面,history 1表示取最后一条命令。管道后面’{ }’内是一整体,相当于一个函数,函数里面可以有多条命令,用分号分割,而且最后一条命令也必须加分号。第一条命令和’{‘之间必须要有空格。

扩展:history 1 | { read x cmd; echo “$cmd”; }

3.正则符号总结

  • . 点代表匹配一个字符
  • * 星号代表匹配星号前面的一个字符存在0次或者多次,.*表示贪婪匹配
  • 加号表示星号前面的一个字符存在1次或者多次
  • ? 问好表示问号前面的一个字符存在0次或者1次
  • () 小括号表示一个组合
  • {} 大括号表示次数,可以是{2,5}
  • | 表示或者的意思
  • [] 中括号表示匹配中括号中的一个字符
  • ^ 在中括号里表示取反的意思,在中括号外面表示开头
  • $ 表示尾部的意思
  • 反斜杠表示转义

4.扩展正则符号

  • 使用以下几个符号的时候请使用egrep或者grep -E 或者在符号前加入转义符
  • *
  • ?
  • ()
  • {}
  • |

0 人点赞