Использование PHP для поиска части URL - PullRequest
3 голосов
/ 16 ноября 2009

Взять этот домен:

http://www. ?. co.uk/elderly-care-advocacy/mental-capacity-act-advance-medical-directive.html

Как я могу использовать PHP, чтобы найти все, что находится между первым и вторым слэшем, независимо от того, изменяется оно или нет?

Т.е.. пожилые люди по уходу-адвокатура

Любой helo был бы очень признателен.

Ответы [ 8 ]

5 голосов
/ 16 ноября 2009
//strip the "http://" part. Note: Doesn't work for HTTPS!
$url = substr("http://www.example.com/elderly-care-advocacy/mental-capacity-act-advance-medical-directive.html", 7);

// split the URL in parts
$parts = explode("/", $url);

// The second part (offset 1) is the part we look for
if (count($parts) > 1) {
    $segment = $parts[1];
} else {
    throw new Exception("Full URLs please!");
}
2 голосов
/ 16 ноября 2009
$url = "http://www.example.co.uk/elderly-care-advocacy/mental-capacity-act-advance-medical-directive.html";
$parts = parse_url($url);
$host = $parts['host'];
$path = $parts['path'];

$items = preg_split('/\//',$path,null,PREG_SPLIT_NO_EMPTY);

$firstPart = $items[0];
1 голос
/ 16 ноября 2009

Все, что вам нужно сделать, это сначала проанализировать URL, а затем взорвать строку и получить первую часть. С некоторыми проверками работоспособности, которые выглядят так:

$url = 'http://www.?.co.uk/elderly-care-advocacy/mental-capacity-act-advance-medical-directive.html';
$url_parts = parse_url($url);
if (isset($url_parts['path'])) {
    $path_components = explode('/', $ul_parts['path']);
    if (count($path_components) > 1) {
        // All is OK. Path's first component is in $path_components[0]
    } else {
        // Throw an error, since there is no directory specified in path
        // Or you could assume, that $path_components[0] is the actual path
    }
} else {
    // Throw an error, since there is no path component was found
}
1 голос
/ 16 ноября 2009

explode('/', $a);

1 голос
/ 16 ноября 2009

от макушки головы:

$url = http://www.example.co.uk/elderly-care-advocacy/mental-capacity-act-advance-medical-directive.html
$urlParts = parse_url($url); // An array
$target_string = $urlParts[1] // 'elderly-care-advocacy'

Приветствия

0 голосов
/ 04 августа 2014

Я тоже был удивлен, но это работает.

$url='http://www.?.co.uk/elderly-care-advocacy/...'
$result=explode('/',$url)[3];
0 голосов
/ 16 ноября 2009

Parse_URL - ваш лучший вариант. Он разбивает строку URL на компоненты, которые вы можете выборочно запрашивать.

Эту функцию можно использовать:

function extract_domain($url){

    if ($url_parts = parse_url($url), $prefix = 'www.', $suffix = '.co.uk') {
        $host = $url_parts['host'];
        $host = str_replace($prefix,'',$host);
        $host = str_replace($suffix,'',$host);
        return $host;
    }
    return false;
}

$host_component = extract_domain($_SERVER['REQUEST_URI']);
0 голосов
/ 16 ноября 2009

Я думаю, что Regular Expression должно быть хорошо для этого.

Попробуйте использовать, например, /[^/]+/, который должен дать вам /elderly-care-advocacy/ в качестве второго индекса массива в вашем примере.

(Первая строка /www.?.com/)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...