如何用PHP限制域名访问? | PHP安全配置优化指南

在PHP中限制域名访问可以通过检查HTTP请求中的Host头来实现,以下是几种实现方法:

php限制域名访问


方法1:直接比较域名(推荐)

// 允许访问的域名列表(不含端口)
$allowedDomains = [
    'example.com',
    'www.example.com',
    'app.example.com'
];
// 获取当前请求的域名(自动去除端口号)
$currentHost = strtolower(explode(':', $_SERVER['HTTP_HOST'])[0]);
// 验证域名
if (!in_array($currentHost, $allowedDomains)) {
    http_response_code(403); // 禁止访问
    exit('Access Denied: Invalid domain');
}
// 后续正常代码...

方法2:支持通配符的子域名匹配

$allowedPatterns = [
    'example.com',
    '*.example.com' // 允许所有子域名
];
$currentHost = strtolower(explode(':', $_SERVER['HTTP_HOST'])[0]);
$allowed = false;
foreach ($allowedPatterns as $pattern) {
    if ($pattern === $currentHost) {
        $allowed = true;
        break;
    }
    // 处理通配符 *.example.com
    if (strpos($pattern, '*') !== false) {
        $regex = '/^' . str_replace('*', '[^.]+', preg_quote($pattern, '/')) . '$/';
        if (preg_match($regex, $currentHost)) {
            $allowed = true;
            break;
        }
    }
}
if (!$allowed) {
    http_response_code(403);
    exit('Invalid domain');
}

方法3:通过.htaccess限制(更高效)

在网站根目录创建/修改.htaccess文件:

RewriteEngine On
RewriteCond %{HTTP_HOST} !^(www.)?example.com$ [NC]
RewriteCond %{HTTP_HOST} !^app.example.com$ [NC]
RewriteRule ^ - [F] # 返回403禁止访问

注意事项:

  1. 安全性

    • Host头可被伪造,敏感操作需额外验证(如Session/Cookie)
    • 此方法主要用于防止用户通过非常用域名访问
  2. 特殊场景处理

    php限制域名访问

    // 处理直接通过IP访问的情况
    if (!isset($_SERVER['HTTP_HOST']) || is_numeric(str_replace('.', '', $_SERVER['HTTP_HOST']))) {
        exit('Domain access only');
    }
  3. 端口处理

    • 代码中已自动剥离端口(如 example.com:8080example.com
    • 如需允许特定端口,需在允许列表中添加带端口的域名

完整示例代码:

<?php
// config.php - 域名验证
$allowed = [
    'example.com',
    'www.example.com',
    '*.app.example.com'
];
$host = $_SERVER['HTTP_HOST'] ?? '';
if (empty($host)) die('Invalid request');
// 剥离端口
$host = strtolower(explode(':', $host)[0]);
$valid = false;
foreach ($allowed as $domain) {
    // 完全匹配
    if ($domain === $host) {
        $valid = true;
        break;
    }
    // 通配符匹配
    if (strpos($domain, '*') !== false) {
        $pattern = '/^' . str_replace('*', '.*', preg_quote($domain)) . '$/';
        if (preg_match($pattern, $host)) {
            $valid = true;
            break;
        }
    }
}
if (!$valid) {
    http_response_code(403);
    include('forbidden.html'); // 自定义错误页
    exit;
}
// 后续业务代码...
?>

常见问题解决:

  1. 本地开发绕过

    // 在检测前加入开发环境白名单
    if ($_SERVER['REMOTE_ADDR'] === '127.0.0.1') return;
  2. 负载均衡场景

    php限制域名访问

    • 如果使用CDN/代理,检查X-Forwarded-Host头:
      $host = $_SERVER['HTTP_X_FORWARDED_HOST'] ?? $_SERVER['HTTP_HOST'];
  3. 大小写问题

    • 使用strtolower()统一转为小写比较

选择最适合你项目需求的方法,通常推荐使用.htaccess进行服务器级限制以减少PHP解析开销。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/290256.html

(0)
上一篇 2026年2月10日 03:39
下一篇 2026年2月10日 03:46

相关推荐

  • 如何准确找到POP3服务器地址与对应域名?

    POP3(Post Office Protocol 3)作为电子邮件接收的核心协议之一,在用户与邮件服务器的交互中承担着关键角色,其服务器地址和域名不仅是邮件客户端访问邮件资源的“导航标识”,更是保障邮件通信稳定、高效的基础,理解{pop3服务器地址和域名}的结构、配置逻辑及使用场景,对于个人用户优化邮件体验……

    2026年1月23日
    015010
  • PHP怎么调用视频API接口?视频API接口调用代码怎么写?

    PHP调用视频API接口是构建流媒体平台、在线教育系统及内容管理系统的核心技术环节,实现这一过程不仅要求开发者掌握HTTP协议与数据格式处理,更需注重鉴权安全、传输效率及异步任务管理,核心结论在于:通过构建标准化的请求封装类,结合云服务商提供的SDK或原生cURL库,能够高效、稳定地完成视频上传、转码及处理任务……

    2026年3月4日
    01245
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • pip2是什么?Python包管理器详解,一文搞懂安装与使用!

    pip2 是 专门用于安装和管理 Python 2 版本第三方软件包 的命令行工具,它是 Python 包管理器 pip 在 Python 2 环境下的具体实现,以下是关于 pip2 的关键点:针对 Python 2:pip2 安装的包是兼容 Python 2.x 版本的,它会将包安装到 Python 2 的……

    2026年2月9日
    02980
  • 大模型能帮我算清楚房贷利息吗,房贷利息怎么算

    大模型完全可以帮你算清楚房贷利息,但需注意其计算逻辑基于通用数学公式,无法直接接入银行实时利率系统,因此结果仅供参考,最终还款额以银行合同为准,大模型计算房贷的核心逻辑与优势算法原理:从黑盒到白盒传统房贷计算器往往只给出一个最终数字,而大模型(LLM)不仅能计算,还能解释过程,其核心基于两种主流还款方式的数学模……

    2026年6月17日
    0335

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注