-1

我需要一个尽可能短且快速的代码来将字符串更改为不可读的内容(对于人类来说),并使其再次可读。这一切都需要在java中发生。

像这样的东西:

encrypt("test");

会导致这样的事情:

ôT¿ÄÜTV CÁˆ“5="ËÂÀœššbÀß{¡ä³

decrypt("ôT¿ÄÜTV CÁˆ“5 1="ËÂÀœššbÀß{¡ä³");

会比再次变成原来的

test

我应该往哪个方向走,有什么课程可以为我做这件事吗?我不是指 Base68Encryption 之类的东西或任何可能被称为的东西,我指的是我可以安全地通过 Internet 发送的真正不可读的文本。

4

3 回答 3

1

请参阅示例代码http://www.code2learn.com/2011/06/encryption-and-decryption-of-data-using.html的数据算法的加密和解密。加密/解密嵌入在 JRE 中,使用起来并不难。

于 2013-04-26T14:16:12.430 回答
1

这是使用真正加密的一个非常简短的示例。它是 128 位 AES,非常安全 - 任何想象都无法读取。

它会生成一个随机密钥,因此每次运行都会有所不同。您需要在两个交换数据的程序之间共享它们的密钥。

private static final String ENCRYPTION_ALGORITHM = "AES/ECB/PKCS5Padding";
private static final SecureRandom RANDOM = new SecureRandom();

public static void main(String[] args) throws UnsupportedEncodingException, GeneralSecurityException {
    final KeyGenerator keyGen = KeyGenerator.getInstance(ENCRYPTION_ALGORITHM.substring(0, ENCRYPTION_ALGORITHM.indexOf('/')));
    keyGen.init(128, RANDOM);
    final SecretKey key = keyGen.generateKey();
    final String s = "My topsecret string";
    System.out.println(s);
    final Cipher encryption = getCipher(key, Cipher.ENCRYPT_MODE);
    final String enc = DatatypeConverter.printBase64Binary(encryption.doFinal(s.getBytes("UTF-8")));
    System.out.println(enc);
    final Cipher decryption = getCipher(key, Cipher.DECRYPT_MODE);
    final String dec = new String(decryption.doFinal(DatatypeConverter.parseBase64Binary(enc)), "UTF-8");
    System.out.println(dec);
}

private static Cipher getCipher(final Key key, final int mode) throws GeneralSecurityException {
    final Cipher cipher = Cipher.getInstance(ENCRYPTION_ALGORITHM);
    cipher.init(mode, key, RANDOM);
    return cipher;
}

输出:

My topsecret string
ip4La5KUBJGTTYenoE920V5w0VBHwALv4fp3qyLTY9o=
My topsecret string
于 2013-04-26T14:17:23.653 回答
0

我应该往哪个方向走,有什么课程可以为我做这件事吗?我不是指 Base68Encryption 之类的东西或任何可能被称为的东西,我指的是我可以安全地通过 Internet 发送的真正不可读的文本。

有两种方法可以解决这个问题:

  • 您可以选择在典型 JVM 中作为标准实现的现有高质量加密系统之一。然后:

    1. 将字符串编码为字节;例如使用 UTF-8。

    2. 使用约定的加密系统和先前约定的密钥对字节进行加密。

    3. 使用 base_64 或等效方法对字节进行编码。

    在另一端:

    1. 解码 base_64

    2. 使用相同的系统和密钥解密字节。

    3. 解码 UTF-8 以获取字符串。

  • 使用 SSL/TLS 保护 TCP/IP 连接,并按原样通过连接发送字符串。

这些选项都不是特别快。但不要试图发明自己更快的加密系统。很有可能,一个“自制”的加密系统比你意识到的要容易得多。

于 2013-04-26T14:48:28.063 回答