当前位置:首页 > 文章列表 > 文章 > php教程 > XAMPP多端口配置实现多域名SSO模拟

XAMPP多端口配置实现多域名SSO模拟

2026-04-30 16:34:02 0浏览 收藏
XAMPP 本身无法直接支持跨域名单点登录(SSO)的本地模拟,因为浏览器同源策略严格隔离不同域名或端口间的 Cookie、LocalStorage 和会话状态,即便通过多端口或多域名配置让多个站点可独立访问,也无法实现登录态共享;真正可行的本地 SSO 模拟必须统一主域名(如 a.test/b.test/sso.test),配合 hosts 映射、SSL 加密(启用 mod_ssl)、显式设置 Domain=.test + SameSite=None + Secure 的 Cookie,并启用 mod_proxy 实现反向代理统一入口——否则任何基于 localhost:端口 或 .local 域名的尝试都会被现代浏览器拦截或失效。

XAMPP配置多端口实现本地多域名SSO模拟

直接说结论:XAMPP 本身不支持跨域名的 SSO(单点登录)模拟,VirtualHost 配置多端口 + 多域名只是让多个站点能被独立访问,但浏览器仍会把 www.a.comwww.b.com 视为完全隔离的源——Cookie、LocalStorage、SameSite 策略全不共享。真要模拟 SSO,得绕过同源限制,或改用其他机制。

为什么多端口 ≠ 多域名 SSO?

很多人以为只要配好 localhost:3000localhost:3001,再分别绑 a.localb.local,就能测试跨域登录态传递。但现实是:

  • 浏览器对 a.local 写的 Cookie,b.local 根本读不到,Domain 属性无法跨二级域名设成 .local.local 是保留 TLD,Chrome/Firefox 拒绝写入)
  • localhost:3000localhost:3001 虽然 IP 相同,但端口不同 → 仍是不同源 → document.cookie 不互通
  • 现代浏览器默认启用 SameSite=Lax,即使你手动设 Domain=localhost,带端口的请求也会被拦截

想本地模拟 SSO,必须统一主域名

可行路径只有一条:所有服务共用同一个一级域名(如 a.testb.testsso.test),靠子域名 + 共享 Cookie 实现登录态透传。操作要点:

  • C:\Windows\System32\drivers\etc\hosts 中统一映射:
    127.0.0.1 a.test
    127.0.0.1 b.test
    127.0.0.1 sso.test
  • 每个 ServerName 必须严格匹配 hosts 里写的域名,不能混用 localhost 或 IP
  • SSO 服务(如 PHP 写的登录中心)响应 Set-Cookie 时,必须显式指定:
    Set-Cookie: auth_token=xxx; Domain=.test; Path=/; HttpOnly; Secure; SameSite=None
  • Secure 标志要求 HTTPS —— 本地开发需用 XAMPP 自带的 OpenSSL 配 SSL 证书,否则浏览器拒绝接受 SameSite=None

多端口配置反而破坏 SSO 模拟条件

如果你硬要在 httpd.conf 里加 Listen 8080,又在 httpd-vhosts.conf 里写 ,会出现这些实际问题:

  • 浏览器地址栏显示 http://a.test:8080/ → 此时域名是 a.test:8080,不是 a.test → Cookie 的 Domain=.test 失效
  • 前端发请求到 /api/login,如果没配代理,实际发向 a.test:8080/api/login,后端返回的 Cookie 域名会被浏览器自动设为 a.test:8080,无法被 b.test 读取
  • Apache 默认不监听非 80/443 端口的 HTTPS,SameSite=None; Secure 在 HTTP 端口下直接被忽略

真正可用的本地 SSO 开发方案

放弃“多端口多域名”思路,改用以下任一方式:

  • 反向代理统一入口:用 Apache 的 mod_proxya.test/apib.test/apisso.test/auth 全部代理到本地不同端口(如 127.0.0.1:3000127.0.0.1:4000),对外只暴露 :80,保持同源
  • .localhost 替代 .test:RFC 6761 明确规定 .localhost 只能解析为 127.0.0.1,且现代浏览器允许设置 Domain=localhost(注意不是 .localhost),可跨子域共享 Cookie
  • 跳过 Cookie,用 JWT + localStorage + postMessage:登录页(auth.localhost)登录后,把 token 通过 window.postMessage 发给父页(a.localhost),由父页存入 localStorage 并自行管理有效期 —— 完全绕开同源限制

最常被忽略的一点:XAMPP 的 Apache 默认禁用 mod_sslmod_proxy,启用前必须先在 httpd.conf 里取消对应 LoadModule 行的注释,否则代理或 HTTPS 都跑不起来。

今天关于《XAMPP多端口配置实现多域名SSO模拟》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

苹果旧机数据迁移到新机教程苹果旧机数据迁移到新机教程
上一篇
苹果旧机数据迁移到新机教程
Go语言错误处理技巧大全
下一篇
Go语言错误处理技巧大全
查看更多
最新文章
资料下载
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    4430次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    4789次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    4665次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    6451次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    5039次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码