懂php和java的进来,求教一个问题 报错-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

懂php和java的进来,求教一个问题 报错

2020-05-26 13:57:04 347 1

"

1 和别的公司对接业务,对方java,我是php。
2 双方把把数据先DES加密,再base64加密。进行传输
3 对方发了一个java的加密解密,我应该照着做一个php的。但看不懂java代码。
4 求大神能忙,万谢。

package com.ab.mediation.util;

import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStreamReader;

import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; /** * 对外接口数据加密/解密类 * @author xin * */ public class DesUtil {

private final static String DES = "DES";

public static void main(String[] args) throws Exception {
    String tDoc = "";// 请求报文
    String encoding = "GBK";
    // 将函数参数赋给本地参数
    String path = "/Users/jieliu/Code/a.txt";
    // String path = "F:\\testxml\\requestAppPolInp881.xml";
    String path1 = path;
    // 初始化文件对象f
    File f = new File(path1);
    // 初始化读数据流对象reader
    InputStreamReader reader = new InputStreamReader(new FileInputStream(
            path1), encoding);
    // 根据f文件长度初始化字符串数据c[]
    char c[] = new char[(int) (f.length())];
    // 取到字符串长度,并将文件f内容写入数组c
    int length = reader.read(c);
    // 逐字节将字符串数组c[],赋给变量tDoc
    for (int i = 0; i < length; i++) {
        tDoc = tDoc + c[i];
    }

    String key = "12dc293d43db3b237849";
    System.out.println(encrypt(tDoc, key));
    System.out.println(decrypt(encrypt(tDoc, key), key));

}

/**
 * Description 根据键值进行加密
 * 
 * @param data
 * @param key
 *            加密键byte数组
 * @return
 * @throws Exception
 */
public static String encrypt(String data, String key) throws Exception {
    byte[] bt = encrypt(data.getBytes(), key.getBytes());
    String strs = new BASE64Encoder().encode(bt);
    return strs;
}

/**
 * 指定字符编码方式并加密
 * @param data
 * @param key
 * @param encoding
 * @return
 * @throws Exception
 */
public static String encrypt(String data, String key, String encoding) throws Exception {
    byte[] bt = encrypt(data.getBytes(encoding), key.getBytes());
    String strs = new BASE64Encoder().encode(bt);
    return strs;
}

/**
 * Description 根据键值进行解密
 * 
 * @param data
 * @param key
 *            加密键byte数组
 * @return
 * @throws IOException
 * @throws Exception
 */
public static String decrypt(String data, String key) throws IOException,
        Exception {
    if (data == null)
        return null;
    BASE64Decoder decoder = new BASE64Decoder();
    byte[] buf = decoder.decodeBuffer(data);
    byte[] bt = decrypt(buf, key.getBytes());
    return new String(bt);
}

/**
 * 根据键值解密并返回指定编码方式字符串
 * @param data
 * @param key
 * @param encoding
 * @return
 * @throws IOException
 * @throws Exception
 */
public static String decrypt(String data, String key, String encoding) throws IOException,
    Exception {
    if (data == null)
        return null;
    BASE64Decoder decoder = new BASE64Decoder();
    byte[] buf = decoder.decodeBuffer(data);
    byte[] bt = decrypt(buf, key.getBytes());
    return new String(bt, encoding);
}

/**
 * Description 根据键值进行加密
 * 
 * @param data
 * @param key
 *            加密键byte数组
 * @return
 * @throws Exception
 */
private static byte[] encrypt(byte[] data, byte[] key) throws Exception {
    // 生成一个可信任的随机数源
    SecureRandom sr = new SecureRandom();

    // 从原始密钥数据创建DESKeySpec对象
    DESKeySpec dks = new DESKeySpec(key);

    // 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
    SecretKey securekey = keyFactory.generateSecret(dks);

    // Cipher对象实际完成加密操作
    Cipher cipher = Cipher.getInstance(DES);

    // 用密钥初始化Cipher对象
    cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);

    return cipher.doFinal(data);
}

/**
 * Description 根据键值进行解密
 * 
 * @param data
 * @param key
 *            加密键byte数组
 * @return
 * @throws Exception
 */
