我需要获得两个功能。我想以xml格式将数据从我的网站传输到我的服务器。现在在我的服务器上,我想创建一个加密数据并将其放在xml中的函数,以及java中的另一个函数来解密它。
请告诉我是否有任何预定义的功能,或者你可以节省5分钟?
答案 0 :(得分:3)
好吧,您可以在PHP中使用任何加密mcrypt
函数。在AES 128中加密的一个例子:
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
$key = "Put your secret key here";
$text = "<xml>This is your XML text</xml>";
//encrypting now with RIJNDAEL 128 encryption.
$crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $text, MCRYPT_MODE_ECB, $iv);
//Display encrypted content
echo $crypttext;
对于解密,请使用此代码(我不是Java专业版,因此可能存在一些错误):
package org.kamal.crypto;
import java.security.*;
import java.security.spec.InvalidKeySpecException;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import sun.misc.*;
public class SimpleProtector
{
private static final String ALGORITHM = "AES";
private static final byte[] keyValue =
new byte[] { 'P', 'u', 't', ' ', 'Y', 'o', 'u', 'r', ' ', 'S', 'e', 'c', 'r', 'e', 't', ' ', 'K', 'e', 'y', '', 'H', 'e', 'r', 'e'};
public static String decrypt(String encryptedValue) throws Exception {
Key key = generateKey();
Cipher c = Cipher.getInstance(ALGORITHM);
c.init(Cipher.DECRYPT_MODE, key);
byte[] decordedValue = new BASE64Decoder().decodeBuffer(encryptedValue);
byte[] decValue = c.doFinal(decordedValue);
String decryptedValue = new String(decValue);
return decryptedValue;
}
private static Key generateKey() throws Exception {
Key key = new SecretKeySpec(keyValue, ALGORITHM);
// SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);
// key = keyFactory.generateSecret(new DESKeySpec(keyValue));
return key;
}
}
答案 1 :(得分:1)
没有必要在这里重新发明轮子。使用SSL,这是HTTPS请求所涉及的内容。你可以通过CURL来做那些。
curl内置于PHP中,还有一个java版本 http://php.net/manual/en/book.curl.php
希望有所帮助。
答案 2 :(得分:-1)
你有没有看过JSON?
它没有加密,但它是在不同程序和语言之间来回传递数据的简单方法。