PHP如何实现只允许特定域名访问网站?域名访问限制技巧

在PHP中限制特定域名访问网站,可以通过检查HTTP请求头中的HTTP_REFERERHTTP_ORIGIN字段实现,以下是两种常用方法:

php限制域名访问网站


方法1:验证 Referer(适用于页面跳转)

// 允许访问的域名列表
$allowedDomains = [
    'example.com',
    'subdomain.example.com'
];
// 获取Referer并提取域名
$referer = $_SERVER['HTTP_REFERER'] ?? '';
$domain = parse_url($referer, PHP_URL_HOST);
// 验证
if (empty($referer) || !in_array($domain, $allowedDomains)) {
    http_response_code(403); // 禁止访问
    exit('Access Denied: Domain not allowed.');
}
// 正常执行业务代码...

方法2:验证 Origin(适用于AJAX/API请求)

// 允许访问的域名列表
$allowedOrigins = [
    'https://example.com',
    'https://subdomain.example.com'
];
// 获取Origin头
$origin = $_SERVER['HTTP_ORIGIN'] ?? '';
// 验证
if (!in_array($origin, $allowedOrigins)) {
    http_response_code(403);
    exit('Access Denied: Invalid origin.');
}
// 可选:设置CORS响应头(用于AJAX)
header("Access-Control-Allow-Origin: $origin");
header("Access-Control-Allow-Credentials: true");

重要注意事项:

  1. 安全性

    • RefererOrigin可被伪造,不能依赖其做敏感操作的安全验证
    • 关键操作(如支付、账户修改)应使用服务端会话(Session)或Token验证。
  2. 适用场景

    • Referer:普通页面跳转、资源防盗链(图片/文件)。
    • Origin:AJAX请求、API接口跨域控制。
  3. 直接访问处理

    php限制域名访问网站

    • 直接输入URL访问时Referer为空,需根据需求决定是否允许(示例代码中禁止了空Referer)。
  4. 通配符支持

    • 如需泛域名匹配(如*.example.com),可用正则:
      $pattern = '/.example.com$/';
      if (!preg_match($pattern, $domain)) { ... }
  5. 性能优化

    将域名列表缓存或存储在配置文件中,避免每次请求重复定义。

    php限制域名访问网站


完整示例(结合两种方法):

$allowedDomains = ['example.com', 'api.example.com'];
$refererDomain = parse_url($_SERVER['HTTP_REFERER'] ?? '', PHP_URL_HOST);
$origin = $_SERVER['HTTP_ORIGIN'] ?? '';
// 验证Referer(非AJAX)或Origin(AJAX)
$isValid = in_array($refererDomain, $allowedDomains) || 
           in_array(parse_url($origin, PHP_URL_HOST), $allowedDomains);
if (!$isValid) {
    http_response_code(403);
    exit('Domain not permitted.');
}

提示:对于生产环境,建议结合Web服务器(如Nginx/Apache)的访问控制,效率更高且减少PHP处理压力。

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

(0)
上一篇 2026年2月9日 18:27
下一篇 2026年2月9日 18:39

相关推荐

  • php网站工具哪个好用?免费php网站开发工具推荐

    在当前的Web开发生态中,PHP依然占据着极其重要的地位,构建了全球超过70%的网站后台,构建一套高效、安全且可扩展的PHP网站工具链,是保障项目稳定性与开发效率的核心关键, 这不仅仅是选择一个好用的框架那么简单,而是需要从开发环境、代码质量管理、性能优化到云端部署运维的全生命周期管理,一个成熟的工具体系能将开……

    2026年3月20日
    0611
  • POS刷卡显示服务器无反应?是什么原因导致的?如何解决?

    问题概述与常见场景POS机(销售点终端)在刷卡或插卡支付时,屏幕显示“服务器无反应”“无法连接服务器”或“交易失败”等提示,是商户在日常收银中常见的故障,该问题会导致交易中断,影响客户体验与商户收入,尤其在高峰时段(如餐饮、零售行业)更易引发连锁反应,常见原因分析POS机“服务器无反应”通常由硬件、软件、网络及……

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

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

      2026年1月10日
      020
  • 2025年个人新手建站,如何抢到稳定靠谱的免费虚拟主机?

    在数字时代,拥有一个属于自己的网站,无论是用于展示个人作品、记录学习心得,还是进行小型项目测试,都已成为许多人的需求,对于初学者、学生或预算有限的开发者而言,虚拟主机的费用可能是一笔不小的开销,“怎么抢免费虚拟主机号码”成为了他们探索网络世界的第一步,这里的“号码”可以理解为一个可用的免费主机账号或服务名额,本……

    2025年10月19日
    03350
  • php聊天网站源码怎么选?免费开源php聊天系统推荐

    构建一个高性能、高并发且具备商业价值的PHP聊天网站,核心关键不在于单纯代码堆砌,而在于架构选型与服务器环境的深度调优,一套优质的PHP聊天网站源码,必须能够解决传统PHP轮询机制带来的高延迟与服务器资源枯竭问题,实现从“伪即时”到“真即时”的跨越,这是项目能否长期稳定运营的决定性因素,PHP聊天网站源码的技术……

    2026年3月10日
    0432

发表回复

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