Descriptografia DES / ECB / PKCS5Padding em PHP
Eu estou precisando descriptografar com PHP (ou Javascript) algumas chamadas de serviço. Passei o dia todo tentando realizar isso, mas não consegui decifrá-lo corretamente.
Como referência, o provedor de serviços me enviou o seguinte código de amostra de descriptografia em Java:
<code>DESKeySpec dks = new DESKeySpec("keyword".getBytes()); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); SecretKey key = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding"); SecureRandom sr = new SecureRandom(); cipher.init( Cipher.DECRYPT_MODE, key ,sr); byte b[] = response.toByteArray(); byte decryptedData[] = cipher.doFinal( b ); </code>
Eu acho que estou no caminho correto usando:
<code>$td = mcrypt_module_open(MCRYPT_DES, '', 'ecb', ''); $iv_size = mcrypt_enc_get_iv_size($td); $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND); $key = substr($keyword, 0, mcrypt_enc_get_key_size($td)); mcrypt_generic_init($td, $key, $iv); $decrypted = mdecrypt_generic($td, $data); $decrypted = pkcs5_unpad($decrypted); </code>
Mas, francamente, tenho certeza de que estou bagunçando tudo com a configuração $ iv creationg e $ keyword (ou talvez com $ data ou $ decrypted types?). A função pkcs5_unpad é a seguinte:
<code>function pkcs5_unpad($text) { $pad = ord($text{strlen($text)-1}); if ($pad > strlen($text)) return false; return substr($text, 0, -1 * $pad); } </code>
Eu não sou apenas um noob em php, mas também em técnicas de criptografia ... você poderia por favor me ajudar a resolver este problema?