Java--new Class[]{}

在cc1链中的poc有着这样一段

        Transformer[] transformers = new Transformer[] {
                //通过ConstantTransformer类的transform方法获取一个对象类型
                new ConstantTransformer(Runtime.class),
                new InvokerTransformer("getMethod", new Class[] {String.class, Class[].class }, new Object[] {"getRuntime", new Class[0] }),
                new InvokerTransformer("invoke", new Class[] {Object.class, Object[].class }, new Object[] {null, new Object[0] }),
                new InvokerTransformer("exec", new Class[] {String.class }, new Object[] {"calc.exe"})};

 

这里的new Class[]{} new Object[]{}是什么意思呢?

new Class[] {String.class }

就是创建一个数组并且填入元素 String.class,就相当于 new int[]{666}

 

也就可以写成

 Class[] para = new Class[1];
        para[0] = String.class;
        Transformer[] transformers = new Transformer[] {
                //通过ConstantTransformer类的transform方法获取一个对象类型
                new ConstantTransformer(Runtime.class),
                new InvokerTransformer("getMethod", new Class[] {String.class, Class[].class }, new Object[] {"getRuntime", new Class[0] }),
                new InvokerTransformer("invoke", new Class[] {Object.class, Object[].class }, new Object[] {null, new Object[0] }),
                new InvokerTransformer("exec", para, new Object[] {"calc.exe"})};

用para来代替了new Class[]{String.class}

 

顺便一提这里的

new InvokerTransformer("getMethod", new Class[] {String.class, Class[].class }, new Object[] {"getRuntime", new Class[0] })

注意这里是new了一个Class[]里面填入了String.class,以及一个新的Class[].class (也就是Class数组类)

这两个Class[]数组是不一样的.

 

参考:new class[]

 

posted @ 2022-02-10 10:07  Erichas  阅读(2091)  评论(0编辑  收藏  举报