位置: 编程技术 - 正文

详解cookie验证的php应用的一种SSO解决办法(cookie验证和token验证的区别)

编辑:rootadmin

推荐整理分享详解cookie验证的php应用的一种SSO解决办法(cookie验证和token验证的区别),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:cookie验证失败如何解决,通过cookie验证后不需要重新提交表单,cookie验证失败是什么意思,cookie验证失败如何解决,cookie检验,cookie检验,cookie认证,cookie验证用户登录,内容如对您有帮助,希望把文章链接给更多的朋友!

详解cookie验证的php应用的一种SSO解决办法

近日,项目中需要接入一个“年久失修”的PHP应用,由于系统已经建设多年,并且是信息中心自己的人通过某些工具弄出来的,而且是本人未真正接触过的PHP写的,而且跟我们的系统不在同一服务器上也就是存在跨域的问题,想通过客户端模拟登录的方式来实现,但是总是不成功。

没办法,只好想尽一切办法查看页面源代码,然后,找服务器的php文件,分析。

由于对php不熟悉,加上没有仔细看,因此,对于找到的登录页面的php文件,一开始只是有一个初步的了解,基本上确定是通过cookie来实现,实际上真正的验证机制还有如何验证都没有了解清楚,急着就开始新的征程,结果屡试屡败。先说一下一开始的实现方式:

最开始

系统中添加一个iframe,试图从本地应用中给iframe中的远程系统的指定页面的用户名、密码赋值,并模拟“登录”按钮的单击事件。这个是必定失败的,因为,跨域了,js一般不能跨域远程操作别人的东西。

然后

详解cookie验证的php应用的一种SSO解决办法(cookie验证和token验证的区别)

本地form的远程action。在本地的页面中新增一个form,此form中添加上与目标系统一样的登录界面的内容(就是用户名、密码输入框,特别说明的是此应用尚没有验证码),然后在页面加载时,便给form中的元素赋值,点击本地页面的“单点登录”时,提交此form,试图按照java登录验证的模式来实现此php系统的登录验证。但是,依然,无法正常登录。

接下来

仔细分析登录的php文件。发现验证过程其实是通过cookie来实现的,依稀记得早期的很多BBS都是这种方式。找相关人员通过各种途径,大体了解了登录验证的机制及过程,原来是在登录之后,将信息写入cookie,每个页面都会引入一个通过读取cookie并根据cookie的内容进行判断的php文件。这样了解了验证机制。于是,想要通过跨域写cookie的方式来实现,由于本身的应用是portal应用,因此,写跨域应用也费了一些劲,最终,写本地cookie没问题,但是跨域的cookie,连想都不用想,生成不了。

最后

分析php的登录界面,发现之所以每次定向的登录php文件,在进行验证的时候,都有一个if(isset($submit) and $submit=="登录")这样的判断,不是特别明白这句是什么意思,isset貌似是判断参数是否为空,而后面则判断参数值为“登录”!由于本人php水平太低,不知道这样的判断有何作用,是否能够执行。最终,只能跟客户讨论是否可以通过在服务端新增一个专门用于接收单点登录需要的php文件。只是把原来的登录用的php文件做了修改,去掉这些判断,并且原来的登录在验证之后,跳转到的目标页面是通过从地址栏获取的信息来进行跳转的,因此,对此部分内容也进行了调增。这样,最终形成了以下的ssologon.php文件

然后,把本地应用中的form的action指定为此php文件,搞定!

总结,对于需要分析别人的东西才能搞定的事情,一定不能过于焦躁,要仔细,了解原理,才能事半功倍。

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

php+ajax实现仿百度查询下拉内容功能示例 本文实例讲述了php+ajax实现仿百度查询下拉内容功能。分享给大家供大家参考,具体如下:运行效果如下:html代码:!DOCTYPEhtmlhtmllang="en"headmetacharset="UTF-8

