前端时间有幸参与到Rasp技术相关的项目中,正好要告一段落,因此今天来科普下这种技术形式与具体应用。

(一)Java Instrumentation介绍

Java Instrumentation是从JavaSE 5开始提供的新特性,用于构建独立于java应用的agent程序,主要目的是对JVM上的应用进行监控,比如性能优化监控等等。

通过这个特性,我们可以实现在不修改JVM源码的基础上操控字节码,这也就可以实现一种虚拟机级别的AOP机制,这和Spring中的基于动态代理实现的AOP机制是有所不同的,前者更加轻量化,与项目的耦合性更低。

JavaSE 6中,Instrumentation的功能更加强大,甚至可以对原生代码(Native code)进行修改。

(二)Java Agent示例代码

在Instrumentation的基础上我们可以实现一个Java agent程序,实现Hook机制。

首先来说一下我们的需求,看下面的这段示例代码:

我们要做的是对这里的say方法进行hook。

(1)首先,新建一个maven工程,并添加resources/META-INF/MANIFEST.MF文件:右键项目-> Properties-> Java Build path -> Add Folder

(2)编写Agent类,实现premain方法:

Premain方法只做一件事情,就是设置一个ClassFileTransform,用来获取和操作字节码。

(3)TestTransform的实现如下:

首先在pom.xml中引入asm依赖,这个库用来插入字节码:

<dependency><groupId>org.ow2.asm</groupId><artifactId>asm-all</artifactId><version>5.1</version>
</dependency>

Java代码:

package agenttest.AgentTest;
import java.lang.instrument.ClassFileTransformer;
import java.lang.instrument.IllegalClassFormatException;
import java.security.ProtectionDomain;import org.objectweb.asm.ClassReader;
import org.objectweb.asm.ClassWriter;public class TestTransform implements ClassFileTransformer{public byte[] transform(ClassLoader loader, String className, Class<?> classBeingRedefined,ProtectionDomain protectionDomain, byte[] classfileBuffer) throws IllegalClassFormatException {ClassReader classReader = new ClassReader(classfileBuffer) ;ClassWriter classWriter = new ClassWriter(ClassWriter.COMPUTE_FRAMES) ;classReader.accept(new MyClassVisitor(classWriter), 0);byte[] bytes = classWriter.toByteArray();return bytes;}
}

我们在MyClassVisitor里来实现修改字节码的操作。

(4)实现MyClassVisitor,继承ClassVisitor类。

package agenttest.AgentTest;import org.objectweb.asm.ClassVisitor;
import org.objectweb.asm.MethodVisitor;
import org.objectweb.asm.Opcodes;public class MyClassVisitor extends ClassVisitor{public MyClassVisitor(ClassVisitor cv) {super(Opcodes.ASM5, cv);}@Overridepublic MethodVisitor visitMethod(int access, String name, String desc, String signature, String[] exceptions) {if ("say".equals(name)) {MethodVisitor methodVisitor = cv.visitMethod(access, name, desc, signature, exceptions) ;methodVisitor.visitCode();methodVisitor.visitFieldInsn(Opcodes.GETSTATIC, "java/lang/System", "out", "Ljava/io/PrintStream;");methodVisitor.visitLdcInsn("CALL " + name);methodVisitor.visitMethodInsn(Opcodes.INVOKEVIRTUAL, "java/io/PrintStream", "println", "(Ljava/lang/String;)V", false);methodVisitor.visitEnd();return methodVisitor ;}return super.visitMethod(access, name, desc, signature, exceptions);}}

在上面的代码中,重写visitMethod方法,然后判断方法名为say的情况。这里的具体操作可以阅读asm5的相关文档。

(5)编写resources/META-INF/MANIFEST.MF文件,指定premain类:

Manifest-Version: 1.0
Premain-Class: agenttest.AgentTest.AgentMain
Built-By: chongrui
Build-Jdk: 1.8.0_111
Created-By: Maven Integration for Eclipse

(6)在pom中添加打包所需项

