Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/297.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 检查URL是否以图像Ext结尾_Php_Regex - Fatal编程技术网

Php 检查URL是否以图像Ext结尾

Php 检查URL是否以图像Ext结尾,php,regex,Php,Regex,我有这个preg_match()这里检查输入值是否是URL $regex = '_^(?:(?:https?|ftp)://)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2

我有这个
preg_match()
这里检查输入值是否是
URL

$regex = '_^(?:(?:https?|ftp)://)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\x{00a1}-\x{ffff}0-9]+-?)*[a-z\x{00a1}-\x{ffff}0-9]+)(?:\.(?:[a-z\x{00a1}-\x{ffff}0-9]+-?)*[a-z\x{00a1}-\x{ffff}0-9]+)*(?:\.(?:[a-z\x{00a1}-\x{ffff}]{2,})))(?::\d{2,5})?(?:/[^\s]*)?$_iuS';
if (preg_match($regex, $string)) {
    echo "It is an Image URL";
} else {
    echo "It is not an Image URL";
}
我从中获取了它,因为它显然具有最好的验证结果,它太长了,而且我对正则表达式不是很精通,所以我尝试添加一个部分,检查URL是否以图像扩展结尾


因此,我在
(?:/[^\s]*)?$\u iuS
部分之前添加了以下规则
(:jpg | gif | png)
,但没有起作用,我到底犯了什么错误?

为什么不使用适当的工具来完成这项工作:

$exts = array('jpg', 'gif', 'png');

if(filter_var($string, FILTER_VALIDATE_URL) &&
   in_array(strtolower(pathinfo($string, PATHINFO_EXTENSION)), $exts)) {
        echo "It is an Image URL";
} else {
        echo "It is NOT an Image URL";
}

有许多验证筛选器,可以返回有关路径的信息。

为什么不为作业使用适当的工具:

$exts = array('jpg', 'gif', 'png');

if(filter_var($string, FILTER_VALIDATE_URL) &&
   in_array(strtolower(pathinfo($string, PATHINFO_EXTENSION)), $exts)) {
        echo "It is an Image URL";
} else {
        echo "It is NOT an Image URL";
}

有许多验证筛选器,可以返回有关路径的信息。

是否尝试使用
筛选器\u var
而不是此怪物来执行
筛选器\u验证\u URL
?如果只允许这三个扩展,请在
$
之后添加以下内容:
(?@baldrs在我提到的URL中,他们的静态告诉我们,这个正则表达式比
FILTER\u VALIDATE\u URL
更适合验证,你是否尝试过用
FILTER\u var
代替这个怪物来进行
FILTER\u VALIDATE\u URL
呢?如果你只想允许这三个扩展,请在
$
之后添加以下内容:
(?@baldrs在我提到的URL中,他们静态告诉我们,这个正则表达式比
FILTER\u VALIDATE\u URL
更适合验证,这正是我所说的
FILTER\u var
通过检查
HEAD
来工作的
不,它解析路径以提供部分信息。检查链接。我所说的使用
filter\u var
的确切意思是
pathinfo
通过检查
?因为我不希望有任何机会遭受
DDoS
攻击。文档头或HTTP头?不,它解析路径以提供部分信息。检查link。