补充概念

AJAX(异步javascript和XML)

Asynchronous javascript and xml

是一个概念,而非一种新的编程语言,是一组现有技术的组合

通过客户端脚本动态更新页面部分内容,而非整个页面

降低带宽使用,提高速度

提升用户体验

后台异步访问

AJAX组件

Javascript:AJAX的核心组件,使用XMLHTTPRequest对象接口向服务器发起请求,接受并处理服务器响应数据

Dynamic HTML (DHTML)

早于AJAX出现,通过javascript、CSS等在客户端修改HTML页面element,缺点是完全依赖客户端代码修改页面,与服务器的交互由JavaScript applets完成,AJAX的XHR弥补了他的缺点(如:注册用户)

Document Object Model (DOM)

处理html、xml文档对象的框架,DHTML是一个浏览器,DOM作为其一个 实现的接口,定义和管理每个页面元素obj的Properties、method、event

基于AJAX的WEB应用工作流程

XMLHTTPRequest API创建对象xmlhttp进行访问

返回内容:Xml、json、html、文本、图片

多个异步请求独立通信,互不依赖

AJAX框架

JQuery

Dojo Toolkit

Google web toolkit (GWT)

Microsoft AJAX library

目前没有通用的AJAX安全最佳实践,其攻击面不为大多数人所知

AJAX的安全问题

多种技术混合,增加了攻击面,每个参数都可能形成独立的攻击过程

AJAX引擎是个全功能的脚本解释器,访问恶意站点可能后果严重,虽然浏览器有沙箱和SOP,但可被绕过

服务器、客户端代码结合使用产生混乱,服务器访问控制不当,将信息泄露

暴漏应用程序逻辑

AJAX对渗透测试的挑战【不可忽视】

异步请求数量多且隐蔽

触发AJAX请求的条件无规律

手动和截断代理爬网可能产生大量遗漏

AJAX爬网工具

ZAP

客户端代码审计  

源码  【不一定高效】

Firebug

WEB Service 

一种面向服务的架构 (service oriented architecture),便于不同系统集成共享数据和功能

尤其适合不想暴漏数据模型和程序逻辑而访问数据的场景

无页面,只是一个web接口,通过http协议

两种类型的WEB Service

Simple object access protocol (SOAP)

传统的WEB Service开发方法,xml是唯一的数据交换格式

要求安全性的应用更多采用

RESTful (Representational State Transfer architecture—REST)

目前更多被采用的轻量web service,JSON是首选数据交换格式

WEB Service安全考虑

  1. 使用API key或session token实现和跟踪身份认证
  2. 身份认证由服务器完成,而非客户端(因为客户端源码可查看)
  3. API key、用户名、Session token永远不要通过URL发送
  4. RESTful默认不提供任何安全机制,需要使用SSL/TLS保护传输数据安全
  5. SOAP提供强于HTTPS的WS-security机制
  6. 使用OAuth或HMAC进行身份验证,HMAC身份认证使用C/S共享的密钥加密API key
  7. RESTful应只允许身份认证用户使用PUT、DELETE方法
  8. 使用随机token防止CSRF攻击
  9. 对用户提交参数过滤,建议部署基于严格白名单的方法
  10. 报错信息消毒
  11. 直接对象引用应严格身份验证(电商公司以产品ID作为主索引)

