钻石会员 发表于 2020-8-3 15:44:15

奇怪的RSA 加密

   try {
            RSAPublicKey v4_1 = RsaUtils.getPublicKey(arg4);
            Cipher v1 = Cipher.getInstance("RSA/ECB/PKCS1Padding");
                       
                        //个人理解,到这里,RSA加密应该完成了,下面是不是把加密后的结果 进行了一些操作??
                        //-------------分割线--------------
            v1.init(1, v4_1);
            int v4_2 = 0;
            byte[] v2 = null;
            while(v4_2 < arg5.length) {
                int v3 = v4_2 + 117;
                v2 = ArrayUtils.addAll(v2, v1.doFinal(ArrayUtils.subarray(arg5, v4_2, v3)));
                v4_2 = v3;
            }
         //-------------分割线--------------
                   //上面是什么操作啊??
            return Base64Utils.byteArrayToBase64(v2);
      }
               
               
               
               
                ---------------
                ---------------
               
               
                public class ArrayUtils {
    public static byte[] addAll(byte[] arg3, byte[] arg4) {
      if(arg3 == null) {
            return ArrayUtils.clone(arg4);
      }

      if(arg4 == null) {
            return ArrayUtils.clone(arg3);
      }

      byte[] v0 = new byte;
      System.arraycopy(((Object)arg3), 0, ((Object)v0), 0, arg3.length);
      System.arraycopy(((Object)arg4), 0, ((Object)v0), arg3.length, arg4.length);
      return v0;
    }

    public static byte[] clone(byte[] arg0) {
      return arg0 == null ? null : ((byte[])arg0.clone());
    }

    public static byte[] subarray(byte[] arg2, int arg3, int arg4) {
      if(arg2 == null) {
            return null;
      }

      if(arg3 < 0) {
            arg3 = 0;
      }

      if(arg4 > arg2.length) {
            arg4 = arg2.length;
      }

      int v4 = arg4 - arg3;
      if(v4 <= 0) {
            return new byte;
      }

      byte[] v1 = new byte;
      System.arraycopy(((Object)arg2), arg3, ((Object)v1), 0, v4);
      return v1;
    }
}

钻石会员 发表于 2020-8-3 15:47:07

try {
            RSAPublicKey v4_1 = RsaUtils.getPublicKey(arg4);
            Cipher v1 = Cipher.getInstance("RSA/ECB/PKCS1Padding");
            
            //个人理解,到这里,RSA加密应该完成了,下面是不是把加密后的结果 进行了一些操作??
            //-------------分割线--------------
            v1.init(1, v4_1);
            int v4_2 = 0;
            byte[] v2 = null;
            while(v4_2 < arg5.length) {
                int v3 = v4_2 + 117;
                v2 = ArrayUtils.addAll(v2, v1.doFinal(ArrayUtils.subarray(arg5, v4_2, v3)));
                v4_2 = v3;
            }
         //-------------分割线--------------
         //上面是什么操作啊??
            return Base64Utils.byteArrayToBase64(v2);
      }
         
         
      //补充代码

      public class ArrayUtils {
    public static byte[] addAll(byte[] arg3, byte[] arg4) {
      if(arg3 == null) {
            return ArrayUtils.clone(arg4);
      }

      if(arg4 == null) {
            return ArrayUtils.clone(arg3);
      }

      byte[] v0 = new byte;
      System.arraycopy(((Object)arg3), 0, ((Object)v0), 0, arg3.length);
      System.arraycopy(((Object)arg4), 0, ((Object)v0), arg3.length, arg4.length);
      return v0;
    }

    public static byte[] clone(byte[] arg0) {
      return arg0 == null ? null : ((byte[])arg0.clone());
    }

    public static byte[] subarray(byte[] arg2, int arg3, int arg4) {
      if(arg2 == null) {
            return null;
      }

      if(arg3 < 0) {
            arg3 = 0;
      }

      if(arg4 > arg2.length) {
            arg4 = arg2.length;
      }

      int v4 = arg4 - arg3;
      if(v4 <= 0) {
            return new byte;
      }

      byte[] v1 = new byte;
      System.arraycopy(((Object)arg2), arg3, ((Object)v1), 0, v4);
      return v1;
    }
}

guhcwtum 发表于 2020-8-4 09:10:20

try {
    //tryC cacth 异常处理
    RSAPublicKey v4_1 = RsaUtils.getPublicKey(arg4);
    //函数名声明         对象的方法调用
    Cipher v1 = Cipher.getInstance("RSA/ECB/PKCS1Padding");
       //函数名声明         对象的方法调用

    //个人理解,到这里,RSA加密应该完成了,下面是不是把加密后的结果 进行了一些操作??
    //-------------分割线--------------

    v1.init(1, v4_1); //init 方法初始值(每次请求调用,找到这个方法)
   
    int v4_2 = 0;
    //声明赋值
    byte[] v2 = null;
    //字节集数组 等于null值

    //判断循环首当0<arg5.length 长度 往下面执行
    while(v4_2 < arg5.length) {
      int v3 = v4_2 + 117;//声明变量赋值;

      v2 = ArrayUtils.addAll(v2, v1.doFinal(ArrayUtils.subarray(arg5, v4_2, v3)));

      //字节型数组存储 = 调用这个ArrayUtils方法的(v2,v1.(这个属性和方法没找到 应该还有,里面就是一些参数))
      v4_2 = v3; //再把v3赋值给v4.2进行循环判断
    }
   //-------------分割线--------------
   //上面是什么操作啊??
    return Base64Utils.byteArrayToBase64(v2);   //返回base一个编码的参数 把v2传出去
}


//补充代码

public class ArrayUtils {
//公开修饰符       声明一个ArrayUtils()类

public static byte[] addAll(byte[] arg3, byte[] arg4)//公开   静态 一个字节集数组byte[]
{
   //如果 ars3 == null 就返回这个方法克隆以下arg4
if(arg3 == null) {
    return ArrayUtils.clone(arg4);
}
//如果 ars4 == null 就返回这个方法克隆以下arg3   俩下调换
if(arg4 == null) {
    return ArrayUtils.clone(arg3);
}
//字节集数组 声明 对象
byte[] v0 = new byte;
//复制数组
System.arraycopy(((Object)arg3), 0, ((Object)v0), 0, arg3.length);
System.arraycopy(((Object)arg4), 0, ((Object)v0), arg3.length, arg4.length);
return v0;
//返回给数组
}

public static byte[] clone(byte[] arg0) {
return arg0 == null ? null : ((byte[])arg0.clone());
}

public static byte[] subarray(byte[] arg2, int arg3, int arg4) {
if(arg2 == null) {
    return null;
}

if(arg3 < 0) {
    arg3 = 0;
}

if(arg4 > arg2.length) {
    arg4 = arg2.length;
}

int v4 = arg4 - arg3;
if(v4 <= 0) {
    return new byte;
}

byte[] v1 = new byte;
System.arraycopy(((Object)arg2), arg3, ((Object)v1), 0, v4);
return v1;
}
}

guhcwtum 发表于 2020-8-4 09:11:11

guhcwtum 发表于 2020-8-4 09:10
try {
    //tryC cacth 异常处理
    RSAPublicKey v4_1 = RsaUtils.getPublicKey(arg4);


我是个菜鸡,,,,,,啥也不会       但是应该没有完 还需要下面的

bpmylbph 发表于 2020-8-5 12:22:54

看不懂,看不懂
页: [1]
查看完整版本: 奇怪的RSA 加密