<build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><source>1.8</source><target>1.8</target></configuration></plugin><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-source-plugin</artifactId><version>3.0.1</version><executions><execution><id>attach-sources</id><phase>verify</phase><goals><goal>jar-no-fork</goal></goals></execution></executions></plugin><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-assembly-plugin</artifactId><version>2.6</version><configuration><descriptorRefs><descriptorRef>jar-with-dependencies</descriptorRef></descriptorRefs><archive><manifestFile>resources/META-INF/MANIFEST.MF</manifestFile></archive></configuration><executions><execution><id>assemble-all</id><phase>package</phase><goals><goal>single</goal></goals></execution></executions></plugin></plugins><resources><resource><directory>${basedir}/resources</directory></resource><resource><directory>${basedir}/src/main/java</directory></resource></resources></build>

(7)eclipse下编译为jar包

(8)实验

单独执行Test.java.输出say Hello。

设置了agent.jar之后,执行java应用的命令用-javaagent:path选项来指定agent。

可以看到会把CALL say输出出来,而且发生在调用say方法之前输出:

(三)Java Rasp技术

Java Rasp技术原理大致如下图:

PS. 这个图片来自于引用的其他文献。

我们可以看到,RASP进程是直接嵌入到APP执行流程中去,这一点和WAF有本质的不同。正是由于这一点,RASP可以避免WAF规则被各种奇异的编码绕过的痛点,因为Agent进程最终获取的参数正是各个层面编码转换完成后真正执行的参数。并且RASP不像WAF那样需要拦截每个请求去check是否命中了攻击的规则,而是当HOOK住的危险函数被调用之后,才会触发检测逻辑。

大致说一下Rasp Agent的实现方法,首先,我们可以在Transform类中注册很多CodeFileVisitor,比如每个漏洞类型编写一个Visitor,其实这里asm提供的这个Visitor是个基于事件模型的处理类,编写起代码来和XML的事件解析差不多。在这些Visitor中我们就可以只监控我们关心的一些危险函数,比如JDBC的execSQL函数,利用asm编程获取到调用这个函数时的具体参数,然后编写我们的规则来判定是否存在漏洞,如果存在漏洞就根据配置进行上报、阻断动作就行了。

在部署时,Agent程序可以通过嵌入到Java中间件启动脚本中与其进行整合。举个例子,在tomcat启动脚本catalina.sh中,我们可以修改JAVA_OPTS变量来设置为javaagent方式进行启动。

(四)总结

Rasp技术的本质就是如何实现这样一个HOOK动作的agent。各个语言的实现都不同,比如PHP和Java的机制就不同,PHP是通过编写PHP扩展的形式进行HOOK与漏洞判断、上报。但是漏洞判定规则是通用的,因此这部分完全可以做成通用的服务运行。

Rasp技术虽然好用,但是令人诟病的是对源程序本身的性能影响,当并发一旦增大,漏洞判定逻辑势必会拖慢程序本身的运行速度。因此,除非有很强大的魄力与上层的支持,否则一般大公司业务线都不会为了安全需求来轻易接受这种性能的影响,毕竟性能、稳定性考虑是算在KPI里的。最好的应用场景是在中小型企业部署,效果应该会很明显。

参考文献

https://liuzhengyang.github.io/2017/03/15/javaagent/

http://paper.seebug.org/330/

