IOS开发---菜鸟学习之路--(十四)-将BASE64图片转换成Image

简介: 本文基本全部都是代码 首先是.H文件 1 #import 2 3 @interface Base64AndImageHelp : NSObject 4 - (NSString*)encodeURL:(NSString *)string; 5 +(id)mydataWithBas...

本文基本全部都是代码

首先是.H文件

1 #import <Foundation/Foundation.h>
2 
3 @interface Base64AndImageHelp : NSObject
4 - (NSString*)encodeURL:(NSString *)string;
5 +(id)mydataWithBase64EncodedString:(NSString *)string ;
6 @end
Base64AndImageHelp.h

然后是.M文件

  1 #import "Base64AndImageHelp.h"
  2 @interface NSData (MBBase64)
  3 
  4 + (id)dataWithBase64EncodedString:(NSString *)string;
  5 - (NSString *)base64Encoding;
  6 
  7 @end
  8 static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  9 
 10 @implementation NSData (MBBase64)
 11 
 12 + (id)dataWithBase64EncodedString:(NSString *)string {
 13     if (string == nil)
 14         [NSException raise:NSInvalidArgumentException format:@""];
 15     
 16     if ([string length] == 0)
 17         return [NSData data];
 18     
 19     static char *decodingTable = NULL;
 20     
 21     if (decodingTable == NULL) {
 22         decodingTable = malloc(256);
 23         if (decodingTable == NULL)
 24             return nil;
 25         memset(decodingTable, CHAR_MAX, 256);
 26         NSUInteger i;
 27         for (i = 0; i < 64; i++)
 28             decodingTable[(short)encodingTable[i]] = i;
 29     }
 30     
 31     const char *characters = [string cStringUsingEncoding:NSASCIIStringEncoding];
 32     if (characters == NULL)
 33         return nil;
 34     char *bytes = malloc((([string length] + 3) / 4) * 3);
 35     if (bytes == NULL)
 36         return nil;
 37     
 38     NSUInteger length = 0;
 39     NSUInteger i = 0;
 40     
 41     while (YES) {
 42         char buffer[4];
 43         short bufferLength;
 44         for (bufferLength = 0; bufferLength < 4; i++) {
 45             if (characters[i] == '\0')
 46                 break;
 47             if (isspace(characters[i]) || characters[i] == '=')
 48                 continue;
 49             buffer[bufferLength] = decodingTable[(short)characters[i]];
 50             if (buffer[bufferLength++] == CHAR_MAX) {
 51                 free(bytes);
 52                 return nil;
 53             }
 54         }
 55         
 56         if (bufferLength == 0)
 57             break;
 58         if (bufferLength == 1) {
 59             free(bytes);
 60             return nil;
 61         }
 62         
 63         bytes[length++] = (buffer[0] << 2) | (buffer[1] >> 4);
 64         if (bufferLength > 2)
 65             bytes[length++] = (buffer[1] << 4) | (buffer[2] >> 2);
 66         if (bufferLength > 3)
 67             bytes[length++] = (buffer[2] << 6) | buffer[3];
 68     }
 69     
 70     realloc(bytes, length);
 71     return [NSData dataWithBytesNoCopy:bytes length:length];
 72 }
 73 
 74 - (NSString *)base64Encoding {
 75     if ([self length] == 0)
 76         return @"";
 77     
 78     char *characters = malloc((([self length] + 2) / 3) * 4);
 79     if (characters == NULL)
 80         return nil;
 81     
 82     NSUInteger length = 0;
 83     NSUInteger i = 0;
 84     
 85     while (i < [self length]) {
 86         char buffer[3] = {0,0,0};
 87         short bufferLength = 0;
 88         while (bufferLength < 3 && i < [self length])
 89             buffer[bufferLength++] = ((char *)[self bytes])[i++];
 90         characters[length++] = encodingTable[(buffer[0] & 0xFC) >> 2];
 91         characters[length++] = encodingTable[((buffer[0] & 0x03) << 4) | ((buffer[1] & 0xF0) >> 4)];
 92         if (bufferLength > 1)
 93             characters[length++] = encodingTable[((buffer[1] & 0x0F) << 2) | ((buffer[2] & 0xC0) >> 6)];
 94         else characters[length++] = '=';
 95         if (bufferLength > 2)
 96             characters[length++] = encodingTable[buffer[2] & 0x3F];
 97         else characters[length++] = '=';
 98     }
 99     
100     return [[NSString alloc] initWithBytesNoCopy:characters length:length encoding:NSASCIIStringEncoding freeWhenDone:YES] ;
101 }
102 
103 @end
104 @implementation Base64AndImageHelp
105 - (NSString*)encodeURL:(NSString *)string
106 {
107     NSString *newString = (NSString *)CFBridgingRelease(CFURLCreateStringByAddingPercentEscapes( kCFAllocatorDefault, (CFStringRef)string, NULL, CFSTR(":/?#[]@!$ &'()*+,;=\"<>%{}|\\^~`"),kCFStringEncodingUTF8));
108     if (newString) {
109         return newString;
110     }
111     return @"";
112     
113     
114 }
115 + (id)mydataWithBase64EncodedString:(NSString *)string {
116     if (string == nil)
117         [NSException raise:NSInvalidArgumentException format:@""];
118     
119     if ([string length] == 0)
120         return [NSData data];
121     
122     static char *decodingTable = NULL;
123     
124     if (decodingTable == NULL) {
125         decodingTable = malloc(256);
126         if (decodingTable == NULL)
127             return nil;
128         memset(decodingTable, CHAR_MAX, 256);
129         NSUInteger i;
130         for (i = 0; i < 64; i++)
131             decodingTable[(short)encodingTable[i]] = i;
132     }
133     
134     const char *characters = [string cStringUsingEncoding:NSASCIIStringEncoding];
135     if (characters == NULL)
136         return nil;
137     char *bytes = malloc((([string length] + 3) / 4) * 3);
138     if (bytes == NULL)
139         return nil;
140     
141     NSUInteger length = 0;
142     NSUInteger i = 0;
143     
144     while (YES) {
145         char buffer[4];
146         short bufferLength;
147         for (bufferLength = 0; bufferLength < 4; i++) {
148             if (characters[i] == '\0')
149                 break;
150             if (isspace(characters[i]) || characters[i] == '=')
151                 continue;
152             buffer[bufferLength] = decodingTable[(short)characters[i]];
153             if (buffer[bufferLength++] == CHAR_MAX) {
154                 free(bytes);
155                 return nil;
156             }
157         }
158         
159         if (bufferLength == 0)
160             break;
161         if (bufferLength == 1) {
162             free(bytes);
163             return nil;
164         }
165         
166         bytes[length++] = (buffer[0] << 2) | (buffer[1] >> 4);
167         if (bufferLength > 2)
168             bytes[length++] = (buffer[1] << 4) | (buffer[2] >> 2);
169         if (bufferLength > 3)
170             bytes[length++] = (buffer[2] << 6) | buffer[3];
171     }
172     
173     realloc(bytes, length);
174     return [NSData dataWithBytesNoCopy:bytes length:length];
175 }
176 @end
Base64AndImageHelp.m

