一、SQL注入攻击(SQL Injection)

攻击者把SQL命令插入到Web表单的输入域或页面请求的字符串,欺骗服务器执行恶意的SQL命令。在某些表单中,用户输入的内容直接用来构造(或者影响)动态SQL命令,或作为存储过程的输入参数,这类表单特别容易受到SQL注入式攻击。常见的SQL注入式攻击过程类如: 1.某个Web应用有一个登录页面,这个登录页面控制着用户是否有权访问应用,它要求用户输入一个名称和密码; 2.登录页面中输入的内容将直接用来构造动态的SQL命令,或者直接用作存储过程的参数; 例如:

$query = 'SELECT * from Users WHERE login = ' . $username . ' AND password = ' . $password;

3.攻击者在用户名字和密码输入框中输入'或'1'='1之类的内容; 4.用户输入的内容提交给服务器之后,服务器运行上面的代码构造出查询用户的SQL命令,但由于攻击者输入的内容非常特殊,所以最后得到的SQL命令变成:

SELECT * from Users WHERE login = '' or '1'='1' AND password = '' or '1'='1';

5.服务器执行查询或存储过程,将用户输入的身份信息和服务器中保存的身份信息进行对比; 6.由于SQL命令实际上已被注入式攻击修改,已经不能真正验证用户身份,所以系统会错误地授权给攻击者。 如果攻击者知道应用会将表单中输入的内容直接用于验证身份的查询,他就会尝试输入某些特殊的SQL字符串篡改查询改变其原来的功能,欺骗系统授予访问权限。 系统环境不同,攻击者可能造成的损害也不同,这主要由应用访问数据库的安全权限决定。如果用户的帐户具有管理员或其他比较高级的权限,攻击者就可能对数据库的表执行各种他想要做的操作,包括添加、删除或更新数据,甚至可能直接删除表 防范方法: 1.检查变量数据类型和格式 2.过滤特殊符号 3.绑定变量,使用预编译语句

二、跨网站脚本攻击(Cross Site Scripting, XSS)

攻击者将恶意代码注入到网页上,其他用户在加载网页时就会执行代码,攻击者可能得到包括但不限于更高的权限(如执行一些操作)、私密网页内容、会话和cookie等各种内容。这些恶意代码通常是JavaScript、HTML以及其他客户端脚本语言。 例如:

<?php
echo "欢迎您,".$_GET['name'];

如果传入一段脚本<script>[code]</script>,那么脚本也会执行。用这样的URL将会执行JavaScript的alert函数弹出一个对话框:http://localhost/test.php?name=<script>alert(123456)</script> 常用的攻击手段有: 盗用cookie,获取敏感信息; 利用iframe、frame、XMLHttpRequest或上述Flash等方式,以(被攻击)用户的身份执行一些管理动作,或执行一些一般的如发微博、加好友、发私信等操作; 利用可被攻击的域受到其他域信任的特点,以受信任来源的身份请求一些平时不允许的操作,如进行不当的投票活动; 在访问量极大的一些页面上的XSS可以攻击一些小型网站,实现DDoS攻击的效果。 防范方法:使用htmlspecialchars函数将特殊字符转换成HTML编码,过滤输出的变量

三、跨网站请求伪造攻击(Cross Site Request Forgeries, CSRF)

攻击者伪造目标用户的HTTP请求,然后此请求发送到有CSRF漏洞的网站,网站执行此请求后,引发跨站请求伪造攻击。攻击者利用隐蔽的HTTP连接,让目标用户在不注意的情况下单击这个链接,由于是用户自己点击的,而他又是合法用户拥有合法权限,所以目标用户能够在网站内执行特定的HTTP链接,从而达到攻击者的目的。 它与XSS的攻击方法不同,XSS利用漏洞影响站点内的用户,攻击目标是同一站点内的用户者,而CSRF 通过伪装成受害用户发送恶意请求来影响Web系统中受害用户的利益。 例如: 某个购物网站购买商品时,采用http://www.shop.com/buy.php?item=watch&num=100,item参数确定要购买什么物品,num参数确定要购买数量,如果攻击者以隐藏的方式发送给目标用户链接 ,那么如果目标用户不小心访问以后,购买的数量就成了100个 防范方法: 1、检查网页的来源 2、检查内置的隐藏变量 3、使用POST,不要使用GET,处理变量也不要直接使用$_REQUEST

四、Session固定攻击(Session Fixation)

