(iOS)Base64加密和DES加密匣椰、以及JAVA和iOS中DES加密統(tǒng)一性問題

我們在項目中為了安全方面的考慮顺呕,通常情況下會選擇一種加密方式對需要安全性的文本進行加密,而Base64加密和DES64加密是常用的加密算法必指。我記得我在前一個項目中使用的就是這兩種加密算法的結(jié)合:Base64 + DES加密囊咏。當然這需要移動端和后臺服務器做一個統(tǒng)一。


1取劫、Base64加解密

值得一提的是:apple提供了基礎(chǔ)的Base64加解密算法。這樣我們就可以直接使用方法去實現(xiàn)Base64加解密研侣。先看一下apple都提供了哪些方法:
<pre>

@interface NSData (NSDataBase64Encoding)

  • (nullable instancetype)initWithBase64EncodedString:(NSString *)base64String options:(NSDataBase64DecodingOptions)options NS_AVAILABLE(10_9, 7_0);

  • (NSString *)base64EncodedStringWithOptions:(NSDataBase64EncodingOptions)options NS_AVAILABLE(10_9, 7_0);

  • (nullable instancetype)initWithBase64EncodedData:(NSData *)base64Data options:(NSDataBase64DecodingOptions)options NS_AVAILABLE(10_9, 7_0);

  • (NSData *)base64EncodedDataWithOptions:(NSDataBase64EncodingOptions)options NS_AVAILABLE(10_9, 7_0);

@end
</pre>
我們先創(chuàng)建一個NSData谱邪,再去一條一條的分析以上的方法
<pre><code>NSData *data = [@"Base64 encoding string" dataUsingEncoding:NSUTF8StringEncoding];</code></pre>

  • (1)創(chuàng)建一個Data(從一個Base64編碼字符串使用給出的設(shè)置創(chuàng)建一個Data)
    <pre><code>NSData *dataFromBase64String = [[NSData alloc]initWithBase64EncodedString:base64String options:0];</code></pre>
  • (2)創(chuàng)建一個Base64編碼字符串(從接受者內(nèi)容創(chuàng)建)
    <pre><code>NSString *base64String = [data base64EncodedStringWithOptions:0];</code></pre>
  • (3)創(chuàng)建一個Data(從一個Base64、UTF-8編碼的Data創(chuàng)建)
    <pre><code>NSData *base64AndUTFData = [base64Data initWithBase64EncodedData:base64Data options:0];</code></pre>
  • (4)創(chuàng)建一個Base64庶诡、UTF-8編碼的Data(從接受者內(nèi)容創(chuàng)建)
    <pre><code>NSData *base64Data = [data base64EncodedDataWithOptions:0];</code></pre>

當然惦银,我們最后也可以將Data轉(zhuǎn)化成String類型。
<pre><code>NSString *base64Decoded = [[NSString alloc]initWithData:dataFromBase64String encoding:NSUTF8StringEncoding];</code></pre>

以上是Base64加解密方法。下面我們看看DES的加解密扯俱。


2书蚪、DES加解密

我們都知道安卓和后臺可以使用統(tǒng)一的代碼去解決這個問題,這也是java的優(yōu)勢之一吧迅栅。這里我會附一段java的代碼殊校。主要是為了下面說明java和iOS端實現(xiàn)中需要注意的地方(也是不同點)。
為了使說明更方便一些读存,我們先看一下java的DES加密方法:

/**
 * EDS加密
 * @param originalStr
 * @return
 */
public static String Encrypt(String originalStr) {
    String result = null;
    byte[] tmpOriginalStr = null;
    try {
        if (!Tools.isEmpty(originalStr)) {
            tmpOriginalStr = originalStr.getBytes("utf-8");
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
            DESKeySpec dks = new DESKeySpec(KEY);
            SecretKey secretKey = keyFactory.generateSecret(dks);
            IvParameterSpec param = new IvParameterSpec(IV);
            Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
            cipher.init(Cipher.ENCRYPT_MODE, secretKey,param);
            byte[] tmpEncypt = cipher.doFinal(tmpOriginalStr);
            if (tmpEncypt != null) {
                result = Base64.encodeToString(tmpEncypt,Base64.NO_WRAP);
            }
        }
    } catch (Exception e) {
        Log.e("Erro",e.getMessage());
    }
    return result;
}}

我們可以看出Java針對DES加密算法默認使用的是CBC模式为流,對齊方式采用的是:PKCS5Padding

而OC中的加密并不是java中的形式實現(xiàn)加密的让簿,接下來我們看一看OC中實現(xiàn)DES加密的代碼:

