乐易论坛-乐易网易语言培训教程火山PC视窗中文编程交流论坛

 找回密码
 立即注册

手机号登录

用手机号号登陆

微信登录

微信扫码,快速开始

QQ登录

用QQ账号登陆

办理VIP,定制软件,报名培训联系QQ[重磅]2024年实地培训高清培训目录火山PC版乐易模块使用教程
请牢记揰掵佲的QQ号1615457736 1615457734 其他都是骗子有了火山,易语言是否还有必要学习吗?易语言0基础入门课程
火山PC视窗0基础入门课程易语言外挂0基础入门课程火山PC视窗火山HOOK入门课程
易语言误报处理课程QQ空间POST课程2022年火山PC易语言POST系列课程
Android逆向Jeb动态调试0基础课程QQ邮箱网页POST课程WeChat个微Hook实战课程
百日Js加密分析实战课程(无密下载)QQ群POST课程h5游戏WebSocket逆向视频
JavaScript加密特训课程易语言汇编快速入门课程破解实战系列课程
[2024年]火山PC0基础x64位游戏内存辅助开发教程手游模拟器脚本0基础课程易语言加密防破解0基础入门课程
广告位招租联系QQ1615457736  
查看: 7290|回复: 4

[易求助] 奇怪的RSA 加密

[复制链接]

[易求助] 奇怪的RSA 加密

[复制链接]
已绑定手机
钻石会员
等级头衔

等級:编程起步

Rank: 5Rank: 5

积分成就
易币
贡献
主题
精华
金钱
积分
564
注册时间
2016-12-12
最后登录
1970-1-1

勋章墙

2020-8-3 15:44:15 | 显示全部楼层 |阅读模式

据统计90%查看本帖的人,都已经注册本站了哦

您需要 登录 才可以下载或查看,没有账号?立即注册

×
[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;
    }
}


guhcwtum已获得悬赏 1 易币+100 易币

最佳答案

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

使用道具 举报

已绑定手机
楼主
钻石会员 楼主
等级头衔

等級:编程起步

Rank: 5Rank: 5

积分成就
易币
贡献
主题
精华
金钱
积分
564
注册时间
2016-12-12
最后登录
1970-1-1

勋章墙

2020-8-3 15:47:07 | 显示全部楼层
[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;
    }
}

回复

使用道具 举报

已绑定手机
guhcwtum
等级头衔

等級:编程学徒

Rank: 3Rank: 3

积分成就
易币
贡献
主题
精华
金钱
积分
211
注册时间
2020-5-22
最后登录
1970-1-1

勋章墙

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[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;
}
}

评分

参与人数 1易币 +10 金钱 +20 收起 理由
揰掵佲 + 10 + 20 感谢帮助解答,谢谢!

查看全部评分

回复

使用道具 举报

已绑定手机
guhcwtum
等级头衔

等級:编程学徒

Rank: 3Rank: 3

积分成就
易币
贡献
主题
精华
金钱
积分
211
注册时间
2020-5-22
最后登录
1970-1-1

勋章墙

2020-8-4 09:11:11 | 显示全部楼层
guhcwtum 发表于 2020-8-4 09:10
try {
    //tryC cacth 异常处理
    RSAPublicKey v4_1 = RsaUtils.getPublicKey(arg4);

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

使用道具 举报

已绑定手机
bpmylbph
等级头衔

等級:初识编程

Rank: 1

积分成就
易币
贡献
主题
精华
金钱
积分
19
注册时间
2020-8-5
最后登录
1970-1-1

勋章墙

2020-8-5 12:22:54 | 显示全部楼层
看不懂,看不懂
回复

使用道具 举报

如果懒得打字,请选择右侧内容快捷回复 提醒:以任何方式进行『恶意灌水』的行为,进行封号处理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

热点推荐上一条 /5 下一条

QQ|网站地图|手机版|小黑屋|乐易论坛-乐易网 | 湘ICP备19007035号

拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表乐易立场!

娄底市乐易网络科技有限公司声明:乐易原创培训课程版权均为我公司所有,未经许可,不得擅自翻录,盗版,破解本站课课程,我们将保留法律诉讼的权利

GMT+8, 2024-5-4 20:24 , Processed in 0.054756 second(s), 53 queries .

Powered by Discuz! X3.4

Copyright © Tencent Cloud.

快速回复 返回顶部 返回列表