PHP高效获取远程图片尺寸和大小的实现方法 PHP高效获取远程图片尺寸和大小的实现方法在这里分享一下自己的心得,希望和大家一起分享技术,如果有什么不足,还请大家指正。写出这篇目的,

PHP实现实时生成并下载超大数据量的EXCEL文件详解 前言最近在工作中接到一个需求,通过选择的时间段导出对应的用户访问日志到excel中,由于用户量较大,经常会有导出万加数据的情况。而常用的PHPe

标签: cookie验证和token验证的区别

本文链接地址:https://www.jiuchutong.com/biancheng/284201.html 转载请保留说明!

上一篇:PHP简单实现二维数组赋值与遍历功能示例(php生成二维码)

下一篇:php+ajax实现仿百度查询下拉内容功能示例(php ajax 实现)

  • 小微企业所得税优惠政策最新2022
  • 企业工商年报填写须知
  • 评估入账几种情况
  • 发行股票手续费佣金计入什么科目
  • 个体户交了增值税又开负数发票怎么退税
  • 个体户餐饮经营范围全部怎么写
  • 个体户3万免税免的是哪些税
  • 票据贴现的账务处理案例
  • 销售商品房属于什么税
  • 广告服务怎么做分录
  • 老板请员工吃饭唯独没叫你是什么意思
  • 营改增后不动产租赁税率
  • 银行收回贷款本息企业怎么做分录
  • 补交增值税如何入账
  • 建筑行业异地预缴
  • 开票未收到款会计分录
  • 为什么报税资料老是显示有
  • 股票现金分红
  • 建筑工程确认收入条件
  • 进的货没有入库怎么处理
  • 购入商品入库时发现实收物多余应收数计入什么科目
  • 企业年会的费用会计分录
  • 招待客户住宿费用计入什么科目
  • php变量底层实现
  • 债务担保是什么意思
  • 租入固定资产改建支出何时开始摊销
  • 什么叫集团内企业
  • 鸟瞰画面
  • php curl_exec
  • 获取企业微信用户身份信息授权失败
  • pytorch怎么入门
  • 卷积神经网络CNN实验报告
  • vue从入门到精通教程
  • 非一般纳税人怎么报税
  • 待报解预算收入待结算财政款项
  • 转让股权个税的计税基础
  • 现金折扣属于什么
  • 决算报表属于会计账簿吗
  • 小企业会计准则2023电子版
  • sqlserver实现分页查询
  • 营业总收入同比增长怎么分析
  • 安装购买的材料怎么做账
  • 单位代个人交社保可以吗
  • 付承包费计入什么科目
  • 小规模纳税人去银行开立什么账户
  • 未取得发票该怎么说明
  • 生产成本有贷方余额怎么调整
  • 开具红字发票后所冲销的销项税应该怎么处理?
  • 销售费用可以提现吗
  • 资金账簿减半征收印花税
  • 付给外包公司的垃圾处理费会计分录
  • 款项已支付是什么科目?
  • mysql触发事件
  • 让Windows XP、2003、2008自动登录的设置
  • mac外接显示器不显示全部桌面
  • centos6.10配置网络
  • win8系统出现蓝屏怎样处理
  • winxp教程
  • debian yum安装
  • linux建立动态库链接
  • windows如何关闭
  • winxp系统怎么安装
  • 人在国外怎么补办身份证
  • android中的布局分为6种,分别是
  • cocos2dx 3.3 tilemap 缩放滑动并且准确点击对象
  • Bullet(Cocos2dx)之增加调试绘制PhysicsDraw3D
  • js调用wsdl接口
  • JavaScript中String.match()方法的使用详解
  • python编程基础语法
  • javascript零基础入门书籍
  • python函数入门
  • 关于python整数类型
  • 安卓开发常见问题
  • 税盘换电脑怎么登陆
  • 西安大修基金和契税怎么计算
  • 中国依靠房地产能发展多久
  • 税务局查帐流程
  • 贵州银行短信服务怎么开通
  • 广西定额发票查询入口官网
  • 总公司和子公司是什么关系
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设