[英]How to do encryption using AES algorithm
我给了一个.key(abc.key)文件。 使用上述.key文件,可以用Java完成加密和解密。 在这里,我需要使用C#.net实现相同的加密和解密功能。
请给我有关如何破解的想法。 我是这些加密技术的新手。
他们在Java中设置的一些参数如下。 希望它不会给什么主意
String keyFile="abc.key";
String keyAlgorithm= "AES";
String cipherTransformation="AES/CBC/PKCS5Padding";
String needtoEncStr = "Password1";
任何帮助将不胜感激。
更新 :
@daveBM:我使用了bouncycastle,但是得到了不同的结果(与Java输出不同)。 下面是我的完整代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Crypto.Engines;
using Org.BouncyCastle.Crypto.Generators;
using Org.BouncyCastle.Crypto.Modes;
using Org.BouncyCastle.Crypto.Paddings;
using Org.BouncyCastle.Crypto.Parameters;
using Org.BouncyCastle.Security;
using Org.BouncyCastle.Utilities.Encoders;
public class BCEngine
{
private readonly Encoding _encoding;
private readonly IBlockCipher _blockCipher;
private PaddedBufferedBlockCipher _cipher;
private IBlockCipherPadding _padding;
public BCEngine(IBlockCipher blockCipher, Encoding encoding)
{
_blockCipher = blockCipher;
_encoding = encoding;
}
public void SetPadding(IBlockCipherPadding padding)
{
if (padding != null)
_padding = padding;
}
public string Encrypt(string plain, string key)
{
byte[] result = BouncyCastleCrypto(true, _encoding.GetBytes(plain), key);
return Convert.ToBase64String(result);
}
public string Decrypt(string cipher, string key)
{
byte[] result = BouncyCastleCrypto(false, Convert.FromBase64String(cipher), key);
return _encoding.GetString(result);
}
/// <summary>
///
/// </summary>
/// <param name="forEncrypt"></param>
/// <param name="input"></param>
/// <param name="key"></param>
/// <returns></returns>
/// <exception cref="CryptoException"></exception>
private byte[] BouncyCastleCrypto(bool forEncrypt, byte[] input, string key)
{
try
{
_cipher = _padding == null ? new PaddedBufferedBlockCipher(_blockCipher) : new PaddedBufferedBlockCipher(_blockCipher, _padding);
byte[] keyByte = _encoding.GetBytes(key);
_cipher.Init(forEncrypt, new KeyParameter(keyByte));
return _cipher.DoFinal(input);
}
catch (Org.BouncyCastle.Crypto.CryptoException ex)
{
throw new CryptoException(ex.Message);
}
}
}
static void Main(string[] args)
{
Encoding _encoding;
IBlockCipherPadding _padding;
string key = "abc.key";
Stream inStr = null;
inStr = File.OpenRead(key);
Stream stream = inStr;
byte[] bytes = new byte[stream.Length];
stream.Position = 0;
stream.Read(bytes, 0, (int)stream.Length);
string data1 = Encoding.UTF8.GetString(bytes); // this is your string.
_encoding = Encoding.ASCII;
Pkcs7Padding pkcs = new Pkcs7Padding();
_padding = pkcs;
BCEngine bcEngine = new BCEngine(new AesEngine(), _encoding);
bcEngine.SetPadding(_padding);
string data=bcEngine.Encrypt("AbcDefg12$", data1);
}
当我的预期输出是“ 3df36eb77ccfc05e264a6212c2db5380”时,我得到此输出“ S2jjvVJVKfGodPfMuI4v + g ==“ ......请让我知道出了什么问题。
您可以使用某人在其他相关问题中发布的这段代码。
您需要做的是使用Encrypt(string plainText,string passPhrase)方法 ,其中plainText是您想要加密的任何内容,而passPhrase是您的.key文件的内容。
顺便说一句,仅提及您拥有一个.key文件就足够了。 我们不需要知道内容:) ..
希望能有所帮助
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.