• 正则grep


    什么是正则:

    正则就是一串有规律的字符串。

    正则三剑客:

    grep/egrep (egrep是grep的扩展),sed, awk

    grep

    grep过滤指定关键词

    [root@localhost grep]# grep 'nologin' passwd 

     

    -c 行数

    [root@localhost grep]# grep -c 'nologin' passwd 

    15

     

    -i 不区分大小写

    [root@localhost grep]# grep -i 'nologin' passwd 

    -n 显示行号

    [root@localhost grep]# grep -n 'nologin' passwd 

     

    -v 取反

    把除了nologin外的所有

    [root@localhost grep]# grep -vin 'nologin' passwd 

     

    -r遍历子目录和孙目录

    [root@localhost grep]# grep -r 'root' /etc/

     

    可以把过滤到的字符串重定向到文件中,然后从文件中查找相应的字符串

    [root@localhost grep]# grep -r 'root' /etc/  > /tmp/grep.log

    [root@localhost grep]# grep passwd /tmp/grep.log 

    /etc/passwd:root:x:0:0:root:/root:/bin/bash

    /etc/passwd:operator:x:11:0:operator:/root:/sbin/nologin

    /etc/passwd-:root:x:0:0:root:/root:/bin/bash

    /etc/passwd-:operator:x:11:0:operator:/root:/sbin/nologin

    /etc/postfix/main.cf:# the system passwd file in the chroot jail is just not practical.

     

     

    -A 后面跟数字,过滤出符合要求的行以及下面n行

    例如当前符合要求的行,以及下面的n行

    [root@localhost grep]# grep  -nA2 'root' passwd 

    1:root:x:0:0:root:/root:/bin/bash

    2-bin:x:1:1:bin:/bin:/sbin/NOLOGIN

    3-daemon:x:2:2:daemon:/sbin:/sbin/nologin

    --

    10:operator:x:11:0:operator:/root:/sbin/nologin

    11-games:x:12:100:games:/usr/games:/sbin/nologin

    12-ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

     

     

    -B 也是一样,后面跟数字,列出符合要求的当前行,以及行上面的n行

    [root@localhost grep]# grep -nB2 'root' passwd 

    1:root:x:0:0:root:/root:/bin/bash

    --

    8-halt:x:7:0:halt:/sbin:/sbin/halt

    9-mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

    10:operator:x:11:0:operator:/root:/sbin/nologin

     

    -C 也是一样,后面跟数字,列出符合要求的当前行,以及行上面n行和行后面n

    [root@localhost grep]# grep -nC2 'root' passwd 

    1:root:x:0:0:root:/root:/bin/bash

    2-bin:x:1:1:bin:/bin:/sbin/NOLOGIN

    3-daemon:x:2:2:daemon:/sbin:/sbin/nologin

    --

    8-halt:x:7:0:halt:/sbin:/sbin/halt

    9-mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

    10:operator:x:11:0:operator:/root:/sbin/nologin

    11-games:x:12:100:games:/usr/games:/sbin/nologin

    12-ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

     

    显示文件中的数字(红色高亮显示数字)

    [root@localhost grep]# grep '[0-9]' passwd 

     

    不显示文件中带有数字的字符

    grep -v '[0-9]' passwd

     

    -n是显示行数,-v取反,意思是不显示数字的,并且显示行数。

    [root@localhost grep]# grep  -vn  '[0-9]' /etc/inittab

    以井号开头的行:

    '^#'

    显示以井号开头的行

    [root@localhost grep]# grep -n '^#' inittab 

    显示不以井号开头的行:

    grep  -nv   '^#' inittab

    [root@localhost grep]# grep -nv '^#' inittab 

    9:jhsdjhsajdhjashdj

     

     

     

    显示非数字的字符:非数字字符高亮

    [root@localhost grep]# grep '[^0-9]' inittab 

    显示非数字开头的行:

    [root@localhost grep]# grep '^[^0-9]' inittab 

    ^ 放到[]方括号里面意思是取反,^放到开头意思是以什么字符开头。

     

     

    grep 'r.o' 表示  . 点表示任意一个字符

    [root@localhost grep]# grep 'r.o' passwd 

    root:x:0:0:root:/root:/bin/bash

    operator:x:11:0:operator:/root:/sbin/nologin

    grep ‘o*o’        * 号 表示o o中间n个字符

    [root@localhost grep]# grep  'o*o' passwd 

    mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

    operator:x:11:0:operator:/root:/sbin/nologin

    grep   '.*' 会匹配所有字符。    .表示任意一个字符,*表示所有字符

     

     

    [root@localhost grep]# grep  'xiaobo.*' passwd 

    xiaobo:x:1000:1000::/home/xiaobo:/bin/bash

     

    grep  'o{2}'  passwd;   表示脱义;

    ‘o{2}’表示o出现两次。

     

    [root@localhost grep]# grep  'o{2}' passwd 

    root:x:0:0:root:/root:/bin/bash

    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

    mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

    operator:x:11:0:operator:/root:/sbin/nologin

    postfix:x:89:89::/var/spool/postfix:/sbin/nologin

     

     

     

     

     

    'o{0,3}' 从0到3都匹配,就是说o出现0次、1次、2次、3次;

    [root@localhost grep]# grep 'o{0,3}' passwd 

    去掉脱义符,用egrep 'o{2}' passwd 表示o出现两次

    [root@localhost grep]# egrep 'o{2}' passwd 

    root:x:0:0:root:/root:/bin/bash

    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

    mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

    operator:x:11:0:operator:/root:/sbin/nologin

    postfix:x:89:89::/var/spool/postfix:/sbin/nologin

     

    也可以用 grep  -E  'o{2}' passwd

    [root@localhost grep]# grep  -E 'o{2}' passwd 

    root:x:0:0:root:/root:/bin/bash

    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

    mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

    operator:x:11:0:operator:/root:/sbin/nologin

    postfix:x:89:89::/var/spool/postfix:/sbin/nologin

     

    grep  -E '(oo){2}'  passwd 表示出现4个o

    [root@localhost grep]# grep  -E 'o{4}' passwd 

    ooooqq

    osdaoooo

     

    grep    'o+o' passwd    +加号 表示1个或者多个o

    [root@localhost grep]# grep 'o+o' passwd 

    root:x:0:0:root:/root:/bin/bash

    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

    mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

    operator:x:11:0:operator:/root:/sbin/nologin

    ooooqq

    osdaoooo

    postfix:x:89:89::/var/spool/postfix:/sbin/nologin

     

    不脱义,用egrep

    egrep  'o+o' passwd

     

    epgrep  'o+t'  passwd

    [root@localhost grep]# egrep 'o+t' passwd 

    root:x:0:0:root:/root:/bin/bash

    operator:x:11:0:operator:/root:/sbin/nologin

     

    egrep 'o?t'  passwd           ?问号表示0或1个 问号前面的字符

    [root@localhost grep]# egrep 'o?1o' passwd 

    postfix:x:89:89::/var/spool/postfix:/sbin/n1ogin

    cho1orony:x:998:996::/var/lib/chrony:/sbin/nologin

     

     

     

    grep -E   'root|nologin' passwd  匹配root或者nologin字符

    [root@localhost grep]# grep -E 'root|nologin' passwd 

    root:x:0:0:root:/root:/bin/bash

    daemon:x:2:2:daemon:/sbin:/sbin/nologin

    不区分大小写 -i

    grep -Ei   'root|nologin' passwd  匹配root或者nologin字符

      

      

  • 相关阅读:
    [轉][Windows] 已啟用Win7遠端桌面,從家中連回去卻無法連線?
    [轉]False SQL Injection and Advanced Blind SQL Injection
    SQL Injection with INFORMATION_SCHEMA (Mysql)
    Exploiting hard filtered SQL Injections
    Mysql 5 以上有内置库 information_schema,存储着mysql的所有数据库和表结构信息
    12个月内自学完成4年麻省理工学院计算机科学的33门课程的scotthyoung所谓的超速学习理论&方法(费曼技巧)?
    SQLi filter evasion cheat sheet (MySQL)
    [轉]字符形注入
    [轉]渗透测试必备Firefox全套渗透装
    Phpexcel範例
  • 原文地址:https://www.cnblogs.com/zhaocundang/p/8290274.html
Copyright © 2020-2023  润新知