在使用过程中,直接将被类引入到项目中即可,不需要其它辅助类。

使用示例:  将此通用类的头文件引入到目标类后,直接使用类名进行调用即可。

NSString *str = [NSString stringWithFormat:@"YWE="]; 
  NSString *str1 = [NSString stringWithFormat:@"aa"]; 
  NSLog(@"resultStr========%@",[CommonFunc textFromBase64String:str]);  //使用类名进行调用 
  NSLog(@"resultStr=========%@",[CommonFunc base64StringFromText:str1]); //使用类名进行调用 

源码下载:

在项目中遇到字符串的base64编解码,分享一下工具类:

JKCommonFunc.h

#define __BASE64( text )    [CommonFunc base64StringFromText:text] 
#define __TEXT( base64 )    [CommonFunc textFromBase64String:base64] 
#import <Foundation/Foundation.h> 
@interface JKCommonFunc : NSObject 
/****************************************************************************** 
 函数名称 :   (NSString *)base64StringFromText:(NSString *)text 
 函数描述 : 将文本转换为base64格式字符串 
 输入参数 : (NSString *)text  文本 
 输出参数 : N/A 
 返回参数 : (NSString *)  base64格式字符串 
 备注信息 : 
 ******************************************************************************/ 
  (NSString *)base64StringFromText:(NSString *)text; 
/****************************************************************************** 
 函数名称 :   (NSString *)textFromBase64String:(NSString *)base64 
 函数描述 : 将base64格式字符串转换为文本 
 输入参数 : (NSString *)base64 base64格式字符串 
 输出参数 : N/A 
 返回参数 : (NSString *)  文本 
 备注信息 : 
 ******************************************************************************/ 
  (NSString *)textFromBase64String:(NSString *)base64; 
@end 

JKCommonFunc.m

