【請求加密】android ios java後臺通用DES base64加密
阿新 • • 發佈:2018-12-08
1、OC方面 Base64編碼採取Google官方程式碼 GTMBase64
2、Android 方面採取 Android android.util.Base64原始碼
3、後臺Java端解密採取android.util.Base64原始碼
4、客戶端進行DES加密後再使用Base64進行編碼,服務端使用Base64解碼後採用DES進行解密
5、後臺和Android端加解密使用同一DES工具包
Android以及Java後臺測試內容:
String s=DESUtil.encode(mSignSecretKey,"Hello你好123"); String result=DESUtil.decode(mSignSecretKey, s);
LogCat.w("DES加密並進行Base64編碼="+s);
LogCat.w("Base64解碼並進行DES解碼="+result);
測試文字:Hello你好123 mSignSecretKey:12345678
控制檯列印
IOS測試內容:
NSString *s=[DesUtil encryptWithText:@"Hello你好123" forKey:@"12345678"]; NSLog(@"DES加密並進行Base64編碼=%@",s); NSString *result=[DesUtil decryptWithText:s forKey:@"12345678"]; NSLog(@"Base64解碼並進行DES解碼=%@",result);
測試文字:Hello你好123 mSignSecretKey:12345678
控制檯列印 末尾的==號是:位元組不夠的地方使用==號補齊
/** * DES加密 * @param key 加密簽名 * @param data 加密資料 * @return 密文 */ public static String encode(String key, String data) { if (data == null) return null; try { DESKeySpec dks = new DESKeySpec(key.getBytes()); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); // key的長度不能夠小於8位位元組 Key secretKey = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); IvParameterSpec iv = new IvParameterSpec("12345678".getBytes()); AlgorithmParameterSpec paramSpec = iv; cipher.init(Cipher.ENCRYPT_MODE, secretKey, paramSpec); byte[] bytes = cipher.doFinal(data.getBytes()); return new String(Base64Encode(bytes)); } catch (Exception e) { e.printStackTrace(); return data; } } /** * DES演算法,解密 * * @param data * 待解密字串 * @param key * 解密私鑰,長度不能夠小於8位 * @return 解密後內容 */ public static String decode(String key, String data) { if (data == null) return null; try { DESKeySpec dks = new DESKeySpec(key.getBytes()); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); // key的長度不能夠小於8位位元組 Key secretKey = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); IvParameterSpec iv = new IvParameterSpec("12345678".getBytes()); AlgorithmParameterSpec paramSpec = iv; cipher.init(Cipher.DECRYPT_MODE, secretKey, paramSpec); return new String(cipher.doFinal(Base64Decode(data.getBytes())),"UTF-8"); } catch (Exception e) { e.printStackTrace(); return data; } }
IOS端核心程式碼:
</pre><p></p><p></p><pre name="code" class="objc">+ (NSString *)encryptWithText:(NSString *)sText forKey:(NSString*) key
{
//kCCEncrypt 加密
return [self encrypt:sText encryptOrDecrypt:kCCEncrypt key:key];
}
+ (NSString *)decryptWithText:(NSString *)sText forKey:(NSString*) key
{
//kCCDecrypt 解密
return [self encrypt:sText encryptOrDecrypt:kCCDecrypt key:key];
}
+ (NSString *)encrypt:(NSString *)sText encryptOrDecrypt:(CCOperation)encryptOperation key:(NSString *)key
{
const void *dataIn;
size_t dataInLength;
if (encryptOperation == kCCDecrypt)//傳遞過來的是decrypt 解碼
{
//解碼 base64
NSData *decryptData = [GTMBase64 decodeData:[sText dataUsingEncoding:NSUTF8StringEncoding]];//轉成utf-8並decode
dataInLength = [decryptData length];
dataIn = [decryptData bytes];
}
else //encrypt
{
NSData* encryptData = [sText dataUsingEncoding:NSUTF8StringEncoding];
dataInLength = [encryptData length];
dataIn = (const void *)[encryptData bytes];
}
/*
DES加密 :用CCCrypt函式加密一下,然後用base64編碼下,傳過去
DES解密 :把收到的資料根據base64,decode一下,然後再用CCCrypt函式解密,得到原本的資料
*/
CCCryptorStatus ccStatus;
uint8_t *dataOut = NULL; //可以理解位type/typedef 的縮寫(有效的維護了程式碼,比如:一個人用int,一個人用long。最好用typedef來定義)
size_t dataOutAvailable = 0; //size_t 是操作符sizeof返回的結果型別
size_t dataOutMoved = 0;
dataOutAvailable = (dataInLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);
dataOut = malloc( dataOutAvailable * sizeof(uint8_t));
memset((void *)dataOut, 0x0, dataOutAvailable);//將已開闢記憶體空間buffer的首 1 個位元組的值設為值 0
NSString *initIv = @"12345678";
const void *vkey = (const void *) [key UTF8String];
const void *iv = (const void *) [initIv UTF8String];
//CCCrypt函式 加密/解密
ccStatus = CCCrypt(encryptOperation,// 加密/解密
kCCAlgorithmDES,// 加密根據哪個標準(des,3des,aes。。。。)
kCCOptionPKCS7Padding,// 選項分組密碼演算法(des:對每塊分組加一次密 3DES:對每塊分組加三個不同的密)
vkey, //金鑰 加密和解密的金鑰必須一致
kCCKeySizeDES,// DES 金鑰的大小(kCCKeySizeDES=8)
iv, // 可選的初始向量
dataIn, // 資料的儲存單元
dataInLength,// 資料的大小
(void *)dataOut,// 用於返回資料
dataOutAvailable,
&dataOutMoved);
NSString *result = nil;
if (encryptOperation == kCCDecrypt)//encryptOperation==1 解碼
{
//得到解密出來的data資料,改變為utf-8的字串
result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding];
}
else //encryptOperation==0 (加密過程中,把加好密的資料轉成base64的)
{
//編碼 base64
NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];
result = [GTMBase64 stringByEncodingData:data];
}
return result;
}
6、最後 附上 Android(Java)、IOS端的核心程式碼。按照給出的例項呼叫即可。
下載:點選開啟連結