安全测试基础知识

常见安全问题

跨站脚本攻击XSS

跨站请求伪造攻击CSRF

前端Cookies安全性

点击劫持攻击

传输过程安全问题

用户密码安全问题

SQL注入攻击

 

XSS(Cross Site Scripting)跨站脚本攻击介绍

什么是XSS

web攻击的一种,通过对网页注入可执行代码(html代码或JS代码)成功被浏览器执行

实施XSS攻击具备的条件

  1. 需要向web页面能够注入恶意代码(输入框、url)
  2. 恶意代码能够被浏览器成功执行

XSS攻击原理

用户传入的数据被当做是程序,所以会执行程序

XSS能干嘛

  • 获取页面数据:通过document即可获取指定元素的值,如获取用户名称、手机号、住址等【偷取网站任意数据包括用户资料】
  • 获取cookies:通过document.cookies可以获取网站当前的所有cookies,盗取当前登录用户的登录态,从而冒充被盗用户登录网站甚至后台管理系统【偷取用户密码和登录态】
  • 劫持前端逻辑:可以修改某个操作的反馈内容,譬如点击某个按钮本来应该只提交一个请求,但通过XSS脚本可篡改该请求地址,然后用户提交的信息发送到攻击者封装的接口;或可改变用户跳转的页面【欺骗用户,流量劫持】
  • 发送请求:攻击者可以让用户在不知情的情况下发送某个请求收集用户信息

XSS攻击方式

  • 反射型XSS:用户访问一个被攻击者篡改后的链接时,被植入的脚本会被用户浏览器执行,也称非持久型因为是一次性,仅对当次的页面访问产生影响
  • 反射型XSS场景:带有XSS脚本的链接转成的短链;【在url后跟xss脚本】,网址跳转
  • 存储型XSS:包含XSS攻击脚本的内容会被存储到服务器端,也称持久型,用户读取到内容时会自动执行脚本
  • 存储型XSS场景:其他用户查看别人发布的留言、评论,管理员发布的公告,黑客发布的博客文章;反馈功能,投诉功能,聊天记录功能

XSS攻击注入点

  • HTML节点内容:动态生成,包含用户输入的内容,从而包含XSS脚本
  • HTML属性:像img的src、输入框的value等需要用户自行输入的地方
  • JS代码:某个JS代码需要用户传值进入
  • 富文本:富文本编辑框本身保存的内容就包含html标签,用户可输入XSS脚本

潜在注入点

判断输入点是否可以成功把数据注入到页面内容,对于提交数据内容但是不输出到页面的输入点是没有必要进行Fuzzing的,因为即使可以提交攻击代码,也不会产生XSS;

Fuzzing:模拟XSS攻击,模糊测试挖漏洞最常用的一种手段,不断尝试的过程

Payload:相当于测试用例

标签属性中: 如<a href="注入位置">test</a>,       Payload:"></a><script>alert(0)</script><a  href="
标签事件中: <img href="a.jpg" onload="注入位置">,   Payload:alert(0)

防御XSS攻击

  1. 浏览器自带防御,X-XSS-Protection,主要防御反射型XSS攻击,如参数出现在HTML内容和属性
  2. 对html内容进行转义,譬如将【<>】转义成&lt; &gt; 存入数据库时即转义,或显示时转义
  3. 对html属性中的双引号和单引号【"" ''】转义成&quto; &apos;
  4. CSP1(Content SecurityPolicy)内容安全策略,用于指定哪些内容可执行

 

CSRF(Cross Site Request Forgy)跨站请求伪造

通俗易懂的理解CSRF

  1. 用户访问的网站对恶意网站发出了一些请求,且这些请求是用户不知情的情况下完成的
  2. 攻击者盗用受信任用户的身份,以他的名义向第三方网站发送恶意请求,对于服务器来说这个请求时合法的

CSRF攻击原理

 

CSRF是如何攻击的?又如何防御

  1. 站点B向站点A发送请求
  2. 请求带站点Acookies
  3. 不访问站点A前端
  4. referer为站点B

CSRF攻击危害

  1. 利用用户登录态
  2. 用户不知情
  3. 完成业务请求(盗取用户资金、冒充用户发帖背锅)
  4. 造成蠕虫攻击
posted @ 2019-12-25 19:51  小菠萝测试笔记  阅读(3886)  评论(3编辑  收藏  举报