这种攻击方式的核心要点就是让合法用户使用攻击者预先设定的session id来访问被攻击的应用程序,一旦用户的会话ID被成功固定,攻击者就可以通过此session id来冒充用户访问应用程序。 例如: 1.攻击者访问网站http:///www.bank.com,获取他自己的session id,如:SID=123; 2.攻击者给目标用户发送链接,并带上自己的session id,如:http:///www.bank.com/?SID=123; 3.目标用户点击了http:///www.bank.com/?SID=123,像往常一样,输入自己的用户名、密码登录到网站; 4.由于服务器的session id不改变,现在攻击者点击http:///www.bank.com/?SID=123,他就拥有了目标用户的身份,可以为所欲为了。 防范方法: 1.定期更改session id

session_regenerate_id(TRUE);//删除旧的session文件,每次都会产生一个新的session id。默认false,保留旧的session

2.更改session的名称 session的默认名称是PHPSESSID,此变量会保存在cookie中,如果攻击者不抓包分析,就不能猜到这个名称,阻挡部分攻击

session_name("mysessionid");

3.关闭透明化session id 透明化session id指当浏览器中的http请求没有使用cookie来制定session id时,sessioin id使用链接来传递

int_set("session.use_trans_sid", 0);

4.只从cookie检查session id

int_set("session.use_cookies", 1);//表示使用cookies存放session id
int_set("session.use_only_cookies", 1);//表示只使用cookies存放session id

5.使用URL传递隐藏参数

$sid = md5(uniqid(rand()), TRUE)); $_SESSION["sid"] = $sid;//攻击者虽然能获取session数据,但是无法得知$sid的值,只要检查sid的值,就可以确认当前页面是否是web程序自己调用的

五、Session劫持攻击(Session Hijacking)

会话劫持是指攻击者利用各种手段来获取目标用户的session id。一旦获取到session id,那么攻击者可以利用目标用户的身份来登录网站,获取目标用户的操作权限。 攻击者获取目标用户session id的方法: 1.暴力破解:尝试各种session id,直到破解为止; 2.计算:如果session id使用非随机的方式产生,那么就有可能计算出来; 3.窃取:使用网络截获,xss攻击等方法获得 防范方法: 1.定期更改session id 2.更改session的名称 3.关闭透明化session id 4.设置HttpOnly。通过设置Cookie的HttpOnly为true,可以防止客户端脚本访问这个Cookie,从而有效的防止XSS攻击。

六、文件上传漏洞攻击(File Upload Attack)

文件上传漏洞指攻击者利用程序缺陷绕过系统对文件的验证与处理策略将恶意代码上传到服务器并获得执行服务器端命令的能力。 常用的攻击手段有: 上传Web脚本代码,Web容器解释执行上传的恶意脚本; 上传Flash跨域策略文件crossdomain.xml,修改访问权限(其他策略文件利用方式类似); 上传病毒、木马文件,诱骗用户和管理员下载执行; 上传包含脚本的图片,某些浏览器的低级版本会执行该脚本,用于钓鱼和欺诈。 总的来说,利用的上传文件要么具备可执行能力(恶意代码),要么具备影响服务器行为的能力(配置文件)。 防范方法: 1.文件上传的目录设置为不可执行; 2.判断文件类型,设置白名单。对于图片的处理,可以使用压缩函数或者resize函数,在处理图片的同时破坏图片中可能包含的HTML代码; 3.使用随机数改写文件名和文件路径:一个是上传后无法访问;再来就是像shell.php.rar.rar和crossdomain.xml这种文件,都将因为重命名而无法攻击; 4.单独设置文件服务器的域名:由于浏览器同源策略的关系,一系列客户端攻击将失效,比如上传crossdomain.xml、上传包含Javascript的XSS利用等问题将得到解决。
参考资料: http://os.51cto.com/art/201204/328938.htm https://www.zhihu.com/question/22953267 http://wt7315.blog.51cto.com/10319657/1865580 http://www.plhwin.com/2014/06/13/web-security-sql/

  • 作者:成九
  • 出处:https://luyucheng.cnblogs.com
  • 若无特别说明均为原创作品,如需转载请注明原文链接

转载于:https://www.cnblogs.com/chun6/p/6235059.html

