AJAX代码复杂性及安全性简析

AJAX代码复杂性 一、多种语言和架构 客户端:vbscript,javascript 服务器端:java,c#,php,ruby on rails,python,perl 表现层:html css 转换语言:xml,xslt,SOAP 查询语言:SQL 二、javascript特性 1)解释型语言,每一次错误都是运行时错误。难重现,难定位 2)弱类型:对

AJAX代码复杂性

一、多种语言和架构

客户端:vbscript,javascript

服务器端:java,c#,php,ruby on rails,python,perl

表现层:html css

转换语言:xml,xslt,SOAP

查询语言:SQL

二、javascript特性

1)解释型语言,每一次错误都是运行时错误。难重现,难定位

2)弱类型:对变量不做检查,所有隐式声明的变量都会被认为是全局变量

三、异步性tt娱乐城 太阳娱乐城 博彩网 香港六和彩 股票t+0 股票t+0开户 3d开奖结果 百家乐 六合采资料 liuhecai

一个通过异步方式处理数据的应用程序会同时执行多个线程,要正确协调好这些线程非常困难。最常见的问题就是竞争条件:e.g.银行系统中的存取款功能,应用程序只有在很大的负载压力下才会暴露出线程方面的漏洞

AJAX应用程序的常见漏洞

1)像API一样的web应用程序,过度细化服务端API,使得攻击者有机会控制程序的流程(透明性)

2)API身份认证问题

3)与用户相关的敏感数据硬编码在代码中

4)在javascript中存储会话状态,例如存储在隐藏的表单域或者cookie中

5)包含在客户端的注释及文档

6)在客户端进行数据交换,将原始的数据转换为HTML代码,在许多情况下,返回的响应信息中包含的都是XML或者JSON格式的原始数据

AJAX透明性,可以通过代码混淆来隐藏应用程序逻辑的很好办法。

劫持AJAX应用程序

JavaScript的动态特性使得其他JavaScript程序可以自动修改某个AJAX应用程序的源代码。方法冲突(在同一个作用域内,最后声明的同名方法会默认覆盖掉之前的方法声明)不仅可以用来重写某个方法的实现,还可以被动监视程序中的数据流向。任何人都可以对客户端代码进行反向工程分析,即使它是一部分一部分动态加载的。由某个用户定义的方法不仅能覆盖其他用户定义的方法,还可以覆盖像window.alert()这样的内置方法,甚至是原生的对象构造方法。这使得攻击者可以实现JSON劫持攻击,窃取由AJAX返回的JSON内容。

(责任编辑:adminadmin2008)

顶一下
(1)
100%
踩一下
(0)
0%
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片
图片资讯

针锋相对 四招防御APT攻击

针锋相对 四招防御APT攻击

APT即“Adavanced Persistent Threat”,是指针对明确目标的持续的、复杂的网络攻击。...[详细]

浏览器必备的五大安全附加组件

浏览器必备的五大安全附加组件

随着云计算和基于Web的业务应用程序的兴起,尽可能的保证浏览器安全已成为关键。并非...[详细]

未来无线路由需要改进的地方

未来无线路由需要改进的地方

对于一般人来说,现有无线路由器的主要目是让手机和平板等设备连上网络,方便自己在特...[详细]

怎样在不同网络安全需求下创建DMZ区

怎样在不同网络安全需求下创建DMZ区

安全区的定义在建立安全网络过程中起着至关重要的作用。DMZ (Demilitarized Zone)是网...[详细]

教你如何利用Wireshark监测无线网络

教你如何利用Wireshark监测无线网络

计算机安全始终是一个让人揪心的问题,网络安全则有过之而无不及。无线网络是黑客们最...[详细]