PHP正则表达式

0x01 前言

CTF中经常出现与正则表达式相关的题目,但一直总是看PHP正则表达式表,这里对正则表达式做个探究详解.

0x02 概述

正则表达式是一种描述字符串结果的语法规则,是一个特定的格式化模式,可以匹配、替换、截取匹配的字符串。常用的语言基本上都有正则表达式,如JavaScript、java等。其实,只有了解一种语言的正则使用,其他语言的正则使用起来,就相对简单些。文本主要围绕解决下面问题展开。

  • 什么是限定符与定位符
  • 什么是单词定位符
  • 特殊字符有哪些
  • 什么是逆向引用以及怎样使用逆向引用
  • 匹配模式
  • php中怎样使用正则表达式
  • php中哪些方面需要用到正则
  • 怎样进行邮箱匹配,url匹配,手机匹配
  • 怎样使用正则替换字符串中某些字符
  • 贪婪匹配与惰性匹配区别
  • 正则表达式之回溯与固态分组
  • 正则优缺点有哪些

    正则表达式的基本知识总结

    行定位符(^与$)

    行定位符是用来描述字符串的边界。“$”表示行结尾,“^”表示行开始如”^de”,表示以de开头的字符串 “de$”,表示以de结尾的字符串。

    单词定界符

    我们在查找的一个单词的时候,如an是否在一个字符串”gril and body”中存在,很明显如果匹配的话,an肯定是可以匹配字符串“gril and body”匹配到,怎样才能让其匹配单词,而不是单词的一部分呢?这时候,我们可以是哟个单词定界符\b。
    \ban\b 去匹配”gril and body”的话,就会提示匹配不到。
    当然还有一个大写的\B,它的意思,和\b正好相反,它匹配的字符串不能使一个完整的单词,而是其他单词或字符串中的一部分。如\Ban\B

    选择字符(|),表示或

    选择字符表示或的意思。如Aa|aA,表示Aa或者是aA的意思。注意使用”[]”与”|”的区别,在于”[]”只能匹配单个字符,而”|”可以匹配任意长度的字符串。在使用”[]”的时候,往往配合连接字符”-“一起使用,如[a-d],代表a或b或c或d。

    排除字符

    正则表达式提供了”^”来表示排除不符合的字符,^一般放在[]中。如[^1-5],该字符不是1~5之间的数字。

    限定符(?*+{n,m})

    限定符主要是用来限定每个字符串出现的次数。
    1
    2
    3
    4
    5
    6
    7
    限定字符     含义
    ? 零次或一次
    * 零次或多次
    + 一次或多次
    {n} n次
    {n,} 至少n次
    {n,m} n到m次

如(A+)表示一个或多个A

点号操作符 .

匹配任意一个字符(不包含换行符)

表达式中的反斜杠 \

表达式中的反斜杠有多重意义,如转义、指定预定义的字符集、定义断言、显示不打印的字符。

转义字符

转义字符主要是将一些特殊字符转为普通字符。而这些常用特殊字符有”.”,”?”、”\”等。

指定预定义的字符集

1
2
3
4
5
6
7
字符          含义
\d 任意一个十进制数字[0-9]
\D 任意一个非十进制数字
\s 任意一个空白字符(空格、换行符、换页符、回车符、字表符)
\S 任意一个非空白字符
\w 任意一个单词字符
\W 任意个非单词字符

显示不可打印的字符

1
2
3
4
5
6
7
字符          含义
\a 报警
\b 退格
\f 换页
\n 换行
\r 回车
\t 字表符

括号字符()

在正则表达式中小括号的作用主要有:

  • 改变限定符如(|、* 、^)的作用范围
    如(my|your)baby,如果没有”()”,|将匹配的是要么是my,要么是yourbaby,有了小括号,匹配的就是mybaby或yourbaby。
  • 进行分组,便于反向引用

    反向引用

    反向引用,就是依靠子表达式的”记忆”功能,匹配连续出现的字串或是字符。如(dqs)(pps)\1\2,表示匹配字符串dqsppsdqspps。

模式修饰符

式修饰符的作用是设定模式,也就是正则表达式如何解释。php中主要模式如下表:

1
2
3
4
5
修饰符	说明
i 忽略大小写
m 多文本模式
s 单行文本模式
x 忽略空白字符

https://www.cnblogs.com/hellohell/p/5718319.html

文章目录
  1. 1. 0x01 前言
  2. 2. 0x02 概述
  3. 3. 正则表达式的基本知识总结
    1. 3.1. 行定位符(^与$)
    2. 3.2. 单词定界符
    3. 3.3. 选择字符(|),表示或
    4. 3.4. 排除字符
    5. 3.5. 限定符(?*+{n,m})
    6. 3.6. 点号操作符 .
    7. 3.7. 表达式中的反斜杠 \
    8. 3.8. 转义字符
    9. 3.9. 指定预定义的字符集
    10. 3.10. 显示不可打印的字符
    11. 3.11. 括号字符()
    12. 3.12. 反向引用
    13. 3.13. 模式修饰符
,