【请求加密】android ios java后台通用DES base64加密
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端的核心代码。按照给出的实例调用即可。
下载:点击打开链接
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: Base64和3DES加密算法原理
- 下一篇: DES加密解密(配合GTMBase64)