完成该类后就可以在其他类中使用了

NSData *newimage=[Base64AndImageHelp mydataWithBase64EncodedString:base64的STRING];

UIImage *newjiaban=[[UIImage alloc] initWithData:newimage];

ok这样就完成拉

目录
相关文章
|
7月前
|
存储 缓存 安全
基于iOS平台的高效图片缓存策略实现
【4月更文挑战第22天】 在移动应用开发中,图片资源的加载与缓存是影响用户体验的重要因素之一。尤其对于iOS平台,由于设备存储空间的限制以及用户对流畅性的高要求,设计一种合理的图片缓存策略显得尤为关键。本文将探讨在iOS环境下,如何通过使用先进的图片缓存技术,包括内存缓存、磁盘缓存以及网络请求的优化,来提高应用的性能和响应速度。我们将重点分析多级缓存机制的设计与实现,并对可能出现的问题及其解决方案进行讨论。
|
7月前
|
存储 缓存 算法
实现iOS平台的高效图片缓存策略
【4月更文挑战第22天】在移动应用开发中,图片资源的处理是影响用户体验的重要因素之一。特别是对于图像资源密集型的iOS应用,如何有效地缓存图片以减少内存占用和提升加载速度,是开发者们面临的关键挑战。本文将探讨一种针对iOS平台的图片缓存策略,该策略通过结合内存缓存与磁盘缓存的机制,并采用先进的图片解码和异步加载技术,旨在实现快速加载的同时,保持应用的内存效率。
|
7月前
|
存储 缓存 编解码
实现iOS平台的高效图片缓存策略
【4月更文挑战第23天】在移动应用开发领域,尤其是图像处理密集型的iOS应用中,高效的图片缓存策略对于提升用户体验和节省系统资源至关重要。本文将探讨一种针对iOS平台设计的图片缓存方案,该方案通过结合内存缓存与磁盘缓存的多层次结构,旨在优化图片加载性能并降低内存占用。我们将深入分析其设计理念、核心组件以及在实际场景中的应用效果,同时对比其他常见缓存技术的优势与局限。
|
5月前
|
前端开发 开发工具 Swift
学习iOS开发的准备
准备学习iOS开发?确保有Mac和最新Xcode,先学好编程基础特别是Swift。利用Apple官方文档、在线课程和书籍作为资源。熟悉Xcode及Git,通过实践项目和开源代码积累经验。深研架构模式、核心框架和优化技巧。加入开发者社区,关注行业动态,持续学习。
52 1
|
7月前
|
存储 Web App开发 Android开发
iOS不支持WebP格式图片解决方案和iPhone 7及其后硬件拍照的HEIC格式图片
iOS不支持WebP格式图片解决方案和iPhone 7及其后硬件拍照的HEIC格式图片
687 1
iOS不支持WebP格式图片解决方案和iPhone 7及其后硬件拍照的HEIC格式图片
|
7月前
按钮的image图片是非圆角,直接对UIButton设置圆角,iOS13系统没有圆角效果的问题及解决方案
按钮的image图片是非圆角,直接对UIButton设置圆角,iOS13系统没有圆角效果的问题及解决方案
52 0
|
7月前
|
存储 缓存 监控
实现iOS平台的高效图片缓存策略
【4月更文挑战第18天】在移动应用开发中,图片资源的加载与缓存是影响用户体验的重要因素之一。特别是对于iOS平台,合理设计图片缓存策略不仅能够提高应用的响应速度,还能降低内存消耗和网络流量。本文将探讨一种针对iOS环境的图片缓存方案,该方案通过多级缓存机制、内存管理和磁盘存储策略相结合,旨在提升图片加载效率并优化性能。
|
29天前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
6天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
87 66