java C# objective-c通用AES对称加解密

源代码已经上传,并经过测试,下载请到文章最后部分的下载链接。

1.java

/**
 * AES加解密
 * 
 * @author talver
 */
public class Security {
	final static String AES_KEY = "Q*1_3@c!4kd^j&g%";

	/**
	 * AES加密
	 * 
	 * @param str
	 *            待加密字符串
	 * @return 加密后字符串
	 */
	public static String aesEncrypt(String str) {
		try {
			String password = AES_KEY;
			SecretKeySpec skeySpec = new SecretKeySpec(password.getBytes(), "AES");
			Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
			cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
			String strTmp = Base64.encodeToString(cipher.doFinal(str.getBytes()), Base64.DEFAULT);
			return strTmp;
		} catch (Exception e) {
			e.printStackTrace();
		}
		return str;
	}

	/**
	 * AES解密
	 * 
	 * @param str
	 *            待解密字符串
	 * @return 解密后字符串
	 */
	public static String aesDecrypt(String str) {
		try {
			String password = AES_KEY;
			SecretKeySpec skeySpec = new SecretKeySpec(password.getBytes(), "AES");
			Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
			cipher.init(Cipher.DECRYPT_MODE, skeySpec);
			String strTmp = new String(cipher.doFinal(Base64.decode(str, Base64.DEFAULT)));
			return strTmp;
		} catch (Exception ex) {
			ex.printStackTrace();
		}
		return str;
	}
}

2.C#

public class Security
    {
        const string AES_KEY = "Q*1_3@c!4kd^j&g%";

        /// <summary>
        /// AES加密
        /// </summary>
        /// <param name="str">待加密字符串</param>
        /// <returns>加密后字符串</returns>
        public static string AesEncrypt(string str)
        {
            try
            {
                string key = AES_KEY;
                //分组加密算法
                AesCryptoServiceProvider aes =new AesCryptoServiceProvider();
                byte[] inputByteArray = Encoding.UTF8.GetBytes(str);//得到需要加密的字节数组 
                //设置密钥及密钥向量
                aes.Key = Encoding.UTF8.GetBytes(key);
                //aes.IV = Encoding.UTF8.GetBytes(key);
                aes.Mode = CipherMode.ECB;
                aes.Padding = PaddingMode.PKCS7;
                byte[] cipherBytes = null;
                using (MemoryStream ms = new MemoryStream())
                {
                    using (CryptoStream cs = new CryptoStream(ms, aes.CreateEncryptor(), CryptoStreamMode.Write))
                    {
                        cs.Write(inputByteArray, 0, inputByteArray.Length);
                        cs.FlushFinalBlock();
                        cipherBytes = ms.ToArray();//得到加密后的字节数组
                        cs.Close();
                        ms.Close();
                    }
                }
                return Convert.ToBase64String(cipherBytes);
            }
            catch { }
            return str;
        }

        /// <summary>
        /// AES解密
        /// </summary>
        /// <param name="str">待解密字符串</param>
        /// <returns>解密后字符串</returns>
        public static string AesDecrypt(string str)
        {
            try
            {
                string key = AES_KEY;
                byte[] cipherText = Convert.FromBase64String(str);
                AesCryptoServiceProvider aes = new AesCryptoServiceProvider();
                aes.Key = Encoding.UTF8.GetBytes(key);
                //aes.IV = Encoding.UTF8.GetBytes(key);
                aes.Mode = CipherMode.ECB;
                aes.Padding = PaddingMode.PKCS7;
                byte[] decryptBytes = new byte[cipherText.Length];
                using (MemoryStream ms = new MemoryStream(cipherText))
                {
                    using (CryptoStream cs = new CryptoStream(ms, aes.CreateDecryptor(), CryptoStreamMode.Read))
                    {
                        cs.Read(decryptBytes, 0, decryptBytes.Length);
                        cs.Close();
                        ms.Close();
                    }
                }
                return Encoding.UTF8.GetString(decryptBytes).Replace("\0", "");   //将字符串后尾的'\0'去掉
            }
            catch { }
            return str;
        }
    }

3.objective-c

1).h文件

#import <Foundation/Foundation.h>

@interface Security : NSObject
+(NSString*)AesEncrypt:(NSString*)str;
+(NSString*)AesDecrypt:(NSString*)str;
@end


2).m文件

#import "Security.h"
#import <CommonCrypto/CommonCryptor.h>
static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
#define LocalStr_None @"" //空字符串

@implementation Security

/*
 * AES加密
 *
 */