PHP安全之Web攻击相关推荐

  1. 实战:一次失败的WEB攻击试验,欢迎高手补充

    2019独角兽企业重金招聘Python工程师标准>>> 首先声明:这个文章我描述的是一次比较失败的WEB攻击试验,理论基础是一次在网上看到的一篇关于"慢攻击"的概 ...

  2. WEB攻击手段及防御第1篇-XSS

    概念 XSS全称为Cross Site Script,即跨站点脚本攻击,XSS攻击是最为普遍且中招率最多的web攻击方式,一般攻击者通过在网页恶意植入攻击脚本来篡改网页,在用户浏览网页时就能执行恶意的 ...

  3. 【技术干货】浏览器工作原理和常见WEB攻击 (下)

    本文作者:上海驻云开发总监 陈昂 上篇给大家带来的是关于浏览器基本工作原理的总结和介绍,这篇文章重点给大家说明有哪些常见WEB攻击. 常见WEB攻击 互联网是个面向全世界的开放平台,越是开放的东西漏洞 ...

  4. 几种常见的Web攻击

    几种常见的Web攻击 文章目录 几种常见的Web攻击 一.DoS攻击 1.SYN洪水攻击 2.IP欺骗 3.Land攻击 4.针对DoS攻击的防御 二.CSRF攻击 1. CSRF攻击的发生有三个必要 ...

  5. WEB攻击手段及防御-扩展篇

    转载自 WEB攻击手段及防御-扩展篇 之前的文章介绍了常见的XSS攻击.SQL注入.CSRF攻击等攻击方式和防御手段,没有看的去翻看之前的文章,这些都是针对代码或系统本身发生的攻击,另外还有一些攻击方 ...

  6. Web 攻击越发复杂,如何保证云上业务高可用性的同时系统不被入侵?| 专家谈...

    如今,电子政务.电子商务.网上银行.网上营业厅等依托Web应用,为广大用户提供灵活多样的服务.在这之中,流量攻击堪称是Web应用的最大敌人,黑客通过流量攻击获取利益.竞争对手雇佣黑客发起恶意攻击.不法 ...

  7. 常见的web攻击手段

    整理自网上关于web攻击的热门文章. (一)跨站脚本攻击 跨站脚本攻击(Cross-Site Scripting,XSS)是指通过存在安全漏洞的web网站注册用户的浏览器内运行非法的HTML标签或Ja ...

  8. 第四章(1.2)机器学习——在web攻击检测中的应用实践

    一.背景 通俗地讲,任何一个的机器学习问题都可以等价于一个寻找合适变换函数的问题.例如语音识别,就是在求取合适的变换函数,将输入的一维时序语音信号变换到语义空间:而近来引发全民关注的围棋人工智能Alp ...

  9. HTTP通信安全和Web攻击技术

    HTTP通信安全和Web攻击技术 一.HTTPS,确保Web安全 1.1 通信使用明文可能会被窃听 1.1.1 通信的加密(建立安全通信线路) 1.1.2 内容的加密 1.2 不验证通信方的身份就可能 ...

  10. 前端学HTTP之web攻击技术

    前端学HTTP之web攻击技术 前面的话 简单的HTTP协议本身并不存在安全性问题,因此协议本身几乎不会成为攻击的对象.应用HTTP协议的服务器和客户端,以及运行在服务器上的Web应用等资源才是攻击目 ...

最新文章

  1. Android开发实践:如何设置NDK的编译选项
  2. 武汉python培训哪一家好一些-武汉哪个Python培训机构比较好?
  3. Adams中的阻尼比样条设置
  4. UVA 1451 Average 数形结合
  5. 原生js设置div隐藏或者显示_10种JS控制DIV的显示隐藏代码
  6. 软件oem要注意什么_英语配音学习要注意什么?配音的注意事项有什么?
  7. 微信支付curl: (60) SSL certificate problem: unable to get local issuer certificate 解决方法
  8. mangos代码阅读
  9. JAVA操作文件大全(二)
  10. spring 容器的 profile 功能
  11. iOS - JSON 数据解析
  12. JavaScript 运输公司计算运费,路程越远,运费的折扣越高
  13. Fiori 磁贴配置
  14. Linaro交叉编译链配置
  15. Android调用第三方App Activity
  16. 如何通过8051单片机与片外存储器的连接来解决8051片内RAM和ROM容量不够用的问题
  17. String 字符串之截取
  18. 雷军:小米如何成功逆转
  19. 方正证券国产CPU行业深度报告
  20. zip压缩和unzip解压

热门文章

  1. linux系统给串口权限,让ubuntu串口和USB设备不用root权限访问
  2. poj 3280 区间dp
  3. jquery内容选择器
  4. 贪心法——LeetCode Assign Cookies分饼干
  5. 吴恩达神经网络和深度学习-学习笔记-39-计算机视觉现状
  6. grafana设置mysql为数据源,并进行可视化
  7. python网络爬虫系列教程——python中lxml库应用全解(xpath表达式)
  8. c#实现文件批处理:剪切、复制、删除、改名、分类等
  9. MOV AH,XXH INT XXH——BIOS中断和DOS中断
  10. MySQL设置默认编码