[Java] 纯文本查看 复制代码 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[arg3.length + arg4.length];
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[0];
}
byte[] v1 = new byte[v4];
System.arraycopy(((Object)arg2), arg3, ((Object)v1), 0, v4);
return v1;
}
}
|