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

相关推荐

  • pro装虚拟机教程视频具体操作步骤是什么?新手也能学会的安装方法详解

    Pro装虚拟机教程视频详解:从基础到高级的全面实践指南虚拟机的核心价值与Pro装必要性虚拟机(Virtual Machine, VM)是一种模拟计算机硬件环境的软件,通过虚拟化技术将物理服务器拆分为多个逻辑隔离的系统,实现多系统共存、软件测试、开发环境隔离等功能,对于IT从业者、开发人员或企业测试团队而言,Pr……

    2026年1月18日
    0390
  • PostgreSQL性能优化,如何解决常见性能瓶颈与优化策略?

    PostgreSQL性能优化深度解析与实践指南基础配置与硬件调优:从底层保障性能PostgreSQL作为开源关系型数据库,其性能表现高度依赖硬件资源分配与核心配置参数,合理配置能显著降低系统开销,提升查询效率,硬件层面优化内存分配:PostgreSQL主要依赖内存执行操作(如缓冲区、排序内存),建议将服务器总内……

    2026年1月17日
    0390
  • PostgreSQL如何实现清空数据库中的折扣数据?

    PostgreSQL作为企业级关系型数据库管理系统,在金融、电商、政务等领域广泛应用,随着业务迭代,数据量增长迅速,定期清空数据库(如历史交易数据、测试环境数据)成为必要的管理操作,不当的清空操作可能导致数据丢失、系统性能下降甚至服务中断,理解PostgreSQL清空数据库的规范方法与最佳实践至关重要,本文将系……

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

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

      2026年1月10日
      020
  • 为什么PS4更换服务器后游戏联机变卡?更换服务器的影响及官方解决方案是什么?

    PS4更换服务器:流程解析与实战优化指南PS4作为索尼推出的主流游戏主机,其服务器系统是保障玩家联机、更新、在线功能的核心,随着游戏内容的不断更新和玩家数量的增长,服务器负载逐渐增加,部分玩家可能遇到服务器响应慢、联机延迟高等问题,更换服务器成为优化体验的关键步骤,本文将从流程、常见问题、专业经验等方面,详细解……

    2026年1月9日
    0540

发表回复

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