在PHP中獲取和驗證Referer的技巧有以下幾種方式:
$referer = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '';
$referer = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '';
if(preg_match('/^https?:\/\/(www\.)?example\.com/', $referer)){
// Referer符合指定的格式
} else {
// Referer不符合指定的格式
}
$referer = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '';
$referer_host = parse_url($referer, PHP_URL_HOST);
if($referer_host == 'example.com'){
// Referer域名符合指定的格式
} else {
// Referer域名不符合指定的格式
}
$referer = $_SERVER['HTTP_REFERER'];
if (strpos($referer, 'example.com') !== false) {
// Referer包含指定的域名
} else {
// Referer不包含指定的域名
}
需要注意的是,Referer頭信息是由瀏覽器提供的,因此可能會被篡改或者不存在,因此建議在驗證Referer時要考慮到這些情況并進行適當的處理。