首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java RMI 远程代码执行漏洞

0x01 漏洞描述 - Java RMI 远程代码执行 - Java RMI服务是远程方法调用,是J2SE的一部分,能够让程序员开发出基于JAVA的分布式应用。...一个RMI对象是一个远程Java对象,可以从另一个Java虚拟机上(甚至跨过网络)调用它的方法,可以像调用本地JAVA对象的方法一样调用远程对象的方法,使分布在不同的JVM中的对象的外表和行为都像本地对象一样...在RMI的通信过程中,默认使用序列化来完成所有的交互,如果该服务器Java RMI端口(默认端口1099)对公网开放,且使用了存在漏洞的Apache Commons Collections版本,就可以在该服务器上执行相关命令...syn-ack ttl 64 Java RMI 输入目标地址端口,使用工具远程执行系统命令。...工具链接: https://pan.baidu.com/s/1i4gatlzs9mAoCocyAmnHNw 提取码: 35cs 上述利用工具不支持多命令拼接执行,可以在vps上设置好监听地址后,使用如下方法反弹

2.1K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Saltstack远程执行

    Saltstack的远程执行概念 远程执行是Saltstack的核心功能之一。主要使用Salt模块批量给选定的minion端执行相应的命令,并获得返回结果。...自带的一个命令 * :表示目标主机,这里表示所有目标主机 test.ping:test是saltstack中的一个模块,ping则是这个模块下面的一个方法 举例:2:saltstack使用cmd.run模块远程执行...arguments] image.png 目标主机target匹配方式: 与minionID有关的采用,通配符、列表和正则; 与minionID无关的采用,IP、复合、分组、Grains、Pillar 远程执行常用模块...Centos' test.ping [root@Saltstack01 /]# salt -G'localhost:Saltstack02' test.ping image.png 4.Salt命令的远程执行常用模块...salt'*'user.add name image.png 4.3 cmd模块  功能:实现远程的命令行调用执行,可以使用shell

    68120

    「小程序JAVA实战」 小程序远程调试(九)

    在开发javaweb应用的时候,如果遇见一个问题都会调试,debug,在火狐和谷歌浏览器的时候我们也可以使用断点的方式调试js,小程序可以吗?肯定是可以的!小程序的调试也可以在手机端进行远程调试。...源码:https://github.com/limingios/wxProgram.git 中的No.4 开始演示 登录微信小程序,获取appId,远程调试必须有AppID ?...了解功能按键 预览:手机可以通过扫描二维码的方式在手机上直接观看小程序 远程调试:可以在手机上进行操作,并且可以在电脑上弹出对应的控制台,来观察操作的效果,同时在手机和电脑上进行调试。 ?...重新进入小程序 ? 点击vConsole ? 这里出发了onHide,上次在工具开发预览的时候并没有触发。. ? 开启远程调试 点击开启远程调试,也会生成一个二维码 ? 手机扫一扫, ?...出现命中断点和远程调试窗口 ? 可以看到类似web调试的一些工具 ? 可以查看远端代码 ? PS:最后想到了什么老铁,可以查看远端的代码是不是就可以获取到借鉴他的代码了。

    1K10

    关于Arthas如何远程监视Java程序

    Arthas 介绍(摘抄) Arthas 是阿里开源 Java 诊断工具。支持 JDK6+, 采用命令行交互模式,提供 Tab 自动不全,可以方便的定位和诊断线上程序运行问题。...程序运行耗时很长,是哪里耗时比较长呢?如何监测呢? 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception? 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?...程序,所以可以直接用 java -jar 运行。...进程 PID java -jar arthas-boot.jar [PID] 远程访问的运行方式(通过URL访问): # target-ip 要用对外能被访问到的IP java -jar arthas-boot.jar...否则,随意切换到远程访问方式启动arthas,可能就直接报错了: 一旦采用远程访问方式,如果还想在本地打开console操作,同样也必须通过 java -jar arthas-boot.jar --target-ip

    8.7K72

    Java程序执行过程及内存机制

    此外还会介绍Java程序所占用的内存是被如何管理的:堆、栈和方法区都各自负责存储哪些内容。最后用一小块代码示例来帮助理解Java程序运行时内存的变化。...Java程序执行过程 ZOYfmKJIopUDleP.jpg 步骤 1: 写源代码,源代码将以.java的文件格式保存在电脑硬盘中。...那么JIT编译器(Just-In-Time Compiler)是如果参与进程序执行过程中呢?让我们来看以下两个例子。...当然,这只是JIT编译器的优化手段之一,不同公司设计的JIT编译器对Java程序的运行会有不同的优化方式。此外需要知道的是,JIT编译器并不是每次都会参与到执行过程中来。...最后让我们通过一个小例子来理解Java程序执行时内存的变化。

    33220

    Java程序main方法执行流程

    Java程序main方法执行流程 当我们编写完java源代码程序后,经过javac编译后,执行java命令执行这个程序时,是怎么一步步的调用到我们程序中的main方法的呢?...java命令是在安装jre/jdk时配置到系统环境路径中去的,执行java命令时会找到bin目录下的java执行程序,并将我们编译后的java程序类名传递进去就可以执行了。...java执行程序是由C++编写的,它的内部会启动一个Java虚拟机实例。 虚拟机启动入口函数位于src/java.base/share/native/launcher/main.c。...// src/java.base/share/native/launcher/main.c // java程序启动入口主函数 JNIEXPORT int main(int argc, char **argv...命令执行一个应用程序时,首先会先启动虚拟机实例,启动过程中包含了很多初始化工作,这些工作是为java程序提供运行环境的必要条件。

    1.2K30

    RCE远程代码执行

    RCE远程代码执行 一、漏洞介绍 概述 RCE(remote command/code execute)RCE漏洞,可以让攻击者直接向后台服务器远程注入操作系统命令或者代码,从而控制后台系统。...远程系统命令执行 一般出现这种漏洞,是因为应用系统从设计上需要给用户提供指定的远程命令操作的接口 比如我们常见的路由器、防火墙、入侵检测等设备的web管理界面上 一般会给用户提供一个ping操作的web...在这种平台上往往会出现远程系统命令执行的漏洞,不信的话现在就可以找你们运维部的系统测试一下,会有意想不到的"收获"-_- 远程代码执行 同样的道理,因为需求设计,后台有时候也会把用户的输入作为代码的一部分进行执行...,也就造成了远程代码执行漏洞。...不管是使用了代码执行的函数,还是使用了不安全的反序列化等等。 因此,如果需要给前端用户提供操作类的API接口,一定需要对接口输入的内容进行严格的判断,比如实施严格的白名单策略会是一个比较好的方法。

    27610

    TCP远程命令执行

    此篇教大家如何利用TCP进行远程命令执行。 一. 命令集 将值得信任的命令放进一个txt文件中,执行命令时,就去这个文件里面找,有就执行命令,没有就不执行。...命令执行模块实现 依然封装成类,将上述命令集写进类中。...命令将被传到 bin/sh 并使用 -c 标志,shell 将执行这个命令,比如sh -c ls type: 只能是读或者写中的一种,得到的返回值(标准 I/O 流)也具有和 type 相应的只读或只写类型...并创建出执行命令类对象。...效果展示 可以看见只要在命令集中的命令都能执行。 总结: 好了,到这里今天的知识就讲完了,大家有错误一点要在评论指出,我怕我一人搁这瞎bb,没人告诉我错误就寄了。

    12210

    Java 程序执行过程的内存分析

    Java 程序执行过程的内存分析 内存分析先知 栈: 1、每个线程私有,不能实现线程间的共享! 2、局部变量放置于栈中。 3、栈是由系统自动分配,速度快!栈是一个连续的内存空间!...2、用来存放程序中永远不变或唯一的内容。(类代码信息、静态变量、字符串常量) ? 注:常量池具有共享的机制,不同类的常量池之间共享数据。...; } } Test1类 重点:注意看代码里的注释,我把每一条的语句的执行过程都做了很详细的讲解 public class Test1 { public static void...赋值为这个字符串的引用 s1.name = "老叶"; //通过 s1 这个引用先找到Student对象,然后找到 study() 方法的引用,然后去方法区内找到方法,执行该方法...,开一个栈帧,执行完成后释放这个栈帧。

    58010
    领券