+(NSString *) encryptUseDES:(NSString *)plainText {
NSString *ciphertext = nil;
NSData *textData = [plainText dataUsingEncoding:NSUTF8StringEncoding];
NSUInteger dataLength = [textData length];
unsigned char buffer[1024 * 5];
memset(buffer, 0, sizeof(char));
size_t numBytesEncrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
                                      kCCOptionPKCS7Padding,
                                      [key UTF8String], kCCKeySizeDES,
                                      [iv UTF8String],
                                      [textData bytes], dataLength,
                                      buffer, 1024,
                                      &numBytesEncrypted);
if (cryptStatus == kCCSuccess) {
    NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
    ciphertext = [data base64EncodedStringWithOptions:0];
}
return ciphertext;}

先說一下代碼中紅色里面的綠色部分:key和iv 敬察。key:是DES加密的公鑰。而iv:是初始化的矢量尔当。兩者都是DES加密的關(guān)鍵參數(shù)莲祸。這個是必須要和Android、后臺有個統(tǒng)一的椭迎。
我們可以看出OC使用的是kCCOptionPKCS7Padding對齊方式锐帜。而java中很明確的指出使用的是PKCS5Padding。接下來我們點進去看看OC中給出的對齊選擇有哪些侠碧,我直接以代碼的形式展示出來:

@constant   kCCOptionPKCS7Padding   Perform PKCS7 padding. 
@constant   kCCOptionECBMode        Electronic Code Book Mode. 
                                    Default is CBC.
*/
enum {
/* options for block ciphers */
kCCOptionPKCS7Padding   = 0x0001,
kCCOptionECBMode        = 0x0002
/* stream ciphers currently have no options */
};

OC中給出的是** kCCOptionECBMode** 和** kCCOptionPKCS7Padding 這兩種選擇抹估。那么,問題現(xiàn)在出現(xiàn)了弄兜。java中的DES加密算法有很多種药蜻,例如:ECB,CBC替饿,OFB语泽,CFB**等。
java 和 OC的DES加密怎樣才能實現(xiàn)一致性呢视卢?(這也是我在項目中遇到的問題)踱卵。

查閱很多資料,再加上自己的很多次測試据过,得出的結(jié)果如下:
在JAVA中使用這種方式加密:"DES/CBC/PKCS5Padding" 對應的Object-C的是 kCCOptionPKCS7Padding.
而使用 "DES/ECB/PKCS5Padding" 對應的Object-C的是 kCCOptionPKCS7Padding | kCCOptionECBMod
覺得似乎OC目前只支持這兩種方式的加密惋砂。當然結(jié)果是已經(jīng)得到驗證的。

注意:md5加密(iOS SDK中自帶了CommonCrypto)出現(xiàn)警告?? 绳锅。
解決方法添加:引入函數(shù)定義的頭文件

#import <CommonCrypto/CommonDigest.h>

其他鏈接:
Objective C與Java之間的DES加解密實現(xiàn)
iOS 7: Base64 Encode and Decode NSData and NSString Objects

這里附上demo:https://github.com/Wheat-Qin/Base64-DES

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末西饵,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子鳞芙,更是在濱河造成了極大的恐慌眷柔,老刑警劉巖期虾,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異驯嘱,居然都是意外死亡镶苞,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門鞠评,熙熙樓的掌柜王于貴愁眉苦臉地迎上來茂蚓,“玉大人,你說我怎么就攤上這事谢澈』吞” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵锥忿,是天一觀的道長牛郑。 經(jīng)常有香客問我,道長敬鬓,這世上最難降的妖魔是什么淹朋? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮钉答,結(jié)果婚禮上础芍,老公的妹妹穿的比我還像新娘。我一直安慰自己数尿,他們只是感情好仑性,可當我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著右蹦,像睡著了一般诊杆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上何陆,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天晨汹,我揣著相機與錄音,去河邊找鬼贷盲。 笑死淘这,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的巩剖。 我是一名探鬼主播铝穷,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼佳魔!你這毒婦竟也來了曙聂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤吃引,失蹤者是張志新(化名)和其女友劉穎筹陵,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體镊尺,經(jīng)...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡朦佩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了庐氮。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片语稠。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖弄砍,靈堂內(nèi)的尸體忽然破棺而出仙畦,到底是詐尸還是另有隱情,我是刑警寧澤音婶,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布慨畸,位于F島的核電站,受9級特大地震影響衣式,放射性物質(zhì)發(fā)生泄漏寸士。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一碴卧、第九天 我趴在偏房一處隱蔽的房頂上張望弱卡。 院中可真熱鬧,春花似錦住册、人聲如沸婶博。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽凡人。三九已至,卻和暖如春垢箕,著一層夾襖步出監(jiān)牢的瞬間划栓,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工条获, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留忠荞,地道東北人。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓帅掘,卻偏偏與公主長得像委煤,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子修档,可洞房花燭夜當晚...
    茶點故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內(nèi)容