1. 启动在线靶场
登陆 在线靶场,启动S2-007
环境,等待环境启动之后,点击访问靶场按钮即可前往靶场环境。该环境来源于vulhub
和vulapps
data:image/s3,"s3://crabby-images/58a4c/58a4c0da003c96a1da82ebb9d2a9ac402ef199b5" alt=""
2. 查看检测结果
登陆洞态IAST
官方网站,查看漏洞检测结果
data:image/s3,"s3://crabby-images/c27ef/c27ef156ec087caec7d48e4b02359b1b9019d668" alt=""
data:image/s3,"s3://crabby-images/88003/88003025d2af25b61c68703fa8bdec9c7a0ad55d" alt=""
3. 进入搜索功能,分析完整的污点调用图
3.1 Source点
首先,在org.apache.struts2.dispatcher.Dispatcher.DefaultActionMapper#createContextMap()
方法中,调用Servlet
接口的getParameterMap
方法获取外部参数,形成初始污点,然后将Map对象放入struts2的上下文com.opensymphony.xwork2.ActionContext.parameters
中
data:image/s3,"s3://crabby-images/8e8e9/8e8e94ccc4f3f731263df8c685e8d0582cc7f963" alt=""
3.2 Propagator方法
经过一系列的处理,在com.opensymphony.xwork2.interceptor.ParametersInterceptor#doIntercept
方法中,调用this.retrieveParameters(ac)
方法获取参数,最终通过this.get("com.opensymphony.xwork2.ActionContext.parameters”)
方法通过struts2上下文获取参数,与初始污点关联起来;
初始污点在com.opensymphony.xwork2.interceptor.ParametersInterceptor#doIntercept
方法中通过setParameters
方法将参数传递至ParametersInterceptor
实例化对象中,最终在com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor#intercept
中调用org.apache.struts2.interceptor.StrutsConversionErrorInterceptor#getOverrideExpr
方法,经过字符串拼接,形成最终的ognl表达式,代码如下:
protected Object getOverrideExpr(ActionInvocation invocation, Object value) {
ValueStack stack = invocation.getStack();
String var4;
try {
stack.push(value);
var4 = "'" + stack.findValue("top", String.class) + "'";
} finally {
stack.pop();
}
return var4;
}
代码中字符串拼接对应JDK层StringBuilder
的一系列操作,如下图
data:image/s3,"s3://crabby-images/86a4d/86a4dfadbecc8ce23e98d4eb44c62c8d9ab9f1fe" alt=""
ognl表达式在com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor#intercept
方法中,被放入map
对象faike
中:fakie.put(propertyName, this.getOverrideExpr(invocation, value));
然后,设置fakie
对象到ExprOverrides
中
if (fakie != null) {
stack.getContext().put("original.property.override", fakie);
invocation.addPreResultListener(new PreResultListener() {
public void beforeResult(ActionInvocation invocation, String resultCode) {
Map<Object, Object> fakie = (Map)invocation.getInvocationContext().get("original.property.override");
if (fakie != null) {
invocation.getStack().setExprOverrides(fakie);
}
}
});
}
然后,在com.opensymphony.xwork2.ognl.OgnlValueStack#lookupForOverrides
方法中,将Ognl表达式读取出来
data:image/s3,"s3://crabby-images/61ab1/61ab1ddec89832b6be2602c882d8d1dfd82e10bc" alt=""
然后在com.opensymphony.xwork2.ognl.OgnlUtil#getValue
方法中,调用compile
方法,形成Ognl对象
public Object getValue(String name, Map<String, Object> context, Object root, Class resultType) throws OgnlException {
return Ognl.getValue(this.compile(name), context, root, resultType);
}
data:image/s3,"s3://crabby-images/55c73/55c734c60702fa8112e1b2fe052f6a4217c1e80b" alt=""
3.3 Sink方法
最后,在ognl.Ognl#getValue
方法中,使用Ognl表达式对象的getValue
方法获取Ognl表达式的值
data:image/s3,"s3://crabby-images/bcc28/bcc287bcd6b9fd77312ba085928104bf5fc2e056" alt=""
本文没有对完整的漏洞细节进行分析,大家可以根据这篇文章,在关键方法的位置设置debug,然后逐步分析,还原漏洞的形成过程。
账号申请
data:image/s3,"s3://crabby-images/0b6be/0b6be34ddb85d2c4dbbcffe7a0d6c2c1c6d076c3" alt=""
- 洞态IAST合作伙伴计划之整体开源联合开发,申请方式请扫描下方二维码
data:image/s3,"s3://crabby-images/ede2e/ede2e0797686c89b674f388ff71f20900c909e9b" alt=""
- 如需加入技术讨论群,扫描二维码添加微信并备注"洞态IAST-加群",工作人员将拉您进群
data:image/s3,"s3://crabby-images/09bee/09beeb03741da60adb53739cb9bf28cd05190323" alt=""
本文迁移自知识星球“火线Zone”