兴趣iOS

iOS下的加密

2016-12-06  本文已影响61人  沧海的风

二话不说,先上Demohttps://github.com/haidumou/CZHEncryption

RSA加密

RSA使用"秘匙对"对数据进行加密解密.在加密解密数据前,需要先生成公钥(public key)和私钥(private key).

iOS中的Security.framework提供了对RSA算法的支持.这种方式需要对密匙对进行处理, 根据public key生成证书, 通过private key生成p12格式的密匙.除了Secruty.framework, 也可以将openssl库编译到iOS工程中, 这可以提供更灵活的使用方式.
本文使用Security.framework的方式处理RSA.

RSA加密需要了解的几点:

DES加解密

const Byte iv[] = {1,2,3,4,5,6,7,8};
/*加密/
+ (NSString *)DESEncrypt:(NSString *)plainText key:(NSString *)key
{
NSString *ciphertext = nil;
NSData *textData = [plainText dataUsingEncoding:NSUTF8StringEncoding];
NSUInteger dataLength = [textData length];
size_t bufferSize = dataLength + kCCBlockSizeDES;
void *buffer = malloc(bufferSize);
memset(buffer, 0, sizeof(char));
size_t numBytesEncrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
kCCOptionPKCS7Padding,
[key UTF8String], kCCKeySizeDES,
iv,
[textData bytes], dataLength,
buffer, bufferSize,
&numBytesEncrypted);
if (cryptStatus == kCCSuccess) {
NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
ciphertext = [data base64EncodedString];
}
return ciphertext;
}

AES加解密

  /**加密*/
  - (NSString *)AES256Encrypt:(NSString *)key
  {
      const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
      NSData *data = [NSData dataWithBytes:cstr length:self.length];
      //对数据进行加密
      NSData *result = [data AES256Encrypt:key];

      //转换为2进制字符串
      if (result && result.length > 0) {
         Byte *datas = (Byte*)[result bytes];
          NSMutableString *output = [NSMutableString stringWithCapacity:result.length * 2];
          for(int i = 0; i < result.length; i++){
              [output appendFormat:@"%02x", datas[i]];
          }
          return output;
      }
      return nil;
  }

MD5加密

  - (NSString *)stringToMD5
  {
      const char *fooData = [self UTF8String];
      unsigned char result[CC_MD5_DIGEST_LENGTH];
      //计算MD5的值, 这是官方封装好的加密方法:把我们输入的字符串转换成16进制的32位数,然后存储到result中
      CC_MD5(fooData, (CC_LONG)strlen(fooData), result);
      /**
       第一个参数:要加密的字符串
       第二个参数: 获取要加密字符串的长度
       第三个参数: 接收结果的数组
       */

      NSMutableString *saveResult = [NSMutableString string];
      for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
          [saveResult appendFormat:@"%02x", result[i]];
      }
      /*
       x表示十六进制,%02X  意思是不足两位将用0补齐,如果多余两位则不影响
        NSLog("%02X", 0x888);  //888
       NSLog("%02X", 0x4); //04
       */
      return saveResult;
  }
屏幕快照 2016-12-06 下午5.22.14.png
上一篇 下一篇

猜你喜欢

热点阅读