小白日记54:kali渗透测试之Web渗透-补充概念(AJAX,WEB Service)的更多相关文章

  1. 第十二章 WEB渗透

    Web技术发展 • 静态WEB• 动态WEB • 应用程序 • 数据库 • 每个人看到的内容不同 • 根据用户输入返回不同结果 WEB攻击面• Network• OS• WEB Server• App ...

  2. 小白日记28:kali渗透测试之Web渗透-扫描工具-Nikto

    扫描工具-Nikto #WEB渗透 靶机:metasploitable 靶场:DVWA[默认账号/密码:admin/password] #新手先将DVWA的安全性,调到最低,可容易发现漏洞 侦察[减少 ...

  3. 小白日记30:kali渗透测试之Web渗透-扫描工具-Skipfish

    WEB渗透-skipfish Skipfish是一个命令行模式,以C语言编写的积极的Web应用程序的安全性侦察工具,没有代理模式. 它准备了一个互动为目标的网站的站点地图进行一个递归爬网和基于字典的探 ...

  4. 小白日记31:kali渗透测试之Web渗透-扫描工具-Arachni

    扫描工具-Arachni Kali中集成旧的arachni的阉割版,所以需要重新安装[在某些方面有其独特性,但不算很强大,有命令行和web两种使用方式][匿名者推荐] apt-get update h ...

  5. 小白日记27:kali渗透测试之Web渗透-Http协议基础,WEB

    Http协议基础 Web技术发展[http://www.cnblogs.com/ProgrammerGE/articles/1824657.html] 静态WEB[网页] 动态WEB 属于一种应用程序 ...

  6. 小白日记18:kali渗透测试之缓冲区溢出实例(二)--Linux,穿越火线1.9.0

    Linux系统下穿越火线-缓冲区溢出 原理:crossfire 1.9.0 版本接受入站 socket 连接时存在缓冲区溢出漏洞. 工具: 调试工具:edb: ###python在漏洞溢出方面的渗透测 ...

  7. 小白日记6:kali渗透测试之被动信息收集(五)-Recon-ng

    Recon-ng Recon-NG是由python编写的一个开源的Web侦查(信息收集)框架.Recon-ng框架是一个全特性的工具,使用它可以自动的收集信息和网络侦查.其命令格式与Metasploi ...

  8. 小白日记17:kali渗透测试之缓冲区溢出实例-windows,POP3,SLmail

    缓冲区溢出实例 缓冲区溢出原理:http://www.cnblogs.com/fanzhidongyzby/archive/2013/08/10/3250405.html 空间存储了用户程序的函数栈帧 ...

  9. 小白日记7:kali渗透测试之主动信息收集-发现(一)--二层发现:arping/shell脚本,Netdiscover,scapy

    主动信息收集 被动信息收集可能不准确,可以用主动信息收集验证   特点:直接与目标系统交互通信,无法避免留下访问痕迹 解决方法:1.使用受控的第三方电脑进行探测,使用代理 (做好被封杀的准备)   2 ...

随机推荐

  1. Azure进阶攻略 | 应用流畅运行杜绝超载,自有一套好方法

    世界上很多东西,无论交通工具.房屋建筑,甚至计算机程序,在容量方面都存在设计上的理论最大值. 比如火车,正常情况下是这样的.舒适地坐着,安静地读一本书,时不时抬头若有所思地远眺车窗外风景,满满的文艺范 ...

  2. vm中efi模式安装windows10

    选择dvd: 界面出现“Press any key to boot from CD or DVD”时,再迅速按下任意键就OK了.

  3. 安卓手机下载YouTube视频的3种方法

    作为全球最大的在线视频网站,YouTube上面的内容可真是应有尽有啊,从教学视频到个人手工艺品制作流程,从各种搞笑视频到电视连续集等等,包罗万象.如果你想下载YouTube视频到电脑上面的话,网上有很 ...

  4. 如何把某个网站的SSL Server certificate链导入到ABAP Netweaver系统里

    我们在用ABAP代码消费外网的url时会遇到一些异常,比如ICM_HTTP_SSL_PEER_CERT_UNTRUSTED,这是因为请求的url所在的网站的SSL Server certificate ...

  5. C++学习之继承中的成员访问控制

    由基类到派生类的过程中,在派生类里如何访问基类成员,以及派生类对象如何访问基类成员,是根据派生类在从基类派生时是以什么方式进行的派生:public.protect或者private.下面说一下在这三种 ...

  6. TeXstudio安装后提示no LaTeX distribution found on this system

    应该是设置一下用户变量,而非系统变量,用TeXLive 2015和MikTeX都不好使,最后设置了用户变量好使了 S:\TeX\MiKTeX 2.9\miktex\bin\x64\ 也是醉醉的 不过等 ...

  7. [转载]——Axure+SVN配置

    最近进行考试系统重构,一个小组十几个人,这么多人要同时搞需求画原型.这样原本的合作开发工具SVN已经不能满足现在的需求了,这是就找到了一个新的方法——Axure+SVN. 在SVN服务器端建立一个空的 ...

  8. php5.3 yum安装升级版本到 php5.6

    centOS系统下如何将php升级到5.6,之前通过yum来安装lamp环境,直接升级的话,提示没有更新包,也就是说默认情况下php5.3.3是最新   1.查看已经安装的php版本号 键入下面代码: ...

  9. 2018.7.30 Oracle的Blog数据库类型读取和存

    package com.lanqiao.shopping.test; import java.io.BufferedInputStream; import java.io.BufferedOutput ...

  10. OpenCV自带dnn的Example研究(5)— segmentation

    这个博客系列,简单来说,今天我们就是要研究 https://docs.opencv.org/master/examples.html下的 6个文件,看看在最新的OpenCV中,它们是如何发挥作用的. ...