+(NSString*)AesEncrypt:(NSString*)str{
    NSString *key=@"Q*1_3@c!4kd^j&g%"; // 密钥
    NSData *data=[str dataUsingEncoding:NSUTF8StringEncoding]; // 待加密字符转为NSData型
    char keyPtr[kCCKeySizeAES128 + 1];
    memset(keyPtr, 0, sizeof(keyPtr));
    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
    
    NSUInteger dataLength = [data length];
    size_t bufferSize = dataLength + kCCBlockSizeAES128;
    void *buffer = malloc(bufferSize);
    
    size_t numBytesCrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,
                                          kCCAlgorithmAES128,
                                          kCCOptionPKCS7Padding|kCCOptionPKCS7Padding,
                                          keyPtr,
                                          kCCBlockSizeAES128,
                                          nil,
                                          [data bytes],
                                          dataLength,
                                          buffer,
                                          bufferSize,
                                          &numBytesCrypted);
    if (cryptStatus == kCCSuccess) {
        NSData *resultData=[NSData dataWithBytesNoCopy:buffer length:numBytesCrypted];
        NSString *result =[self base64EncodedStringFrom:resultData];
        return result;
    }
    free(buffer);
    return str;
}

/*
 * AES解密
 *
 */
+(NSString*)AesDecrypt:(NSString*)str{
    NSString *key=@"Q*1_3@c!4kd^j&g%"; // 密钥
    NSData *data=[self dataWithBase64EncodedString:str]; // base4解码
    char keyPtr[kCCKeySizeAES128 + 1];
    memset(keyPtr, 0, sizeof(keyPtr));
    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
    
    NSUInteger dataLength = [data length];
    size_t bufferSize = dataLength + kCCBlockSizeAES128;
    void *buffer = malloc(bufferSize);
    
    size_t numBytesCrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
                                          kCCAlgorithmAES128,
                                          kCCOptionPKCS7Padding|kCCOptionPKCS7Padding,
                                          keyPtr,
                                          kCCBlockSizeAES128,
                                          nil,
                                          [data bytes],
                                          dataLength,
                                          buffer,
                                          bufferSize,
                                          &numBytesCrypted);
    if (cryptStatus == kCCSuccess) {
        NSData *resultData=[NSData dataWithBytesNoCopy:buffer length:numBytesCrypted];
        NSString *result =[[NSString alloc]initWithData:resultData encoding:NSUTF8StringEncoding];
        return result;
    }
    free(buffer);
    return str;
}


+ (NSString *)base64StringFromText:(NSString *)text
{
    if (text && ![text isEqualToString:LocalStr_None]) {
        NSData *data = [text dataUsingEncoding:NSUTF8StringEncoding];
        return [self base64EncodedStringFrom:data];
    }
    else {
        return LocalStr_None;
    }
}

