> 백엔드 개발 > PHP 튜토리얼 > 特征匹配 - PHP 正则表达式 如何实现 反模式匹配

特征匹配 - PHP 正则表达式 如何实现 反模式匹配

WBOY
풀어 주다: 2016-06-06 20:39:41
원래의
1131명이 탐색했습니다.

需求

如何用一行正则表达式进行排除匹配:不以/结尾且不以文件扩展名结尾的字符串
目的:访问的不是有扩展名文件名格式的、且结尾不是以“/”结尾,那么重定向到带“/”的网址。

示例

<code>#符合
/images        ==> /images/
/uploads        ==> /uploads/
/register        ==> /register/
/images/uploads/201412    ==>    /images/uploads/201412/
/2014/222/jpg        ==>    /2014/222/jpg/

#不符合
/
/images/
/uploads/
/index.php
/images/test.jpg
/upload/my.1/test.jpg?a=1111&b=ddd&file=t.php
/index.html</code>
로그인 후 복사
로그인 후 복사

正则

<code>#如下是错误的
[^\/|\.[a-zA-Z]{2,4}]$ </code>
로그인 후 복사
로그인 후 복사

正则中括号貌似只能排除单个字符串,而不能排除一段字符串。如何排除一段字符串,如何实现如上的匹配

回复内容:

需求

如何用一行正则表达式进行排除匹配:不以/结尾且不以文件扩展名结尾的字符串
目的:访问的不是有扩展名文件名格式的、且结尾不是以“/”结尾,那么重定向到带“/”的网址。

示例

<code>#符合
/images        ==> /images/
/uploads        ==> /uploads/
/register        ==> /register/
/images/uploads/201412    ==>    /images/uploads/201412/
/2014/222/jpg        ==>    /2014/222/jpg/

#不符合
/
/images/
/uploads/
/index.php
/images/test.jpg
/upload/my.1/test.jpg?a=1111&b=ddd&file=t.php
/index.html</code>
로그인 후 복사
로그인 후 복사

正则

<code>#如下是错误的
[^\/|\.[a-zA-Z]{2,4}]$ </code>
로그인 후 복사
로그인 후 복사

正则中括号貌似只能排除单个字符串,而不能排除一段字符串。如何排除一段字符串,如何实现如上的匹配

<code>$arr = [
    'home.inc/include.dir/a/', 
    'home.inc/include.dir/a.7z', 
    'home.inc/include.dir/a', 
];

$arr = array_filter($arr, function($str) {
    return preg_match('/^(?:[^\/]*\/)*[^.]*[^\/]$/', $str); 
    // also preg_match('/^(?!.*?(?:\/|\.[^\/]+)$).*/', $str);
});

var_dump($arr); // array(1) { [2]=> string(22) "home.inc/include.dir/a" }
</code>
로그인 후 복사

你需要的应该是「零宽断言」

写了一个奇丑的,实在没办法写的更好看了

<code>^.*(?</code>
로그인 후 복사

!preg_match('#(\/$)|(\/(?=[^\/]*\.[^\/]*$))#', $str)

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