LPSecureData.m 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. //
  2. // LPSecureData.m
  3. // zhimi
  4. //
  5. // Created by 张灿 on 2019/1/22.
  6. // Copyright © 2019年 caiPro. All rights reserved.
  7. //
  8. #import "LPSecureData.h"
  9. #import <CommonCrypto/CommonCryptor.h>
  10. #define LocalStr_None @""
  11. //#define AESKEYVALUE @"!IQ31NeGcV&*n6w="
  12. #define AESKEYVALUE @"JANp_XpXL^&1c47l"
  13. static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  14. @implementation LPSecureData
  15. + (NSString*)getRadomStr:(int)count{
  16. NSString *string = [[NSString alloc]init];
  17. for (int i = 0; i < count; i++) {
  18. int number = arc4random() % 36;
  19. if (number < 10) {
  20. int figure = arc4random() % 10;
  21. NSString *tempString = [NSString stringWithFormat:@"%d", figure];
  22. string = [string stringByAppendingString:tempString];
  23. }else {
  24. int figure = (arc4random() % 26) + 97;
  25. char character = figure;
  26. NSString *tempString = [NSString stringWithFormat:@"%c", character];
  27. string = [string stringByAppendingString:tempString];
  28. }
  29. }
  30. NSLog(@"%@", string);
  31. return string;
  32. }
  33. //将字典进行AES128加密
  34. + (NSString*)setSecureWithDict:(NSDictionary*)dict{
  35. NSString* jsonStr = [dict mj_JSONString];
  36. // NSString* newStr = [jsonStr stringByAppendingString:[self getRadomStr:4]];
  37. NSData *data = [jsonStr dataUsingEncoding:NSUTF8StringEncoding];
  38. NSData* aesdata = [self AES128operation:kCCEncrypt data:data key:AESKEYVALUE iv:AESKEYVALUE];
  39. NSLog(@"加密后的字符串为%@",[self base64EncodedStringFrom:aesdata]);
  40. return [self base64EncodedStringFrom:aesdata];
  41. }
  42. //将字符串解密为字典
  43. + (NSDictionary*)getDictWithSecureString:(NSString*)str{
  44. NSData *data = [self dataWithBase64EncodedString:str];
  45. NSData *aesData = [self AES128operation:kCCDecrypt
  46. data:data
  47. key:AESKEYVALUE
  48. iv:AESKEYVALUE];
  49. NSDictionary* dict = [aesData mj_JSONObject];
  50. return dict;
  51. }
  52. + (NSData *)AES128operation:(CCOperation)operation data:(NSData *)data key:(NSString *)key iv:(NSString *)iv {
  53. char keyPtr[kCCKeySizeAES128 + 1]; //kCCKeySizeAES128是加密位数 可以替换成256位的
  54. bzero(keyPtr, sizeof(keyPtr));
  55. [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
  56. // IV
  57. char ivPtr[kCCBlockSizeAES128 + 1];
  58. bzero(ivPtr, sizeof(ivPtr));
  59. [iv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding];
  60. size_t bufferSize = [data length] + kCCBlockSizeAES128;
  61. void *buffer = malloc(bufferSize);
  62. size_t numBytesEncrypted = 0;
  63. CCCryptorStatus cryptorStatus = CCCrypt(operation, kCCAlgorithmAES128, kCCOptionPKCS7Padding|kCCOptionECBMode,
  64. keyPtr, kCCKeySizeAES128,
  65. ivPtr,
  66. [data bytes], [data length],
  67. buffer, bufferSize,
  68. &numBytesEncrypted);
  69. if(cryptorStatus == kCCSuccess) {
  70. NSLog(@"Success");
  71. return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
  72. } else {
  73. NSLog(@"Error");
  74. }
  75. free(buffer);
  76. return nil;
  77. }
  78. //base64字符串转二进制
  79. + (NSData *)dataWithBase64EncodedString:(NSString *)string{
  80. if (string == nil)
  81. return [NSData data];
  82. if ([string length] == 0)
  83. return [NSData data];
  84. static char *decodingTable = NULL;
  85. if (decodingTable == NULL)
  86. {
  87. decodingTable = malloc(256);
  88. if (decodingTable == NULL)
  89. return nil;
  90. memset(decodingTable, CHAR_MAX, 256);
  91. NSUInteger i;
  92. for (i = 0; i < 64; i++)
  93. decodingTable[(short)encodingTable[i]] = i;
  94. }
  95. const char *characters = [string cStringUsingEncoding:NSASCIIStringEncoding];
  96. if (characters == NULL) // Not an ASCII string!
  97. return nil;
  98. char *bytes = malloc((([string length] + 3) / 4) * 3);
  99. if (bytes == NULL)
  100. return nil;
  101. NSUInteger length = 0;
  102. NSUInteger i = 0;
  103. while (YES)
  104. {
  105. char buffer[4];
  106. short bufferLength;
  107. for (bufferLength = 0; bufferLength < 4; i++)
  108. {
  109. if (characters[i] == '\0')
  110. break;
  111. if (isspace(characters[i]) || characters[i] == '=')
  112. continue;
  113. buffer[bufferLength] = decodingTable[(short)characters[i]];
  114. if (buffer[bufferLength++] == CHAR_MAX) // Illegal character!
  115. {
  116. free(bytes);
  117. return nil;
  118. }
  119. }
  120. if (bufferLength == 0)
  121. break;
  122. if (bufferLength == 1) // At least two characters are needed to produce one byte!
  123. {
  124. free(bytes);
  125. return nil;
  126. }
  127. // Decode the characters in the buffer to bytes.
  128. bytes[length++] = (buffer[0] << 2) | (buffer[1] >> 4);
  129. if (bufferLength > 2)
  130. bytes[length++] = (buffer[1] << 4) | (buffer[2] >> 2);
  131. if (bufferLength > 3)
  132. bytes[length++] = (buffer[2] << 6) | buffer[3];
  133. }
  134. bytes = realloc(bytes, length);
  135. return [NSData dataWithBytesNoCopy:bytes length:length];
  136. }
  137. //NSData转base64字符串
  138. + (NSString *)base64EncodedStringFrom:(NSData *)data{
  139. if ([data length] == 0)
  140. return @"";
  141. char *characters = malloc((([data length] + 2) / 3) * 4);
  142. if (characters == NULL)
  143. return nil;
  144. NSUInteger length = 0;
  145. NSUInteger i = 0;
  146. while (i < [data length])
  147. {
  148. char buffer[3] = {0,0,0};
  149. short bufferLength = 0;
  150. while (bufferLength < 3 && i < [data length])
  151. buffer[bufferLength++] = ((char *)[data bytes])[i++];
  152. // Encode the bytes in the buffer to four characters, including padding "=" characters if necessary.
  153. characters[length++] = encodingTable[(buffer[0] & 0xFC) >> 2];
  154. characters[length++] = encodingTable[((buffer[0] & 0x03) << 4) | ((buffer[1] & 0xF0) >> 4)];
  155. if (bufferLength > 1)
  156. characters[length++] = encodingTable[((buffer[1] & 0x0F) << 2) | ((buffer[2] & 0xC0) >> 6)];
  157. else characters[length++] = '=';
  158. if (bufferLength > 2)
  159. characters[length++] = encodingTable[buffer[2] & 0x3F];
  160. else characters[length++] = '=';
  161. }
  162. return [[NSString alloc] initWithBytesNoCopy:characters length:length encoding:NSASCIIStringEncoding freeWhenDone:YES];
  163. }
  164. //普通字符串转base64
  165. + (NSString *)base64StringFromText:(NSString *)text {
  166. NSData *data = [text dataUsingEncoding:NSUTF8StringEncoding];
  167. NSString *base64String = [data base64EncodedStringWithOptions:0];
  168. return base64String;
  169. }
  170. //base64转普通字符串
  171. + (NSString *)textFromBase64String:(NSString *)base64 {
  172. if (!base64) { return @""; }
  173. NSData *data = [[NSData alloc] initWithBase64EncodedString:base64 options:0];
  174. NSString *text = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
  175. return text;
  176. }
  177. //将字符串解密为字符串
  178. + (NSString*)getStrWithSecureString:(NSString*)str {
  179. NSData *data = [self dataWithBase64EncodedString:str];
  180. NSData *aesData = [self AES128operation:kCCDecrypt
  181. data:data
  182. key:AESKEYVALUE
  183. iv:AESKEYVALUE];//AES解密
  184. NSString *base64 = [[NSString alloc] initWithData:aesData encoding:NSUTF8StringEncoding];
  185. if (!base64) {
  186. NSLog(@"AES加密解析失败");
  187. return @"";
  188. }
  189. NSData *base64Data = [[NSData alloc] initWithBase64EncodedString:base64 options:0];//base64解密
  190. NSString *text = [[NSString alloc] initWithData:base64Data encoding:NSUTF8StringEncoding];
  191. return text;
  192. }
  193. @end