可以使用跨站COOKIE来操作,主要涉及P3P header技术。
P3P 是 The Platform for Privacy Preferences 的简称,他允许跨域访问隐私数据,从而可以跨域set-COOKIE
操作步骤如下:
1.在A站点www.a.com登录页面用户完成登录后在用户浏览器执行b站点的script脚本,代码如下:
<?php
echo '<script src="http://www.b.com/setCOOKIE.php"></script>';die;
2.然后在B站点的这个setCOOKIE.php代码里写入COOKIE
<?php3.这样在B站点上就可以获取到tokenid这个COOKIE的值,如果session会话使用redis等分布式会话共享的话,就实现一站登录了。
header('P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"');
setCOOKIE("tokenid", "sdfsdf34234234324", time()+3600, "/");
注意:P3P header 在同一个包里只能设置一次,后面的P3P Header不会覆盖前面的P3P header,浏览器只认第一个。
网友回复
python如何实现torrent的服务端进行文件分发p2p下载?
如何在浏览器中录制摄像头和麦克风数据为mp4视频保存下载本地?
go如何编写一个类似docker的linux的虚拟容器?
python如何写一个bittorrent的种子下载客户端?
ai能通过看一个网页的交互过程视频自主模仿复制网页编写代码吗?
ai先写功能代码通过chrome mcp来进行测试功能最后ai美化页面这个流程能行吗?
vue在手机端上下拖拽元素的时候如何禁止父元素及body的滚动导致无法拖拽完成?
使用tailwindcss如何去掉响应式自适应?
有没有直接在浏览器中运行的离线linux系统?
nginx如何保留post或get数据进行url重定向?