preg_match to domain.tld

问题描述:

如何获取只包含domain.tld的字符串?preg_match to domain.tld

if (preg_match('^(?:[-A-Za-z0-9]+\.)+[A-Za-z]{2,6}$', $domain)) 
echo "domain.tld found!"; 

但对正则表达式^(?:[-A-Za-z0-9]+\.)+[A-Za-z]{2,6}$,子域也没关系。但我只想检查“domain.tld”。我应该使用什么正则表达式?

谢谢。

if (preg_match('/^[-a-z0-9]+\.[a-z]{2,6}$/', strtolower($domain))) 
    echo "domain.tld found!"; 

将是明显的答案。你可能永远是对的TLD部分更具体的,如果你想删除误报:

if (preg_match('/^[-a-z0-9]+\.[a-z][a-z]|biz|cat|com|edu|gov|int|mil|net|org|pro|tel|aero|arpa|asia|coop|info|jobs|mobi|name|museum|travel$/', strtolower($domain))) 
    echo "domain.tld found!"; 

如果你想拼出国家代码顶级域也,这里的当前列表:

if (preg_match('/^[-a-z0-9]+\.a[cdefgilmnoqrstuwxz]|b[abdefghijmnorstvwyz]|c[acdfghiklmnoruvxyz]|d[ejkmoz]|e[cegrstu]|f[ijkmor]|g[abdefghilmnpqrstuwy]|h[kmnrtu]|i[delmnoqrst]|j[emop]|k[eghimnprwyz]|l[abcikrstuvy]|m[acdeghklmnopqrstuvwxyz]|n[acefgilopruz]|om|p[aefghklmnrstwy]|qa|r[eosuw]|s[abcdeghijklmnortuvyz]|t[cdfghjklmnoprtvwz]|u[agksyz]|v[aceginu]|w[fs]|y[et]|z[amw]|biz|cat|com|edu|gov|int|mil|net|org|pro|tel|aero|arpa|asia|coop|info|jobs|mobi|name|museum|travel$/', strtolower($domain))) 
    echo "domain.tld found!"; 

我会也接受了国际顶级域名

xn--p1ai|xn--fiqs8s|xn--fiqz9s|xn--o3cw4h|xn--wgbh1c|xn--zckzah|xn--0zwm56d|xn--deba0ad|xn--g6w251d|xn--j6w193g|xn--kprw13d|xn--kpry57d|xn--pgbs0dh|xn--jxalpdlp|xn--kgbechtv|xn--fzc2c9e2c|xn--ygbi2ammx|xn--9t4b11yi5a|xn--mgbaam7a8h|xn--mgbayh7gpa|xn--80akhbyknj4f|xn--xkc2al3hye2a|xn--11b5bs3a9aj6g|xn--mgberp4a5d4ar|xn--hgbk6aj7f53bba|xn--hlcj6aya9esc7a 

,或者至少xn--[a-z0-9]+

因此,那些加.arpa

if (preg_match('^[-a-z0-9]+\.a[cdefgilmnoqrstuwxz]|b[abdefghijmnorstvwyz]|c[acdfghiklmnoruvxyz]|d[ejkmoz]|e[cegrstu]|f[ijkmor]|g[abdefghilmnpqrstuwy]|h[kmnrtu]|i[delmnoqrst]|j[emop]|k[eghimnprwyz]|l[abcikrstuvy]|m[acdeghklmnopqrstuvwxyz]|n[acefgilopruz]|om|p[aefghklmnrstwy]|qa|r[eosuw]|s[abcdeghijklmnortuvyz]|t[cdfghjklmnoprtvwz]|u[agksyz]|v[aceginu]|w[fs]|y[et]|z[amw]|biz|cat|com|edu|gov|int|mil|net|org|pro|tel|aero|arpa|asia|coop|info|jobs|mobi|name|museum|travel|arpa|xn--[a-z0-9]+$', strtolower($domain))) 
+0

提取http://www.example.com他们不工作 – transilvlad 2012-10-07 20:01:28

+0

取决于你正在寻找通过什么时,^可能没有必要。例如,如果您通过电子邮件列表进行搜索,则应删除^,然后这将起作用。 – zeusstl 2016-08-25 16:21:08

+0

@zeusstl对。 – Charles 2016-08-25 17:50:01

你想找到一个特定文本domain.tld而与A-Za-z0-9字符类的组合正则表达式匹配几乎所有的文本。你为什么不干脆做:

if (strpos('domain.tld', $domain) !== false) { 
    echo "domain.tld found!"; 
} 

something http://www.example.com/page/blabla.html some thingggggg

<?php 
preg_match('/((http:||https:)\/\/.*?)[\/||\n||\s]/s', $f,$n); 
echo $n[1]; 
?>