位置: 编程技术 - 正文

PHP开发中csrf攻击的简单演示和防范(php csrf攻击)

编辑:rootadmin

推荐整理分享PHP开发中csrf攻击的简单演示和防范(php csrf攻击),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php cs fixer,php rfc,phpfastcgi,php csv,csrf php,php cs,php cs fixer,php cs,内容如对您有帮助,希望把文章链接给更多的朋友!

csrf攻击,即cross site request forgery跨站(域名)请求伪造,这里的forgery就是伪造的意思。网上有很多关于csrf的介绍,比如一位前辈的文章CSRF的攻击方式详解,参考这篇文章简单解释下:csrf 攻击能够实现依赖于这样一个简单的事实:我们在用浏览器浏览网页时通常会打开好几个浏览器标签(或窗口),假如我们登录了一个站点A,站点A如果是通过cookie来跟踪用户的会话,那么在用户登录了站点A之后,站点A就会在用户的客户端设置cookie,假如站点A有一个页面siteA-page.php(url资源)被站点B知道了url地址,而这个页面的地址以某种方式被嵌入到了B站点的一个页面siteB-page.php中,如果这时用户在保持A站点会话的同时打开了B站点的siteB-page.php,那么只要siteB-page.php页面可以触发这个url地址(请求A站点的url资源)就实现了csrf攻击。

上面的解释很拗口,下面举个简单的例子来演示下。

1,背景和正常的请求流程

A站点域名为html5.yang.com,它有一个/get-update.php&#;uid=uid&username=username地址,可以看到这个地址可以通过get方法来传递一些参数,假如这个页面的逻辑是:它通过判断uid是否合法来更新username,这个页面脚本如下:

正常情况下这个页面的链接是放在站点A下面的,比如A站点的csrfdemo.php页面,用户登录站点A以后可以通过点击这个链接来发送请求,比如站点A有一个页面脚本,包含了这个链接:

加载这个页面如下:

用点击页面中的链接来到get-update.php页面:

上面是正常的请求流程,下面来看B站点是如何实现csrf攻击的。

PHP开发中csrf攻击的简单演示和防范(php csrf攻击)

2,csrf攻击的最简单实现

B站点域名为test.yang.com,它有一个页面csrf.php,只要用户在维持A站点会话的同时打开了这个页面,那么B站点就可以实现csrf攻击。至于为什么会打开......,其实这种情景在我们浏览网页时是很常见的,比如我在写这篇博客时,写着写着感觉对csrf某个地方不懂,然后就百度了,结果百度出来好多结果,假如说有个网站叫csrf百科知识,这个网站对csrf介绍的非常详细、非常权威,那么我很可能会点进去看,但是这个网站其实是个钓鱼网站,它在某个访问频率很高的页面中嵌入了我博客编辑页面的url地址,那么它就可以实现对我博客的csrf攻击。好了,言归正传,下面来看下csrf.php脚本代码:

可以看到上面的代码没有php代码,只有一个img标签,img标签的src就是A站点的那个更新用户名的链接,只不过把username改为了jsonp,访问站点B的csrf.php这个页面:

下面再来访问下A站点的csrfdemo.php页面:

可以看到用户名被修改为了jsonp。

简单分析下:B站点的这个csrf.php利用了html中的img标签,我们都知道img标签有个src属性,属性值指向需要加载的图片地址,当页面载入时,加载图片就相当于向src指向的地址发起http请求,只要把图片的地址修改为某个脚本地址,这样自然就实现了最简单的csrf攻击。如此说来,其实csrf很容易实现,只不过大家都是“正人君子”,谁没事会闲着去做这种“下三滥”的事情。但是害人之心不可有,防人之心不可无。下面看下如何简单防范这种最简单的csrf攻击。

3,简单防范措施

其实防范措施也比较简单,A站点可以在get-update.php脚本中判断请求头的来源,如果来源不是A站点就可以截断请求,下面在get-update.php增加些代码:

但是,这样就万事大吉了吗,如果http请求头被伪造了呢?A站点升级了防御,B站点同时也可以升级攻击,通过curl请求来实现csrf,修改B站点的csrf.php代码如下:

这样同样可以实现csrf攻击的目的。那么就没有比较好的防范方法了吗?

4,小结

下面我们回到问题的开始,站点A通过cookie来跟踪用户会话,在cookie中存放了重要的用户信息uid,get-update.php脚本通过判断用户的cookie正确与否来决定是否更改用户信息,看来靠cookie来跟踪会话并控制业务逻辑是不太安全的,还有最严重的一点:get-update.php通过get请求来修改用户信息,这个是大忌。所以站点A可以接着升级防御:用session来代替cookie来跟踪用户会话信息,将修改用户信息的逻辑重写,只允许用post方法来请求用户信息。站点B同样可以升级攻击:curl可以构造post请求,劫持session等等,不过这些我还没研究过,后续再说吧。