#import "CommonFunc.h"    
//引入IOS自带密码库  
#import <CommonCrypto/CommonCryptor.h>  
//空字符串  
#define   LocalStr_None      @""  
static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789 /";  
@implementation CommonFunc  
  (NSString *)base64StringFromText:(NSString *)text  
{  
  if (text && ![text isEqualToString:LocalStr_None]) {  
    //取项目的bundleIdentifier作为KEY 改动了此处 
    //NSString *key = [[NSBundle mainBundle] bundleIdentifier];  
    NSData *data = [text dataUsingEncoding:NSUTF8StringEncoding];  
    //IOS 自带DES加密 Begin 改动了此处 
    //data = [self DESEncrypt:data WithKey:key];  
    //IOS 自带DES加密 End  
    return [self base64EncodedStringFrom:data];  
  }  
  else {  
    return LocalStr_None;  
  }  
}  
  (NSString *)textFromBase64String:(NSString *)base64  
{  
  if (base64 && ![base64 isEqualToString:LocalStr_None]) {  
    //取项目的bundleIdentifier作为KEY  改动了此处 
    //NSString *key = [[NSBundle mainBundle] bundleIdentifier];  
    NSData *data = [self dataWithBase64EncodedString:base64];  
    //IOS 自带DES解密 Begin  改动了此处 
    //data = [self DESDecrypt:data WithKey:key];   
    //IOS 自带DES加密 End  
    return [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];  
  }  
  else {  
    return LocalStr_None;  
  }  
}  
/****************************************************************************** 
 函数名称 :   (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key 
 函数描述 : 文本数据进行DES加密 
 输入参数 : (NSData *)data   
     (NSString *)key 
 输出参数 : N/A 
 返回参数 : (NSData *) 
 备注信息 : 此函数不可用于过长文本 
 ******************************************************************************/  
  (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key  
{  
  char keyPtr[kCCKeySizeAES256 1];  
  bzero(keyPtr, sizeof(keyPtr));  
  [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
  NSUInteger dataLength = [data length];  
  size_t bufferSize = dataLength   kCCBlockSizeAES128;  
  voidvoid *buffer = malloc(bufferSize);  
  size_t numBytesEncrypted = 0;  
  CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,  
                     kCCOptionPKCS7Padding | kCCOptionECBMode,  
                     keyPtr, kCCBlockSizeDES,  
                     NULL,  
                     [data bytes], dataLength,  
                     buffer, bufferSize,  
                     &numBytesEncrypted);  
  if (cryptStatus == kCCSuccess) {  
    return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];  
  }  
  free(buffer);  
  return nil;  
}  
/****************************************************************************** 
 函数名称 :   (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key 
 函数描述 : 文本数据进行DES解密 
 输入参数 : (NSData *)data 
     (NSString *)key 
 输出参数 : N/A 
 返回参数 : (NSData *) 
 备注信息 : 此函数不可用于过长文本 
 ******************************************************************************/  
  (NSData *)DESDecrypt:(NSData *)data WithKey:(NSString *)key  
{  
  char keyPtr[kCCKeySizeAES256 1];  
  bzero(keyPtr, sizeof(keyPtr));  
  [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
  NSUInteger dataLength = [data length];  
  size_t bufferSize = dataLength   kCCBlockSizeAES128;  
  voidvoid *buffer = malloc(bufferSize);  
  size_t numBytesDecrypted = 0;  
  CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmDES,  
                     kCCOptionPKCS7Padding | kCCOptionECBMode,  
                     keyPtr, kCCBlockSizeDES,  
                     NULL,  
                     [data bytes], dataLength,  
                     buffer, bufferSize,  
                     &numBytesDecrypted);  
  if (cryptStatus == kCCSuccess) {  
    return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];  
  }  
  free(buffer);  
  return nil;  
}  
/****************************************************************************** 
 函数名称 :   (NSData *)dataWithBase64EncodedString:(NSString *)string 
 函数描述 : base64格式字符串转换为文本数据 
 输入参数 : (NSString *)string 
 输出参数 : N/A 
 返回参数 : (NSData *) 
 备注信息 : 
 ******************************************************************************/  
  (NSData *)dataWithBase64EncodedString:(NSString *)string  
{  
  if (string == nil)  
    [NSException raise:NSInvalidArgumentException format:nil];  
  if ([string length] == 0)  
    return [NSData data];  
  static charchar *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 charchar *characters = [string cStringUsingEncoding:NSASCIIStringEncoding];  
  if (characters == NULL)   // Not an ASCII string!  
    return nil;  
  charchar *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 
 函数描述 : 文本数据转换为base64格式字符串 
 输入参数 : (NSData *)data 
 输出参数 : N/A 
 返回参数 : (NSString *) 
 备注信息 :  
 ******************************************************************************/  
  (NSString *)base64EncodedStringFrom:(NSData *)data  
{  
  if ([data length] == 0)  
    return @"";  
  charchar *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  ] = ((charchar *)[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  

iOS base64 加密解密 通用类实例代码的更多相关文章

  1. 使用canvas压缩图片大小的方法示例

    这篇文章主要介绍了使用canvas压缩图片大小的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. 手对手的教你用canvas画一个简单的海报的方法示例

    企业的广告投入开始从电视等传统媒体向基于圈层文化的新媒体精准营销转移,很多人都想制作一张属于自己的海报,本文介绍了手对手的教你用canvas画一个简单的海报的方法示例,感兴趣的可以了解一下

  3. 浅谈移动端网页图片预加载方案

    这篇文章主要介绍了浅谈移动端网页图片预加载方案 的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  4. html5 canvas合成海报所遇问题及解决方案总结

    这篇文章主要介绍了html5 canvas合成海报所遇问题及解决方案总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  5. 使用html2canvas实现将html内容写入到canvas中生成图片

    这篇文章主要介绍了使用html2canvas实现将html内容写入到canvas中生成图片,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  6. Canvas与图片压缩的示例代码

    本篇文章主要介绍了Canvas与图片压缩的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. web字体加载方案优化小结

    这篇文章主要介绍了web字体加载方案优化小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  8. HTML5在微信内置浏览器下右上角菜单的调整字体导致页面显示错乱的问题

    HTML5在微信内置浏览器下,在右上角菜单的调整字体导致页面显示错乱的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

  9. iOS实现拖拽View跟随手指浮动效果

    这篇文章主要为大家详细介绍了iOS实现拖拽View跟随手指浮动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. ios – containerURLForSecurityApplicationGroupIdentifier:在iPhone和Watch模拟器上给出不同的结果

    我使用默认的XCode模板创建了一个WatchKit应用程序.我向iOSTarget,WatchkitAppTarget和WatchkitAppExtensionTarget添加了应用程序组权利.(这是应用程序组名称:group.com.lombax.fiveminutes)然后,我尝试使用iOSApp和WatchKitExtension访问共享文件夹URL:延期:iOS应用:但是,测试NSURL

随机推荐

  1. iOS实现拖拽View跟随手指浮动效果

    这篇文章主要为大家详细介绍了iOS实现拖拽View跟随手指浮动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  2. iOS – genstrings:无法连接到输出目录en.lproj

    使用我桌面上的项目文件夹,我启动终端输入:cd然后将我的项目文件夹拖到终端,它给了我路径.然后我将这行代码粘贴到终端中找.-name*.m|xargsgenstrings-oen.lproj我在终端中收到此错误消息:genstrings:无法连接到输出目录en.lproj它多次打印这行,然后说我的项目是一个目录的路径?没有.strings文件.对我做错了什么的想法?

  3. iOS 7 UIButtonBarItem图像没有色调

    如何确保按钮图标采用全局色调?解决方法只是想将其转换为根注释,以便为“回答”复选标记提供更好的上下文,并提供更好的格式.我能想出这个!

  4. ios – 在自定义相机层的AVFoundation中自动对焦和自动曝光

    为AVFoundation定制图层相机创建精确的自动对焦和曝光的最佳方法是什么?

  5. ios – Xcode找不到Alamofire,错误:没有这样的模块’Alamofire’

    我正在尝试按照github(https://github.com/Alamofire/Alamofire#cocoapods)指令将Alamofire包含在我的Swift项目中.我创建了一个新项目,导航到项目目录并运行此命令sudogeminstallcocoapods.然后我面临以下错误:搜索后我设法通过运行此命令安装cocoapodssudogeminstall-n/usr/local/bin

  6. ios – 在没有iPhone6s或更新的情况下测试ARKit

    我在决定下载Xcode9之前.我想玩新的框架–ARKit.我知道要用ARKit运行app我需要一个带有A9芯片或更新版本的设备.不幸的是我有一个较旧的.我的问题是已经下载了新Xcode的人.在我的情况下有可能运行ARKit应用程序吗?那个或其他任何模拟器?任何想法或我将不得不购买新设备?解决方法任何iOS11设备都可以使用ARKit,但是具有高质量AR体验的全球跟踪功能需要使用A9或更高版本处理器的设备.使用iOS11测试版更新您的设备是必要的.

  7. 将iOS应用移植到Android

    我们制作了一个具有2000个目标c类的退出大型iOS应用程序.我想知道有一个最佳实践指南将其移植到Android?此外,由于我们的应用程序大量使用UINavigation和UIView控制器,我想知道在Android上有类似的模型和实现.谢谢到目前为止,guenter解决方法老实说,我认为你正在计划的只是制作难以维护的糟糕代码.我意识到这听起来像很多工作,但从长远来看它会更容易,我只是将应用程序的概念“移植”到android并从头开始编写.

  8. ios – 在Swift中覆盖Objective C类方法

    我是Swift的初学者,我正在尝试在Swift项目中使用JSONModel.我想从JSONModel覆盖方法keyMapper,但我没有找到如何覆盖模型类中的Objective-C类方法.该方法的签名是:我怎样才能做到这一点?解决方法您可以像覆盖实例方法一样执行此操作,但使用class关键字除外:

  9. ios – 在WKWebView中获取链接URL

    我想在WKWebView中获取tapped链接的url.链接采用自定义格式,可触发应用中的某些操作.例如HTTP://我的网站/帮助#深层链接对讲.我这样使用KVO:这在第一次点击链接时效果很好.但是,如果我连续两次点击相同的链接,它将不报告链接点击.是否有解决方法来解决这个问题,以便我可以检测每个点击并获取链接?任何关于这个的指针都会很棒!解决方法像这样更改addobserver在observeValue函数中,您可以获得两个值

  10. ios – 在Swift的UIView中找到UILabel

    我正在尝试在我的UIViewControllers的超级视图中找到我的UILabels.这是我的代码:这是在Objective-C中推荐的方式,但是在Swift中我只得到UIViews和CALayer.我肯定在提供给这个方法的视图中有UILabel.我错过了什么?我的UIViewController中的调用:解决方法使用函数式编程概念可以更轻松地实现这一目标.

返回
顶部