一、Base64
1.Base64簡單說明
描述:Base64可以成為密碼學的基石,非常重要。
特點:可以將任意的二進制數據進行Base64編碼
結果:所有的數據都能被編碼為并只用65個字符就能表示的文本文件。
65字符:A~Z a~z 0~9 + / =
對文件進行base64編碼后文件數據的變化:編碼后的數據~=編碼前數據的4/3,會大1/3左右。
2.命令行進行Base64編碼和解碼
編碼:base64 123.png -o 123.txt
解碼:base64 123.txt -o test.png -D
2.Base64編碼原理
1)將所有字符轉化為ASCII碼;
2)將ASCII碼轉化為8位二進制;
3)將二進制3個歸成一組(不足3個在后邊補0)共24位,再拆分成4組,每組6位;
4)統一在6位二進制前補兩個0湊足8位;
5)將補0后的二進制轉為十進制;
6)從Base64編碼表獲取十進制對應的Base64編碼;
處理過程說明:
a.轉換的時候,將三個byte的數據,先后放入一個24bit的緩沖區中,先來的byte占高位。
b.數據不足3byte的話,于緩沖區中剩下的bit用0補足。然后,每次取出6個bit,
按照其值選擇查表選擇對應的字符作為編碼后的輸出。
c.不斷進行,直到全部輸入數據轉換完成。
d.如果最后剩下兩個輸入數據,在編碼結果后加1個“=”;
e.如果最后剩下一個輸入數據,編碼結果后加2個“=”;
f.如果沒有剩下任何數據,就什么都不要加,這樣才可以保證資料還原的正確性。
3.實現
a.說明:
1)從iOS7.0 開始,蘋果就提供了base64的編碼和解碼支持
2)如果是老項目,則還能看到base64編碼和解碼的第三方框架,如果當前不再支持iOS7.0以下版本,則建議替換。
b.相關代碼:
//給定一個字符串,對該字符串進行Base64編碼,然后返回編碼后的結果
-(NSString *)base64EncodeString:(NSString *)string
{
//1.先把字符串轉換為二進制數據
NSData *data = [string dataUsingEncoding:NSUTF8StringEncoding];
//2.對二進制數據進行base64編碼,返回編碼后的字符串
return [data base64EncodedStringWithOptions:0];
}
//對base64編碼后的字符串進行解碼
-(NSString *)base64DecodeString:(NSString *)string
{
//1.將base64編碼后的字符串『解碼』為二進制數據
NSData *data = [[NSData alloc]initWithBase64EncodedString:string options:0];
//2.把二進制數據轉換為字符串返回
return [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
}
c.終端測試命令
$ echo -n A | base64
$ echo -n QQ== |base64 -D
二、加密相關
網絡應用程序數據的原則:
1. 在網絡上"不允許"傳輸用戶隱私數據的"明文"
2. 在本地"不允許"保存用戶隱私數據的"明文"
加密相關
1. base64 編碼格式
2. 密碼學演化 "秘密本"-->RSA
RSA簡單說明:加密算法算法是公開的,加密方式如下:
- "公鑰"加密,"私鑰"解密
- "私鑰"加密,"公鑰"解密
目前流行的加密方式:
---------------
- 哈希(散列)函數
- MD5
- SHA1
- SHA256
- 對稱加密算法
- DES
- 3DES
- AES(高級密碼標準,美國國家安全局使用的)
- 非對稱加密算法(RSA)
散列函數:
---------------
特點:
- 算法是公開的
- "對相同的數據加密,得到的結果是一樣的"
- 對不同的數據加密,得到的結果是定長的,MD5對不同的數據進行加密,得到的結果都是 32 個字符長度的字符串
- 信息摘要,信息"指紋",是用來做數據識別的!
- 不能反算的
用途:
- 密碼,服務器并不需要知道用戶真實的密碼!
- 搜索
張老師 楊老師 蒼老師
蒼老師 張老師 楊老師
張老師 1bdf605991920db11cbdf8508204c4eb
楊老師 2d97fbce49977313c2aae15ea77fec0f
蒼老師 692e92669c0ca340eff4fdcef32896ee
如何判斷:對搜索的每個關鍵字進行三列,得到三個相對應的結果,按位相加結果如果是一樣的,
那搜索的內容就是一樣的!
- 版權
版權保護,文件的識別。
破解:
- http://www.cmd5.com 記錄超過24萬億條,共占用160T硬盤 的密碼數據,通過對海量數據的搜索得到的結果!
提升MD5加密安全性,有兩個解決辦法
1. 加"鹽"(佐料)
2. HMAC:給定一個"秘鑰",對明文進行加密,并且做"兩次散列"!-> 得到的結果,還是 32 個字符
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。