跳转至

常见逻辑漏洞

挖掘重点:

业务流程和HTTP/HTTPS请求篡改

支付漏洞和越权漏洞是金融业务中常见的

支付漏洞

(1) 密码重置

验证码直接在HTTP响应中返回;

验证码未绑定用户,没和手机号和邮箱号做匹配验证;

未校验用户字段值,改自己密码,最后提交其它UID;

验证码不失效,可枚举;

(2) 支付订单

篡改支付金额,运费修改为负数,使总金额降低。

(3) 竞争条件

在文件上传中和购物时;

A用户余额10元,B商品5元,C商品6元;

A利用竞争条件多线程同时发起购买B和C的请求;

可能的结果有:

有一件商品购买失败;

商品都购买成功,但只扣了6元;

商品都购买成功,但余额为 -1元;

越权访问

越权访问他人信息或操纵他人账号

水平越权:

同级别(权限)用户之间,越权访问非法操纵其它账户;(这会导致大批量数据泄露,恶意篡改)

垂直越权:

不同级别之间的用户越权,普通用户执行管理员的功能;

越权访问攻击测试:

1、改ID; ?id=1
2、改用户名;login.php?username=admin

越权访问修复建议:

越权访问漏洞的主要原因是没有对用户的身份做判断和控制,防护这种漏洞可以通过session来控制。

用户登录成功后,把username和UID等信息写入到session中,

当查看个人信息时,从session中取出username,而不是从GET和POST取,此时username就是没被篡改的。

会话劫持

会话劫持(Session hijacking),这是一种通过获取用户 Session ID 后,使用该 Session ID 登录目标账号的攻击方法,此时攻击者实际上是使用了目标会话固定漏洞基本防御方法 账户的有效 Session。

会话劫持的第一步是取得一个合法的会话标识来伪装成合法用户,因此需要保证会话标识不被泄漏。


受害者登录站点,服务器返回一个会话标识(Session ID)

黑客捕获这个Session ID( 网络嗅探,XSS ),使用这个Session ID访问站点获得受害者合法会话

防御方法

XSS漏洞引起的会话劫持:使用http-only来防止JS获取cookie中的Session ID信息

网络嗅探引起的会话劫持:使用HTTPS+secure来保证Session ID不被嗅探获取到

Session机制

Session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构来保存信息用于保持状态。

保存这个Session ID最为方便的方式是采用Cookie。

Cookie的名字都是类似于SESSIONID;

weblogic对于web应用程序生成的cookie,JSESSIONID;

PHP中Session的默认名称是PHPSESSID。

HttpOnly 设置方法

服务端发送cookie的时候,可以设置HTTP-Only ,禁止 JS 获取Cookie内容

Set-Cookie: SESSIONID=abc123; expires=Wednesday, 17-Nov-99 23:12:40 GMT; HttpOnly

Secure

设置cookie的某个值secure为True时, 此cookie只有在HTTPS协议中才会进行传输

HTTP协议传输时,是不传输此协议的。

会话固定

会话固定(Session fixation)是一种诱骗受害者使用攻击者指定的会话标识(Session ID)的攻击手段。这是攻击者获取合法会话标识的最简单的方法。会话固定也可以看成是会话劫持的一种类型,原因是会话固定的攻击的主要目的同样是获得目标用户的合法会话。不过会话固定还可以是强迫受害者使用攻击者设定的一个有效会话,以此来获得用户的敏感信息。

  • 访问网站时,网站会设置cookie中的Session ID
  • 当用户登录后,cookie中的SessionID保持不变形成原因
  • 只要获取登陆前的Session ID内容,就可以知道登陆后的Session ID
  • 黑客用该Session ID构造链接,发送给受害者点击后,黑客成功劫持受害者的会话

漏洞检测

访问网站(未登录):获取cookie信息,获取Session ID

登录网站:查看Cookie信息,获取Session ID

查看登录前,登录后SessionID是否相同

防御方法

1、在用户登录成功后重新创建一个Session ID,使登录前的匿名会话强制失效

// 会话失效
session.invalidate();

// 会话重建
session=request.getSession(true);

2、SessionID与浏览器绑定:SessionID与所访问浏览器有变化,立即重置

3、SessionID与所访问的IP绑定:SessionID与所访问IP有变化,立即重置