美文网首页
iOS&JAVA AES加密解密

iOS&JAVA AES加密解密

作者: 满庭花醉三千客 | 来源:发表于2019-10-30 17:08 被阅读0次

AES加密与解密,iOS端代码:
AESCipher.h文件

#import <Foundation/Foundation.h>

@interface AESCipher : NSObject

+(NSString*)aesEncryptString:(NSString *)content;

+(NSString*)aesDecryptString:(NSString*)content;

+(NSString *)aesEncryptString:(NSString *)content withKey:(NSString *)key withIv:(NSString*)iv;

+(NSString *)aesDecryptString:(NSString *)content withKey:(NSString *)key withIv:(NSString*)iv;

@end

AESCipher.m文件:

//
//  AESCipher.m
//  WLPoetryProject
//
//  Created by 变啦 on 2019/10/30.
//  Copyright © 2019 龙培. All rights reserved.
//

#import "AESCipher.h"
#import <CommonCrypto/CommonCryptor.h>
@implementation AESCipher

static NSString *publicKey = @"12345678876543211234567887654321";
static NSString *publicIv = @"8888777766665544";

+(NSString *)aesEncryptString:(NSString *)content{
    return [self aesEncryptString:content withKey:publicKey withIv:publicIv];
}
+(NSString *)aesDecryptString:(NSString *)content{
    return [self aesDecryptString:content withKey:publicKey withIv:publicIv];
}

+(NSString *)aesEncryptString:(NSString *)content withKey:(NSString *)key withIv:(NSString*)iv{
    NSData *contentData = [content dataUsingEncoding:NSUTF8StringEncoding];
    NSData *keyData = [key dataUsingEncoding:NSUTF8StringEncoding];
    NSData *ivData = [iv dataUsingEncoding:NSUTF8StringEncoding];
    NSData *encrptData = [self aesEncryptData:contentData withKey:keyData withIv:ivData];
    return [encrptData base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithLineFeed];
}

+(NSString *)aesDecryptString:(NSString *)content withKey:(NSString *)key withIv:(NSString*)iv {
    NSData *contentData = [[NSData alloc] initWithBase64EncodedString:content options:NSDataBase64DecodingIgnoreUnknownCharacters];
    NSData *keyData = [key dataUsingEncoding:NSUTF8StringEncoding];
    NSData *ivData = [iv dataUsingEncoding:NSUTF8StringEncoding];
    NSData *decryptedData = [self aesDecryptData:contentData withKey:keyData withIv:ivData];
    return [[NSString alloc] initWithData:decryptedData encoding:NSUTF8StringEncoding];
}

+(NSData *)aesEncryptData:(NSData *)contentData withKey:(NSData *)keyData withIv:(NSData*)ivData {
    return [self cipherAction:contentData withKey:keyData withIv:ivData withOperation:kCCEncrypt];
}

+(NSData *)aesDecryptData:(NSData *)contentData withKey:(NSData *)keyData withIv:(NSData*)ivData {
    return [self cipherAction:contentData withKey:keyData withIv:ivData withOperation:kCCDecrypt];
}


+(NSData *) cipherAction:(NSData *)contentData withKey:(NSData *)keyData withIv:(NSData*)ivData withOperation:(CCOperation) operation{
    NSUInteger dataLength = contentData.length;
    
    void const *ivBytes = ivData.bytes;
    void const *contentBytes = contentData.bytes;
    void const *keyBytes = keyData.bytes;
    
    size_t bufferSize = dataLength + kCCKeySizeAES256;
    void *buffer = malloc(bufferSize);
    size_t numBytesEncrypted = 0;
    
    CCCryptorStatus cryptStatus = CCCrypt(operation,
                                          kCCAlgorithmAES,
                                          kCCOptionPKCS7Padding,
                                          keyBytes,
                                          kCCKeySizeAES256,
                                          ivBytes,
                                          contentBytes,
                                          dataLength,
                                          buffer,
                                          bufferSize,
                                          &numBytesEncrypted);
    
    if (cryptStatus == kCCSuccess) {
        return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
    }
    free(buffer);
    return nil;
}

@end

iOS端调用:


iOS端调用

效果:


iOS端效果

可以得知我们可以顺利解密,且加密得到的值为:klswbkdjrFj8auI1/9K5DQ==

接下来是Java端,AESHelper.java文件:

package com.wql.utils.security;

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;

public class AESHelper {

    private static final String keyString = "12345678876543211234567887654321";
    private static final String ivString = "8888777766665544";
    private static final String charset = "UTF-8";

    public static String encryptString(String content){
        try {
            byte[] contentBytes = content.getBytes(charset);
            byte[] keyBytes = keyString.getBytes(charset);

            byte[] encryptData = cipherAction(contentBytes,keyBytes,Cipher.ENCRYPT_MODE);

            byte[] base64Bytes = Base64.getEncoder().encode(encryptData);
            return new String(base64Bytes,charset);

        }catch (Exception e){
            e.printStackTrace();
        }
        return "";
    }

    public static String decryptString(String encryptString){
        try {
            byte[] decryptBytes = Base64.getDecoder().decode(encryptString);
            byte[] keyBytes = keyString.getBytes(charset);

            byte[] decryptData = cipherAction(decryptBytes,keyBytes,Cipher.DECRYPT_MODE);
            return new String(decryptData,charset);

        }catch (Exception e){
            e.printStackTrace();
        }
        return "";

    }


    private static byte[] cipherAction(byte[] contentBytes, byte[] keyBytes, int mode) {
        try {
            SecretKeySpec secretKey = new SecretKeySpec(keyBytes, "AES");
            byte[] initParam = ivString.getBytes(charset);
            IvParameterSpec ivParameterSpec = new IvParameterSpec(initParam);

            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
            cipher.init(mode, secretKey, ivParameterSpec);

            return cipher.doFinal(contentBytes);
        }catch (Exception e){
            e.printStackTrace();
        }
        return null;
    }

    public static void main(String[] args) {
        String enString = AESHelper.encryptString("王啟龙");
        String deString = AESHelper.decryptString(enString);

        System.out.println("加密后:"+enString+"\n解密后:"+deString);
    }

}

Java端运行效果:


Java端加密与解密效果

可以得知我们在Java端顺利解密,且加密得到的值为:klswbkdjrFj8auI1/9K5DQ==
与iOS端的加密结果一致。
由此可以得出结果:iOS端加密,Java端解密可以成功的。Java端加密,iOS端解密也是可以成功的。

代码在这里(另含iOS端RSA加解密、验签;Java端RSA加解密、验签)

加油~

相关文章

网友评论

      本文标题:iOS&JAVA AES加密解密

      本文链接:https://www.haomeiwen.com/subject/ukaovctx.html