private static byte[] decrypt(byte[] data, byte[] key) throws Exception {
    // 生成一个可信任的随机数源
    SecureRandom sr = new SecureRandom();

    // 从原始密钥数据创建DESKeySpec对象
    DESKeySpec dks = new DESKeySpec(key);

    // 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
    SecretKey securekey = keyFactory.generateSecret(dks);

    // Cipher对象实际完成解密操作
    Cipher cipher = Cipher.getInstance(DES);

    // 用密钥初始化Cipher对象
    cipher.init(Cipher.DECRYPT_MODE, securekey, sr);

    return cipher.doFinal(data);
}

}

" ![image.png](https://ucc.alicdn.com/pic/developer-ecology/3e1a6c3761a54afba05b93ba2793612c.png)
取消 提交回答
全部回答(1)
  • 因为相信,所以看见。
    2020-05-27 10:06:23

    "

    <a href=""https://github.com/sjclijie/php-des"" rel=""nofollow noreferrer"">https://github.com/sjclijie/p...

    用这个试试吧,这和他用的什么java代码关系不大,你实现他的加密逻辑就可以了。

    先 base64 decode 然后用des算法解密

    ######

    已解决

    class DES {
        protected $cipher; //密码
        protected $mode; //模式
        private $_secret_key; //密钥
    
        public function __construct($key, $cipher=MCRYPT_TRIPLEDES, $mode=MCRYPT_MODE_ECB) {
            $this->_secret_key = $key;
            $this->cipher = $cipher;
            $this->mode = $mode;
        }
    
        public function encrypt($str, $padding = true) {
            if ($padding) {
                $size = mcrypt_get_block_size($this->cipher, $this->mode);
                $pad = $size - (strlen($str) % $size);
                $str .= str_repeat(chr($pad), $pad);
            }
    
            $td = mcrypt_module_open($this->cipher, '', $this->mode, '');
            $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
            mcrypt_generic_init($td, $this->_secret_key, $iv);
            $data = mcrypt_generic($td, $str);
            mcrypt_generic_deinit($td);
            mcrypt_module_close($td);
    
            return base64_encode($data);
        }
    
        public function decrypt($str, $padding = true) {
            $td = mcrypt_module_open($this->cipher, '', $this->mode, '');
            $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
            mcrypt_generic_init($td, $this->_secret_key, $iv);
            $data = mdecrypt_generic($td, base64_decode($str));
            mcrypt_generic_deinit($td);
            mcrypt_module_close($td);
    
            if ($padding) {
                $pad = ord($data{strlen($data) - 1});
                return substr($data, 0, -1 * $pad);
            }
            return $data;
        }
    }
    " ![image.png](https://ucc.alicdn.com/pic/developer-ecology/0332f43c26714d129f3999425907b9c0.png)
    0 0
相关问答

1

回答

如何再ecs上同时部署php和java环境

2018-08-30 15:26:51 511浏览量 回答数 1

12

回答

Ecs上可以同时部署java和php环境吗

2014-07-29 08:57:19 13192浏览量 回答数 12

1

回答

PHP如何读取WEB服务器上的JS文件源代码,报错

2020-06-20 21:30:31 2427浏览量 回答数 1

1

回答

PHP 读取TXT文件的相关问题,报错

2020-06-20 21:31:25 2480浏览量 回答数 1

1

回答

首页index.php文件没有放到htdocs文件夹根目录下 出现403错误

2018-10-12 20:49:10 1229浏览量 回答数 1

1

回答

在浏览器中打开php文件时,是Linux中的哪个用户执行的?

2017-11-30 17:36:53 1715浏览量 回答数 1

0

回答

如何通过IIS7.5和php.ini配置文件调整网站后上传文件大小限制

2017-11-02 15:04:04 2388浏览量 回答数 0

8

回答

文件存贮在阿里云的OSS,PHP怎么实现多文件打包下载?

2017-03-10 11:14:31 11932浏览量 回答数 8

1

回答

新建PHP的utf-8无dom文件,关了再打开变成ANSI了,怎么办?

2016-06-14 14:25:47 2258浏览量 回答数 1

1

回答

关于在linux中定时执行php文件的问题!

2016-06-13 11:00:26 1628浏览量 回答数 1
+关注
因为相信,所以看见。
阿里,我所有的向往
0
文章
1438
问答
问答排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载