AES 加密求教, Java / PHP aes 数据加密不一致求教

2019-07-12 11:58:36 +08:00
 OneTomato

php 代码:

$key = 'com.sccin.cn';
$str = '315edfbdfrb5rgfhb1651656';
$data = 'cC94QUdYVnBJcW5HRmJyRU1IcUxGbUlzQ0pnQmQvNlh3K3FTMjA1MHl2WT0=';
var_dump(openssl_encrypt($str, 'AES-256-ECB', $key, OPENSSL_RAW_DATA, null));

java 代码


    public static byte[] encrypt(String content, String password) {
        try {
            KeyGenerator kgen = KeyGenerator.getInstance("AES");
            SecureRandom securerandom = new SecureRandom(tohash256Deal(password));
            kgen.init(256, securerandom);
            SecretKey secretKey = kgen.generateKey();
            byte[] enCodeFormat = secretKey.getEncoded();
            SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
            Security.addProvider(new BouncyCastleProvider());

            Cipher cipher = Cipher.getInstance("AES/ECB/PKCS7Padding", "BC");

            cipher.init(Cipher.ENCRYPT_MODE, key);
            byte[] byteContent = content.getBytes("utf-8");
            byte[] cryptograph = cipher.doFinal(byteContent);
            return Base64.getEncoder().encode(cryptograph);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    private static byte[] tohash256Deal(String datastr) {
        try {
            MessageDigest digester = MessageDigest.getInstance("SHA-256");
            digester.update(datastr.getBytes());
            byte[] hex = digester.digest();
            return hex;
        } catch (NoSuchAlgorithmException e) {
            throw new RuntimeException(e.getMessage());
        }
    }
3899 次点击
所在节点    算法
13 条回复
icy37785
2019-07-12 12:12:03 +08:00
java 这边结果错了,具体是哪个环节出了问题,我写 java 少肉眼看不出来。
OneTomato
2019-07-12 12:23:06 +08:00
@icy37785 但是 java 的数据现在能正常加解密。
这个是 java 同事提供的 demo 代码: http://note.youdao.com/noteshare?id=104256e9c3ba463203d5c94e14d28578&sub=9B9014CAAF1C4558A557A88CC4DE66B5

运行环境是 JDK1.8
麻烦您帮我看看,谢谢
JamesMackerel
2019-07-12 12:27:46 +08:00
没写过 php,不知道用的是哪种 padding。一般我用 Java 是写的 pkcs5。
OneTomato
2019-07-12 12:29:06 +08:00
@JamesMackerel 我现在用的也是 pkcs5
geeglo
2019-07-12 12:35:12 +08:00
不会 java,看着是 PKCS7Padding 这个的原因?
Citrus
2019-07-12 12:43:36 +08:00
简单看了下大概是密钥扩展算法的问题。等下写个 Demo 调试一下。
icy37785
2019-07-12 12:49:36 +08:00
@OneTomato 我现在用的电脑没装 java 环境
你这边 java 数据能正常解密,应该是用 java 写了个逆运算来解密这个结果,所以能解挺正常的。
我没有 java 环境,所以我当时检验的方式是用其他的语言的 AES-256-ECB 加密来加密这个字符串,我用 go,c++,和 php 加密的结果是一致的,如你上面给出的 php 加密后数据一致。
所以我的判断是 java 得到的结果不一样,但是因为 java 写得少,肉眼看不出来问题出在哪里,又没 java 环境去检验,所以给不出太多建设性的意见。
OneTomato
2019-07-12 12:55:48 +08:00
@icy37785 好,谢谢你
OneTomato
2019-07-12 13:03:59 +08:00
@Citrus 要的,感谢
iyaozhen
2019-07-12 13:10:49 +08:00
感觉是密钥长度的原因 AES-256 需要密钥 32 位长,java 你那个 tohash256Deal 一通操作后处理了下密钥,和 PHP 应该不一致了
allenforrest
2019-07-12 13:12:57 +08:00
php 代码是的密钥是 com.sccin.cn
java 代码是把 com.sccin.cn 算 sha256 hash 后做密钥
across
2019-07-12 13:15:33 +08:00
前几年做过一个 java c++ C#直接交互的,当时类似问题是 encode decode 部分不一致,java 是 unicode 还是什么来着,忘了,自己验证下吧···很可能和字符串编码相关。
OneTomato
2019-07-12 15:23:31 +08:00
@iyaozhen tohash256Deal 这一步我研究出来了,就是把密钥 用 sha256 方式加密出来

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/582316

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX