iOS开发:用DES对字符串加解密
参考http://www.cnblogs.com/janken/archive/2012/04/05/2432930.html,做了个小修改,实现PHP,JAVA,Objective-c加解密结果相同。
原先Android版的客户端与服务端(PHP)通讯部分内容用DES加密,加密方法:http://www.pocketdigi.com/20121112/940.html
直接拷贝原文的源码,发现结果不同,原因在于,我在java和php里用的IvParameterSpec是动态的,就是key转成byte[],但原文是静态写死的。
上修改后的源码:
先是Base64:
Base64.h:
- #import <Foundation/Foundation.h>
- @interface Base64 : NSObject
- +(int)char2Int:(char)c;
- +(NSData *)decode:(NSString *)data;
- +(NSString *)encode:(NSData *)data;
- @end
Base64.m
- #import "Base64.h"
- static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
- @interface Base64()
- +(int)char2Int:(char)c;
- @end
- @implementation Base64
- +(NSString *)encode:(NSData *)data
- {
- if (data.length == 0)
- return nil;
- char *characters = malloc(data.length * 3 / 2);
- if (characters == NULL)
- return nil;
- int end = data.length - 3;
- int index = 0;
- int charCount = 0;
- int n = 0;
- while (index <= end) {
- int d = (((int)(((char *)[data bytes])[index]) & 0x0ff) << 16)
- | (((int)(((char *)[data bytes])[index + 1]) & 0x0ff) << 8)
- | ((int)(((char *)[data bytes])[index + 2]) & 0x0ff);
- characters[charCount++] = encodingTable[(d >> 18) & 63];
- characters[charCount++] = encodingTable[(d >> 12) & 63];
- characters[charCount++] = encodingTable[(d >> 6) & 63];
- characters[charCount++] = encodingTable[d & 63];
- index += 3;
- if(n++ >= 14)
- {
- n = 0;
- characters[charCount++] = ' ';
- }
- }
- if(index == data.length - 2)
- {
- int d = (((int)(((char *)[data bytes])[index]) & 0x0ff) << 16)
- | (((int)(((char *)[data bytes])[index + 1]) & 255) << 8);
- characters[charCount++] = encodingTable[(d >> 18) & 63];
- characters[charCount++] = encodingTable[(d >> 12) & 63];
- characters[charCount++] = encodingTable[(d >> 6) & 63];
- characters[charCount++] = '=';
- }
- else if(index == data.length - 1)
- {
- int d = ((int)(((char *)[data bytes])[index]) & 0x0ff) << 16;
- characters[charCount++] = encodingTable[(d >> 18) & 63];
- characters[charCount++] = encodingTable[(d >> 12) & 63];
- characters[charCount++] = '=';
- characters[charCount++] = '=';
- }
- NSString * rtnStr = [[NSString alloc] initWithBytesNoCopy:characters length:charCount encoding:NSUTF8StringEncoding freeWhenDone:YES];
- return rtnStr;
- }
- +(NSData *)decode:(NSString *)data
- {
- if(data == nil || data.length <= 0) {
- return nil;
- }
- NSMutableData *rtnData = [[NSMutableData alloc]init];
- int slen = data.length;
- int index = 0;
- while (true) {
- while (index < slen && [data characterAtIndex:index] <= ' ') {
- index++;
- }
- if (index >= slen || index + 3 >= slen) {
- break;
- }
- int byte = ([self char2Int:[data characterAtIndex:index]] << 18) + ([self char2Int:[data characterAtIndex:index + 1]] << 12) + ([self char2Int:[data characterAtIndex:index + 2]] << 6) + [self char2Int:[data characterAtIndex:index + 3]];
- Byte temp1 = (byte >> 16) & 255;
- [rtnData appendBytes:&temp1 length:1];
- if([data characterAtIndex:index + 2] == '=') {
- break;
- }
- Byte temp2 = (byte >> 8) & 255;
- [rtnData appendBytes:&temp2 length:1];
- if([data characterAtIndex:index + 3] == '=') {
- break;
- }
- Byte temp3 = byte & 255;
- [rtnData appendBytes:&temp3 length:1];
- index += 4;
- }
- return rtnData;
- }
- +(int)char2Int:(char)c
- {
- if (c >= 'A' && c <= 'Z') {
- return c - 65;
- } else if (c >= 'a' && c <= 'z') {
- return c - 97 + 26;
- } else if (c >= '0' && c <= '9') {
- return c - 48 + 26 + 26;
- } else {
- switch(c) {
- case '+':
- return 62;
- case '/':
- return 63;
- case '=':
- return 0;
- default:
- return -1;
- }
- }
- }
- @end
DESUtils.h:
- #import <Foundation/Foundation.h>
- #import <CommonCrypto/CommonCrypto.h>
- #import "Base64.h"
- @interface DESUtils : NSObject
- +(NSString *)decryptUseDES:(NSString *)cipherText key:(NSString *)key;
- +(NSString *) encryptUseDES:(NSString *)plainText key:(NSString *)key;
- @end
DESUtils.m:
- #import "DESUtils.h"
- @implementation DESUtils
- +(NSString *)decryptUseDES:(NSString *)cipherText key:(NSString *)key
- {
- NSString *plaintext = nil;
- NSData *cipherdata = [Base64 decode:cipherText];
- unsigned char buffer[1024];
- memset(buffer, 0, sizeof(char));
- size_t numBytesDecrypted = 0;
- CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmDES,
- kCCOptionPKCS7Padding,
- [key UTF8String], kCCKeySizeDES,
- (Byte *)[[key dataUsingEncoding:NSUTF8StringEncoding] bytes],
- [cipherdata bytes], [cipherdata length],
- buffer, 1024,
- &numBytesDecrypted);
- if(cryptStatus == kCCSuccess) {
- NSData *plaindata = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted];
- plaintext = [[NSString alloc]initWithData:plaindata encoding:NSUTF8StringEncoding];
- }
- return plaintext;
- }
- +(NSString *) encryptUseDES:(NSString *)plainText key:(NSString *)key
- {
- NSString *ciphertext = nil;
- NSData *textData = [plainText dataUsingEncoding:NSUTF8StringEncoding];
- NSUInteger dataLength = [textData length];
- unsigned char buffer[1024];
- memset(buffer, 0, sizeof(char));
- size_t numBytesEncrypted = 0;
- CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
- kCCOptionPKCS7Padding,
- [key UTF8String], kCCKeySizeDES,
- (Byte *)[[key dataUsingEncoding:NSUTF8StringEncoding] bytes],
- [textData bytes], dataLength,
- buffer, 1024,
- &numBytesEncrypted);
- if (cryptStatus == kCCSuccess) {
- NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
- ciphertext = [Base64 encode:data];
- }
- return ciphertext;
- }
- @end
© 2014, 冰冻鱼. 请尊重作者劳动成果,复制转载保留本站链接! 应用开发笔记
iOS开发:用DES对字符串加解密的更多相关文章
- 李洪强iOS开发Swift篇—03_字符串和数据类型
李洪强iOS开发Swift篇—03_字符串和数据类型 一.字符串 字符串是String类型的数据,用双引号""包住文字内容 let website = "http:// ...
- android中使用jni对字符串加解密实现分析
android中使用jni对字符串加解密实现分析 近期项目有个需求.就是要对用户的敏感信息进行加密处理,比方用户的账户password,手机号等私密信息.在java中,就对字符串的加解密我们能够使用A ...
- iOS开发-通过正则表达式判断字符串是否为纯阿拉伯数字
iOS开发-通过正则表达式判断字符串是否为纯阿拉伯数字 简述:NSString * regex_0 = @"\\d{1,}"; /*允许首位为0*/ NSString * re ...
- DES跨(C# Android IOS)三个平台通用的加解密方法
#region 跨平台加解密(c# 安卓 IOS) // public static string sKey = "12345678"; ...
- iOS - (base64对字符串加解密)
今天公司让做支付系统,为了安全起见,需要对一些数据进行加密,然而我首想到的就是 base64 ,严格来说这不是一种加密方式,这只是将原有的一些字符串或者其它的一些文本进行一个转化而已,就是转化成数字, ...
- DES,AeS加解密,MD5,SHA加密
1.DES一共就有4个参数参与运作:明文.密文.密钥.向量.其中这4者的关系可以理解为: 密文=明文+密钥+向量: 明文=密文-密钥-向量: 为什么要向量这个参数呢?因为如果有一篇文章,有几个词重复, ...
- 在ios开发中有多少常用的加密解密方式(备用)
最常用的是MD5和base64编码,还有DES 3DES AES加密 ios怎么实现RAS加密解密 最近几天折腾了一下如何在iOS上使用RSA来加密.iOS上并没有直接的RSA加密API.但是iOS提 ...
- [IOS 开发] NSDateFormatter的格式字符串 -- 《整理的笔记》
在ios开发中, OBjective-C中的NSDate是一个挺讨厌的类型, 自己找不到转换成字符串的类型,还得带一个NSDateFormatter的类型. 官方文档上对NSDateFormatter ...
- C#常用字符串加解密方法封装
C#中常用的字符串加密.解密方法封装,包含只加密但不解密的方法.收藏起来备用. //方法一 //须添加对System.Web的引用 //using System.Web.Security; /// & ...
随机推荐
- Python高级语法总结
1.Python面向对象 创建类 使用class语句来创建一个新类,class之后为类的名称并以冒号结尾,如下实例: class ClassName: '类的帮助信息' #类文档字符串 class_s ...
- HAOI2017游记
HACF的最终成绩已经出炉,但是事情还没有结束. 好多想说的,不知道从何说起,就按照时间顺序说吧. 考前 考前大概一周半就开始复习了,一些比较重要的算法,比如KDT,单纯性,线性基等等没有再继续学,所 ...
- K8S dashboard 创建只读账户
1.创建名字为“Dashboard-viewonly“的Cluster Role,各种资源只给予了list,get,watch的权限.dashboard-viewonly.yaml --- apiVe ...
- Spring Boot + Swagger
前言: 在互联网公司, 微服务的使用者一般分为两种, 客户端和其他后端项目(包括关联微服务),不管是那方对外提供文档 让别人理解接口 都是必不可少的.传统项目中一般使用wiki或者文档, 修改繁琐,调 ...
- jQuery UI基本使用方法
其实jQuery UI早就在我的学习计划中,只不过因为计划安排始终处于待命状态,最近项目要用到jQuery UI,就提前学习一下,也想能够封装自己的UI库,这样就不用老按照别人的套路走了,像使用jQu ...
- ArrayList既然继承自AbstractList抽象类,而AbstractList已经实现了List接口,那么ArrayList类为何还要再实现List接口呢?
https://www.cnblogs.com/bluejavababy/p/4320545.html
- koa源码阅读[0]
koa源码阅读[0] Node.js也是写了两三年的时间了,刚开始学习Node的时候,hello world就是创建一个HttpServer,后来在工作中也是经历过Express.Koa1.x.Koa ...
- Unity 添加鼠标右键事件
把此类放到 Editor下使用就OK using UnityEngine; using System.Collections; using System.Collections.Generic; us ...
- android内存回收顺序
最近做项目的时候,经常会考虑到系统回收进程,释放资源等问题.特别查找了相关资料,了解下android内存回收顺序以及回收场景. 下面内容都为网络查找资料,若有错误,欢迎指出. 以下顺序,依次被回收的可 ...
- 【nginx+tomcat集群】Nginx1.12.2+Tomcat7集群+负载均衡+Session共享
今天想着将项目优化一下,就想的实现集群分布,在本机测试:利用nginx+tomcat实现 通过上一篇博客(http://www.cnblogs.com/qlqwjy/p/8535235.html),N ...