ThinkPHP实现图片上传操作的方法详解 本文实例讲述了ThinkPHP实现图片上传操作的方法。分享给大家供大家参考,具体如下:直接上个例子,其中包括有单图片文件上传、多图片文件上传、以

ThinkPHP使用getlist方法实现数据搜索功能示例 本文实例讲述了ThinkPHP使用getlist方法实现数据搜索功能。分享给大家供大家参考,具体如下:自己在ThinkPHP之中的model之中书写getlist方法,其实所谓的搜

Win7环境下Apache连接MySQL提示连接已重置的解决办法 win7下手动搭建wamp环境,碰到的几个坑总结下:1.能正常访问php和html类型文件,但是访问项目文件时老是连接被重置,后来总结是数据库的问题,就写测

标签: php csrf攻击

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

上一篇:ThinkPHP框架实现数据增删改(thinkphp框架介绍)

下一篇:ThinkPHP实现图片上传操作的方法详解(thinkphp5教程)

  • 完全成本法税前利润计算例题
  • 民营医院一般纳税人帐务处理视频税收风险
  • 金税盘的作用是什么意思
  • 企业销售商品房需要缴纳什么税费
  • 向银行借款产生的利息
  • 包工包料怎么付款流程
  • 税控盘和税控钥匙一样吗
  • 个贷系统平账专户A户
  • 多余的实收资本可以转到其他应付款吗
  • 上市公司股价变动谁受益
  • 坏账的处理方法包括
  • 发票抬头开错重开怎么处理?
  • 新个税年终奖怎么申报
  • 会员卡 退
  • 车辆使用费怎么开票
  • 增值税设备抵扣怎么抵扣
  • 企业职工福利费扣除标准
  • 小微企业可以抵税吗
  • 建筑工程发票抵扣有时间限制吗
  • 本年利润年末账务处理
  • 环境保护税的申报期限是如何规定的
  • 应收账款产生的利息分录
  • Win10 LTSC 2021(长期服务频道)正式版发布: 附MSDN官方ISO纯净镜像下载
  • 本年利润贷方为正数
  • linux系统授权命令
  • 关于激活函数的说法错误的是
  • 车辆交通罚款怎样避免重复报销
  • 查补以前年度收入怎么做会计分录
  • vue可视化面板怎么打开
  • 一文读懂谢娜张杰购房跳单事件始末
  • 销售地下车库缴纳哪些税
  • 所有非批扣和所有批扣是什么意思
  • php序列化和反序列化函数
  • php源码封装
  • ps怎么选中图形放大
  • 金税盘税控盘和税务Ukey有什么区别
  • 微擎框架是开源的吗
  • 总公司所得税汇算
  • 一般纳税人接受的下列服务中不得抵扣进项税额的有
  • 长期股权投资处置损失计入什么科目
  • 非税收入票据存根的保存期限一般为多少年
  • 公司法人必须在公司名下缴纳社保吗
  • 怎么盘存货
  • 退差价后退货
  • 设备投入安装会计分录怎么写
  • 购进货物的发票确认定虚开,所得税处理
  • 企业会计档案由谁保管
  • 公司投资银行理财产品如何做账
  • sqlserver关键字附近有语法错误
  • sql server 2019自定义安装教程
  • mysql详细教程
  • 安装centos6.10
  • tabletpc输入面板怎么打开
  • 怎么把mac系统的文件导出
  • dns server配置
  • win8摄像头设置
  • centos6 centos7区别
  • init systemd
  • win10搜索功能不好用
  • iis的安全性设置主要包括
  • win7系统纯净版64位无法修改窗口颜色怎么办?Win7窗口颜色修改详细步骤
  • windows7 sp1升级包
  • Win10系统怎么截图快捷键
  • 更改uac设置在哪
  • cocos creator rpg
  • python第三方库在哪下载
  • linux shell中 if else以及大于、小于、等于逻辑表达式介绍
  • js模拟touch
  • python简明
  • javascriptz
  • unity3d怎么让物体依次运动
  • jqueryui dialog
  • jquery图片
  • android 屏幕适配方案
  • 税务案件移送案件的法律条款
  • 蚌埠城乡医保缴费查询
  • 江苏增值税电子专用发票可以抵扣吗
  • 在本地买车怎么上外地牌照
  • 企业内部清欠的措施和做法
  • 领完发票后 怎么读取
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设