IOS AES加密之ECB128模式

1、AES加密模式有好几种,网上大多是CBC、256模式,找了好久才找到解决ECB128模式加密。

AES需要导入头文件

#import <CommonCrypto/CommonCryptor.h>

#import "GTMBase64.h" //加密后的数据在Base64转字符串类型

+(NSString *)AES128Encrypt:(NSString *)plainText key:(NSString *)key
{
    char keyPtr[kCCKeySizeAES128+1];
    memset(keyPtr, 0, sizeof(keyPtr));
    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];

    NSData* data = [plainText dataUsingEncoding:NSUTF8StringEncoding];
    NSUInteger dataLength = [data length];

    size_t bufferSize = dataLength + kCCBlockSizeAES128;
    void *buffer = malloc(bufferSize);
    size_t numBytesEncrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,
                                          kCCAlgorithmAES128,
                                          kCCOptionPKCS7Padding|kCCOptionECBMode,
                                          keyPtr,
                                          kCCBlockSizeAES128,
                                          NULL,
                                          [data bytes],
                                          dataLength,
                                          buffer,
                                          bufferSize,
                                          &numBytesEncrypted);
    if (cryptStatus == kCCSuccess) {
        NSData *resultData = [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
        return [GTMBase64 stringByEncodingData:resultData];
    }
    free(buffer);
    return nil;
}

直接放 Demo: AES/ECB模式128Demo下载 密码:qj57

时间: 2024-07-31 14:22:13

IOS AES加密之ECB128模式的相关文章

AES加密,CBC模式,0填充

java的aes加密的CBC模式只有NoPadding,PKCS5Padding,PKCS7Padding,因此0填充需要手动更改 public static byte[] encrypt(byte[] data, byte[] iv, byte[] key) { if(key.length != 16) { throw new RuntimeException("Invalid AES key length (must be 16 bytes)"); } else { try { S

IOS AES加密

AES GitHub 下载地址:https://github.com/Gurpartap/AESCrypt-ObjC AES支持密钥128位,192位,256位(常用的是128位 md5, 256位 sha256) 工作模式:ECB/CBC,默认情况下iOS是CBC的 iOS在设置加密参数的时候要添加参数 kCCOptionECBMode 填充方式:kCCOptionPKCS7Padding,iOS似乎只支持这样的填充方式,所以要引用第三方包bouncycastle (www.bouncycas

IOS AES加密 第三方库

数据加密在解密在软件开发过程中举足轻重的作用,可能有的公司在加密的时候有自己公司内部一套设计的算法,而在这方面不想浪费太大精力就可以去考虑使用第三方提供的加密算法,如AES加密算法,本篇内容介绍开源中国iOS客户端使用ASE算法加密密码: AES   GitHub 下载地址  https://github.com/Gurpartap/AESCrypt-ObjC 对一个比较大的工程我们可能都不知道某个类库或者方法在哪被使用,但是智能的Xcode给我们提供了一个全局搜索的功能,我们可以在真个工程中来

iOS AES加密解密实现方法

使用方法 先导入头文件 #import "NSData+AES.h" //AES测试 //用来密钥 NSString *key = @"123456"; //用来发送的原始数据 NSString *secret = @"I Love You"; //数据转码 NSData *plain = [secret dataUsingEncoding:NSUTF8StringEncoding]; //用密钥加密 NSData *cipher = [plai

ios AES 加密

AES   GitHub 下载地址  https://github.com/Gurpartap/AESCrypt-ObjC 官方文档 Add this line to your class: #import "AESCrypt.h" Usage NSString *message = @"top secret message"; // message 为加密字符串 与密码混合加密 NSString *password = @"p4ssw0rd";

python 实现aes加密解密 ecb模式和其他模式

ecb模式:(这种不需要偏移向量iv,安全性较低,代码出处忘了) # -*- coding=utf-8-*- from Crypto.Cipher import AES import os from Crypto import Random import base64 from Crypto.Cipher import AES from binascii import b2a_hex, a2b_hex """ aes加密算法 ECB模式 """

有关AES加密的问题

遇到一个项目,需要用AES加密密码,android的已经写好了,java源码: private static final String AES_OPTIONS = "AES/ECB/PKCS5Padding"; private final static String CHARSET = "utf-8"; public static String encryptAES(String plain, String key) { try { Cipher cipher =

AES加密CBC模式 IOS - Java 互通共用

AES加密模式和填充方式 算法/模式/填充                16字节加密后数据长度        不满16字节加密后长度AES/CBC/NoPadding             16                          不支持AES/CBC/PKCS5Padding          32                          16AES/CBC/ISO10126Padding       32                          16AE

.NET/andriod/java/iOS AES通用加密解密

移动端越来越火了,我们在开发过程中,总会碰到要和移动端打交道的场景,比如.NET和android或者iOS的打交道.为了让数据交互更安全,我们需要对数据进行加密传输.今天研究了一下,把几种语言的加密都实践了一遍,实现了.NET,java(andriod),iOS都同一套的加密算法,下面就分享给大家. AES加密有多种算法模式,下面提供两套模式的可用源码. 加密方式: 先将文本AES加密 返回Base64转码 解密方式: 将数据进行Base64解码 进行AES解密 一.CBC(Cipher Blo