一个实用的NSString分类工具(三) —— json与OC对象转换及加解密

版本记录

版本号 时间
V1.0 2017.12.16

前言

NSString是我们经常使用的一个类,但是苹果的API很多用起来不是那么方便,需要根据我们特殊需求进行个性化的改变和定制,接下来,我就写一个NSString分类工具,以后在使用的时候直接调用这个分类中的方法,可以实现很多小的功能,用起来也很方便。相关代码已经上传至GitHub - 刀客传奇。感兴趣的可以看我上面写的几篇。
1. 一个实用的NSString分类工具 (一)—— 玩转数字
2. 一个实用的NSString分类工具(二) —— 获取拼音大写首字母和转义等

Json转数组NSArray

下面还是看代码

- (NSArray *)jj_jsonArray;
- (NSArray *) jj_jsonArray 
{
    id json = [self jsonValue];
    return [json isKindOfClass:NSArray.class] ? json : nil;
}

- (id)jsonValue 
{
    NSError *error = nil;
    id jsonObj = [NSJSONSerialization JSONObjectWithData:[self dataUsingEncoding:NSUTF8StringEncoding] options:NSJSONReadingMutableContainers | NSJSONReadingMutableLeaves error:&error];
    if (error) {
        NSLog(@"JSON: %@\nparse error: %@", self, error);
        return jsonObj;
    }
    return jsonObj;
}

这里就不给大家验证了,大家自己验证吧。


json转NSString字符串

下面还是先看代码

+ (NSString *)jj_stringWithJSONObject:(id)object;
+ (NSString *)jj_stringWithJSONObject:(id)object
{
    NSError *error = nil;
    NSData *data = [NSJSONSerialization dataWithJSONObject:object options:0 error:&error];
    if (error) {
        NSLog(@"JSON generate error: %@", error);
        return nil;
    }
    return [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
}

这就不给大家验证了。


json转字典NSDictionary

还是直接看代码

- (NSDictionary *)jj_jsonDictionary;
- (NSDictionary *) jj_jsonDictionary 
{
    id json = [self jsonValue];
    return [json isKindOfClass:NSDictionary.class] ? json : nil;
}

- (id)jsonValue 
{
    NSError *error = nil;
    id jsonObj = [NSJSONSerialization JSONObjectWithData:[self dataUsingEncoding:NSUTF8StringEncoding] options:NSJSONReadingMutableContainers | NSJSONReadingMutableLeaves error:&error];
    if (error) {
        NSLog(@"JSON: %@\nparse error: %@", self, error);
        return jsonObj;
    }
    return jsonObj;
}

这里也就不给大家验证了。


CBC模式对齐加密

下面看代码

- (NSData *)jj_encryptWithCBC:(NSString *)key; 
- (NSData *) jj_encryptWithCBC:(NSString *)key
{
    NSData *textData = [self dataUsingEncoding:NSUTF8StringEncoding];
    NSUInteger dataLength = [textData length];
    size_t bufferSize = dataLength + kCCBlockSizeDES;
    unsigned char buffer[bufferSize];
    memset(buffer, 0, sizeof(buffer));
    size_t numBytesEncrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
                                          kCCOptionPKCS7Padding,
                                          [key UTF8String], kCCKeySizeDES,
                                          [key UTF8String],
                                          [textData bytes], dataLength,
                                          buffer, bufferSize,
                                          &numBytesEncrypted);
    if (cryptStatus == kCCSuccess) {
        NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
        return data;
    }
    return nil;
}

这里也不给大家验证了。


ECB模式对齐加密

还是先看代码

- (NSData *)jj_encryptWithECB:(NSString *)key;
- (NSData *) jj_encryptWithECB:(NSString *) key
{
    NSData *textData = [self dataUsingEncoding:NSUTF8StringEncoding];
    NSUInteger dataLength = [textData length];
    size_t bufferSize = dataLength + kCCBlockSizeDES;
    unsigned char buffer[bufferSize];
    memset(buffer, 0, sizeof(buffer));
    size_t numBytesEncrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
                                          kCCOptionPKCS7Padding|kCCOptionECBMode,
                                          [key UTF8String], kCCKeySizeDES,
                                          NULL,
                                          [textData bytes], dataLength,
                                          buffer, bufferSize,
                                          &numBytesEncrypted);
    if (cryptStatus == kCCSuccess) {
        NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
        return data;
    }
    return nil;
}

同样不给大家验证了。


DES解密

- (NSString *)jj_decryptUseDESkey:(NSString *)key;
-(NSString*) jj_decryptUseDESkey:(NSString*)key 
{
    // 利用 GTMBase64 解碼 Base64 字串
    NSData* cipherData = [GTMBase64 decodeString:self];
    size_t bufferSize = [cipherData length] + kCCBlockSizeDES;
    unsigned char buffer[bufferSize];
    
    memset(buffer, 0, sizeof(buffer));
    size_t numBytesDecrypted = 0;
    
    // IV 偏移量不需使用
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
                                          kCCAlgorithmDES,
                                          kCCOptionPKCS7Padding,
                                          [key UTF8String],
                                          kCCKeySizeDES,
                                          [key UTF8String],
                                          [cipherData bytes],
                                          [cipherData length],
                                          buffer,
                                          bufferSize,
                                          &numBytesDecrypted);
    NSString* plainText = nil;
    if (cryptStatus == kCCSuccess) {
        NSData* data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted];
        plainText = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding] ;
    }
    return plainText;
}

后记

未完,待续~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 首先罗列一些知识点: 1.加密算法通常分为对称性加密算法和非对称性加密算法:对于对称性加密算法,信息接收双方都需事...
    JonesCxy阅读 5,310评论 2 4
  • JSON JSON和XML都是需要解析的 JSON是一种轻量级的数据格式,一般用于数据交互服务器返回给客户端的数据...
    JonesCxy阅读 5,899评论 2 10
  • 关于想家 昨天才离开家,然后从离开家的前一个星期就开始想家。 想念妈妈做的饭菜,最终只能在吃看起来还不错的外卖上寻...
    一只ten阅读 1,436评论 0 0
  • 清明祭祖 清明时节,遥祭老祖双亲。轻轻捧出,岁月染黄的古训。字里行间,满满教吾辈做人。 清洁 清廉 清净,厚重的一...
    参天大树_阅读 1,630评论 0 0
  • 2014年年初,我从布达佩斯旅行结束,返回柏林的途中,在斯洛伐克的首都布拉提斯拉发停留了几日。那几天正好下起了大雪...
    小惠Kiterunner阅读 2,532评论 0 5

友情链接更多精彩内容