一. 數(shù)據(jù)安全
密鑰:密鑰是一種參數(shù),它是在明文轉(zhuǎn)換為密文或者密文轉(zhuǎn)換為明文的算法中輸入的參數(shù).密鑰分為對稱密鑰與分對稱密鑰.
明文:沒有進行加密,能夠直接代表原文含義的信息.
密文:經(jīng)過加密處理,隱藏原文含義.
加密:將明文轉(zhuǎn)換成為密文
解密:將密文轉(zhuǎn)換成為明文
二. MD5加密
MD5加密可以加密NSData對象,也可以加密NSString對象
- MD5加密NSData對象
+ (NSMutableString *)md5Data:(NSData *)sourceData {
// 需要MD5變量并且初始化
CC_MD5_CTX md5;
CC_MD5_Init(&md5);
// 開始加密
// 參數(shù)1:對MD5變量取地址(要為該變量指向的內(nèi)存空間存儲計算好的數(shù)據(jù))
// 參數(shù)2:需要計算的源數(shù)據(jù)
// 參數(shù)3:源數(shù)據(jù)的長度
CC_MD5_Update(&md5, sourceData.bytes, (CC_LONG)sourceData.length);
// 聲明一個無符號的字符數(shù)組,用來存放轉(zhuǎn)換好的數(shù)據(jù)
unsigned char result[CC_MD5_DIGEST_LENGTH];
// 將數(shù)據(jù)放入result數(shù)組
// 參數(shù)1:容器地址
// 參數(shù)2:MD5變量地址
CC_MD5_Final(result, &md5);
// result中的字符拼接為OC語言中的字符串,以便我們使用.
NSMutableString *resultStr = [[NSMutableString alloc] init];
for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
[resultStr appendFormat:@"%02x",result[i]];
}
NSLog(@"%@",resultStr);
return resultStr;
}
- MD5加密NSString對象
+ (NSMutableString *)md5String:(NSString *)sourceString {
// 1.由于md5加密是通過C語言函數(shù)來計算,所以需要將NSString對象轉(zhuǎn)化成為C語言的字符串.
const char *cStr = [sourceString UTF8String];
// 2.創(chuàng)建一個C語言的字符數(shù)組,用來接收加密計數(shù)后的字符.
unsigned char result[CC_MD5_DIGEST_LENGTH];
// 3.md5計算(加密過程)
/*
參數(shù)1為需要加密的字符串
參數(shù)2為需要加密的字符串的長度
參數(shù)3為加密完成之后的字符串存儲的地方
*/
CC_MD5(cStr, (CC_LONG)strlen(cStr), result);
// 4.將加密完成的字符拼接起來使用(16進制的)
// 聲明一個可變字符串類型,用來拼接轉(zhuǎn)換好的字符
NSMutableString *resultStr = [[NSMutableString alloc] initWithCapacity:CC_MD5_DIGEST_LENGTH];
// 遍歷result數(shù)組,取出所有字符來拼接
for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
// 此處格式控制符為x則為小寫字母,X則為大寫字母
[resultStr appendFormat:@"%02X",result[i]];
}
NSLog(@"%@",resultStr);
return resultStr;
}
三. Base64加密
Base64加密過后可以進行解密操作,MD5加密則不可進行解密操作.
- Base64加密NSData對象
+ (NSString *)base64EncodedWithData:(NSData *)sourceData {
if (!sourceData) {
return nil;
}
NSString *resultStr = [sourceData base64EncodedStringWithOptions:NSDataBase64Encoding64CharacterLineLength];
// NSData *newData = [sourceData base64EncodedDataWithOptions:NSDataBase64Encoding64CharacterLineLength];
NSLog(@"%@",resultStr);
return resultStr;
}
- Base64解密對象
+ (id)base64DecodedWithString:(NSString *)sourceString {
if (!sourceString) {
return nil;
}
// 解密
NSData *resultData = [[NSData alloc] initWithBase64EncodedString:sourceString options:NSDataBase64DecodingIgnoreUnknownCharacters];
// NSLog(@"%@",resultData);
return resultData;
}
四.KVO
KVO:(Key-Value-Observer) 鍵值觀察者,是觀察者設(shè)計模式的一種體現(xiàn).
KVO觸發(fā)機制:一個對象(觀察者),監(jiān)測另一個對象(被觀察者),若被監(jiān)測的屬性發(fā)生更改(調(diào)用其屬性的setter方法時)會觸發(fā)觀察者的一個方法.
給一個屬性添加觀察者:
[self.view addObserver:self forKeyPath:@"backgroundColor" options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld context:nil];
并實現(xiàn)方法:
所有的觀察者都會執(zhí)行該方法,則可以通過object參數(shù)(不同對象)與keyPath屬性參數(shù)不同來進行判斷具體應(yīng)該怎么執(zhí)行方法.
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSString *,id> *)change context:(void *)context {
if ([keyPath isEqualToString:@"backgroundColor"]) {
id oldColor = [change objectForKey:NSKeyValueChangeOldKey];
NSLog(@"%@",oldColor);
id newColor = [change objectForKey:NSKeyValueChangeNewKey];
NSLog(@"%@",newColor);
}
}