Java Rasp技术浅析相关推荐

  1. java 声音技术浅析

    java 声音技术浅析 java 的魅力之一就是对多媒体的支持,Appley使得原来沉闷的网页变得 丰富起来,在java.applet中提供了很多功能强大的方法对多媒体的支 持.现在我们就java中的 ...

  2. 深入分析Java Web技术内幕读书笔记(二)浅析DNS域名解析过程

    上一篇文章<浅析Web请求过程>讲述的是如何发起HTTP请求,对于请求发起过程中很重要的一个步骤--DNS解析过程的描述是一带而过,本篇文章将跟着DNS解析过程来分析域名是如何解析的. 一 ...

  3. 深入分析Java Web技术内幕读书笔记(一)浅析Web请求过程

    随着Web技术的快速发展,互联网的网络架构已经从传统的C/S架构转变为B/S架构,B/S架构相较于传统的C/S架构,有诸多优点,例如:提供了统一的操作方式,简化了用户的学习成本:便捷的开发方式大大提高 ...

  4. 基础网络爬虫(Web crawler)相关技术浅析

    文章目录 前言 基本概念 Robots协议 基本原理 现状概况 爬虫软件 跨语言 Selenium Python urllib requests Scrapy Pyspider Java WebMag ...

  5. RASP技术攻防之基础篇

    本文就笔者研究RASP的过程进行了一些概述,技术干货略少,偏向于普及RASP技术.中间对java如何实现rasp技术进行了简单的举例,想对大家起到抛砖引玉的作用,可以让大家更好的了解一些关于web应用 ...

  6. 云原生安全之RASP技术(应用运行时自我保护)

    文章目录 一.背景 1. WAF和RASP 2. waf和rasp是非此即彼的吗? 二.RASP技术(应用运行时自我保护) 1. 应用安全测试SAST.IAST.DAST 和 RASP区别 SAST, ...

  7. rasp 系统_Java RASP技术详细介绍及应用「附RASP参考资料」

    . 0x01 什么是 RASP ? . RASP,即Runtime Application SelfProtection,实时 应用自我保护. RASP实现原理示意图 . 0x02 RASP的实现方案 ...

  8. rasp 系统_浅谈RASP技术攻防之基础篇

    引言 本文就笔者研究RASP的过程进行了一些概述,技术干货略少,偏向于普及RASP技术.中间对java如何实现rasp技术进行了简单的举例,想对大家起到抛砖引玉的作用,可以让大家更好的了解一些关于we ...

  9. 硬核干货合集!500+篇Java干货技术文章整理|资源|书单|工具|面试指南|强烈建议打开!

    今天给大家推荐一位在阿里做Java的朋友给大家,他是公众号[程序员书单]的作者黄小斜. 他的公众号[程序员书单]这两年来累积了200多篇优质原创文章,独家原创的系列文章有<五分钟学编程>系 ...

最新文章

  1. ElasticSearch(六) Update API
  2. IntelliJ IDEA中JAVA连接MYSQL
  3. python画相关性可视化图上三角_完成这50个Matplotlib代码,你也能画出优秀的图表...
  4. Jmeter初学(一)
  5. OpenCV实现Mat与vector,Mat与数组互转
  6. PHP面向对象(OOP)----分页类
  7. python元组取值_Python基础之元组
  8. SpringMVC注解 @initbinder 解决类型转换问题
  9. linux 7防火墙删除端口号,centos 7 firewall(防火墙)开放端口/删除端口/查看端口
  10. prometheus监控redis(无metric接口)
  11. [转载] Python算法
  12. ubuntu 14.04 下hadoop2.9.1 64位编译
  13. zabbix mysql默认模板_zabbix默认自带对Mysql数据库监控模板
  14. 轻量级日志收集转发 | fluent-bit指令详解(一)
  15. python安装pygame教程_python-pygame安装教程
  16. 完美解决Win11无法启动安全中心
  17. puppeteer 初步实战 测试
  18. 8.9.2 疯狂填词
  19. 做QQ群霸屏的,我们盯上你了
  20. UE4VR学习笔记3

热门文章

  1. 初学者基于paddle的计算机视觉快速上手项目
  2. java编程实现;猜单词游戏
  3. pytorch 目标检测数据增强 详细讲解
  4. ImproperlyConfigured: mysqlclient 1.4.0 or newer is required; you have 0.10.1.
  5. 《DEEP GRADIENT COMPRESSION:REDUCING THE COMMUNICATION BANDWIDTH FOR DISTRIBUTED TRAINING》精读
  6. baidu patchrom项目 make后刷机包脚本多一个0解决
  7. JAVA程序设计题——英雄对战游戏,定义一个描述战斗单位的英雄(Hero)类,此类必须包含以下成员变量:名称(name),生命值(life),技能1攻击力(damage1),防御力(defence)
  8. 【Python入门】:字典与集合
  9. nodejs中hapi/joi 被弃用
  10. 计算机相关期刊阅读,计算机领域的所有SCI一区期刊,这是最顶级期刊了.doc