+ (NSString *)textFromBase64String:(NSString *)base64
{
    if (base64 && ![base64 isEqualToString:LocalStr_None]) {
        NSData *data = [self dataWithBase64EncodedString:base64];
        return [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
    }
    else {
        return LocalStr_None;
    }
}

+ (NSData *)dataWithBase64EncodedString:(NSString *)string
{
    if (string == nil)
        [NSException raise:NSInvalidArgumentException format:nil];
    if ([string length] == 0)
        return [NSData data];
    
    static char *decodingTable = NULL;
    if (decodingTable == NULL)
    {
        decodingTable = malloc(256);
        if (decodingTable == NULL)
            return nil;
        memset(decodingTable, CHAR_MAX, 256);
        NSUInteger i;
        for (i = 0; i < 64; i++)
            decodingTable[(short)encodingTable[i]] = i;
    }
    
    const char *characters = [string cStringUsingEncoding:NSASCIIStringEncoding];
    if (characters == NULL)     //  Not an ASCII string!
        return nil;
    char *bytes = malloc((([string length] + 3) / 4) * 3);
    if (bytes == NULL)
        return nil;
    NSUInteger length = 0;
    
    NSUInteger i = 0;
    while (YES)
    {
        char buffer[4];
        short bufferLength;
        for (bufferLength = 0; bufferLength < 4; i++)
        {
            if (characters[i] == '\0')
                break;
            if (isspace(characters[i]) || characters[i] == '=')
                continue;
            buffer[bufferLength] = decodingTable[(short)characters[i]];
            if (buffer[bufferLength++] == CHAR_MAX)      //  Illegal character!
            {
                free(bytes);
                return nil;
            }
        }
        
        if (bufferLength == 0)
            break;
        if (bufferLength == 1)      //  At least two characters are needed to produce one byte!
        {
            free(bytes);
            return nil;
        }
        
        //  Decode the characters in the buffer to bytes.
        bytes[length++] = (buffer[0] << 2) | (buffer[1] >> 4);
        if (bufferLength > 2)
            bytes[length++] = (buffer[1] << 4) | (buffer[2] >> 2);
        if (bufferLength > 3)
            bytes[length++] = (buffer[2] << 6) | buffer[3];
    }
    
    bytes = realloc(bytes, length);
    return [NSData dataWithBytesNoCopy:bytes length:length];
}

+ (NSString *)base64EncodedStringFrom:(NSData *)data
{
    if ([data length] == 0)
        return @"";
    
    char *characters = malloc((([data length] + 2) / 3) * 4);
    if (characters == NULL)
        return nil;
    NSUInteger length = 0;
    
    NSUInteger i = 0;
    while (i < [data length])
    {
        char buffer[3] = {0,0,0};
        short bufferLength = 0;
        while (bufferLength < 3 && i < [data length])
            buffer[bufferLength++] = ((char *)[data bytes])[i++];
        
        //  Encode the bytes in the buffer to four characters, including padding "=" characters if necessary.
        characters[length++] = encodingTable[(buffer[0] & 0xFC) >> 2];
        characters[length++] = encodingTable[((buffer[0] & 0x03) << 4) | ((buffer[1] & 0xF0) >> 4)];
        if (bufferLength > 1)
            characters[length++] = encodingTable[((buffer[1] & 0x0F) << 2) | ((buffer[2] & 0xC0) >> 6)];
        else characters[length++] = '=';
        if (bufferLength > 2)
            characters[length++] = encodingTable[buffer[2] & 0x3F];
        else characters[length++] = '=';
    }
    
    return [[NSString alloc] initWithBytesNoCopy:characters length:length encoding:NSASCIIStringEncoding freeWhenDone:YES];
}

@end

4.源代码下载:http://download.csdn.net/detail/talver/7985063

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 我可以提供一段Java与C-share通用的RSA2解密的C语言程序示例: #include <stdio.h> #include <string.h> #include <stdlib.h> #include <openssl/rsa.h> #include <openssl/pem.h>//密 int public_encrypt(unsigned char *data,int data_len,unsigned char *key,unsigned char *encrypted) { RSA * rsa = NULL; FILE * fp = NULL; int flen; int rsa_len; //从文件中读取公钥 fp=fopen(key,"rb"); if(fp==NULL){ perror("open key file error"); return -1; } rsa=PEM_read_RSA_PUBKEY(fp,NULL,NULL,NULL); if(rsa==NULL){ perror("read key file error"); return -2; } fclose(fp); //获取RSA长度 flen=RSA_size(rsa); rsa_len=RSA_public_encrypt(data_len,data,encrypted,rsa,RSA_NO_PADDING); if(rsa_len==-1){ perror("RSA_public_encrypt error"); return -3; } RSA_free(rsa); return 0; }//解密 int private_decrypt(unsigned char *enc_data,int data_len,unsigned char *key,unsigned char *decrypted) { RSA * rsa = NULL; FILE * fp = NULL; int rsa_len; //从文件中读取私钥 fp=fopen(key,"rb"); if(fp==NULL){ perror("open key file error"); return -1; } rsa=PEM_read_RSAPrivateKey(fp,NULL,NULL,NULL); if(rsa==NULL){ perror("read key file error"); return -2; } fclose(fp); //获取RSA长度 rsa_len=RSA_private_decrypt(data_len,enc_data,decrypted,rsa,RSA_NO_PADDING); if(rsa_len==-1){ perror("RSA_private_decrypt error"); return -3; } RSA_free(rsa); return 0; } ### 回答2: RSA2是一种非对称密算法,常用于保护通信数据的安全性。JAVAC#都提供了RSA2算法的库和工具包,因此我们可以使用这两种编程语言来实现RSA2解密。 首先,我们需要生成一对RSA2密钥,包括公钥和私钥。在JAVA中,可以使用"KeyPairGenerator"类生成密钥对;在C#中,可以使用"RSACryptoServiceProvider"类生成密钥对。生成密钥对后,将公钥保存在一个地方,供密方使用,私钥则保密,供解密方使用。 在JAVA中,使用公钥对数据进行密的步骤如下: 1. 从存储的公钥文件中读取公钥。 2. 使用读取到的公钥初始化"Cipher"类的实例。 3. 将待密数据传入"update"方法中,并得到密后的字节数据。 4. 将密后的字节数据转换为Base64编码字符串,以保证数据的可读性。 在C#中,使用公钥对数据进行密的步骤如下: 1. 从存储的公钥文件中读取公钥。 2. 使用读取到的公钥初始化"RSACryptoServiceProvider"类的实例。 3. 将待密数据转换为字节数组。 4. 调用"Encrypt"方法,传入待密的字节数组,并得到密后的字节数组。 解密的步骤在两种语言中是类似的,都是使用私钥对密后的数据进行解密。首先,要从存储的私钥文件中读取私钥,然后使用私钥对密后的数据进行解密解密后的数据就是原始数据。 总结一下,JAVAC#都可以实现RSA2解密通用。在JAVA中,使用"KeyPairGenerator"和"Cipher"类实现;在C#中,可以使用"RSACryptoServiceProvider"类实现。关键是要确保公钥和私钥的生成和存储方式一致,以及解密方正确使用私钥解密密后的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值