参考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:

  1. #import <Foundation/Foundation.h>
  2. @interface Base64 : NSObject
  3. +(int)char2Int:(char)c;
  4. +(NSData *)decode:(NSString *)data;
  5. +(NSString *)encode:(NSData *)data;
  6. @end

Base64.m

  1. #import "Base64.h"
  2. static const char encodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  3. @interface Base64()
  4. +(int)char2Int:(char)c;
  5. @end
  6. @implementation Base64
  7. +(NSString *)encode:(NSData *)data
  8. {
  9. if (data.length == 0)
  10. return nil;
  11. char *characters = malloc(data.length * 3 / 2);
  12. if (characters == NULL)
  13. return nil;
  14. int end = data.length - 3;
  15. int index = 0;
  16. int charCount = 0;
  17. int n = 0;
  18. while (index <= end) {
  19. int d = (((int)(((char *)[data bytes])[index]) & 0x0ff) << 16)
  20. | (((int)(((char *)[data bytes])[index + 1]) & 0x0ff) << 8)
  21. | ((int)(((char *)[data bytes])[index + 2]) & 0x0ff);
  22. characters[charCount++] = encodingTable[(d >> 18) & 63];
  23. characters[charCount++] = encodingTable[(d >> 12) & 63];
  24. characters[charCount++] = encodingTable[(d >> 6) & 63];
  25. characters[charCount++] = encodingTable[d & 63];
  26. index += 3;
  27. if(n++ >= 14)
  28. {
  29. n = 0;
  30. characters[charCount++] = ' ';
  31. }
  32. }
  33. if(index == data.length - 2)
  34. {
  35. int d = (((int)(((char *)[data bytes])[index]) & 0x0ff) << 16)
  36. | (((int)(((char *)[data bytes])[index + 1]) & 255) << 8);
  37. characters[charCount++] = encodingTable[(d >> 18) & 63];
  38. characters[charCount++] = encodingTable[(d >> 12) & 63];
  39. characters[charCount++] = encodingTable[(d >> 6) & 63];
  40. characters[charCount++] = '=';
  41. }
  42. else if(index == data.length - 1)
  43. {
  44. int d = ((int)(((char *)[data bytes])[index]) & 0x0ff) << 16;
  45. characters[charCount++] = encodingTable[(d >> 18) & 63];
  46. characters[charCount++] = encodingTable[(d >> 12) & 63];
  47. characters[charCount++] = '=';
  48. characters[charCount++] = '=';
  49. }
  50. NSString * rtnStr = [[NSString alloc] initWithBytesNoCopy:characters length:charCount encoding:NSUTF8StringEncoding freeWhenDone:YES];
  51. return rtnStr;
  52. }
  53. +(NSData *)decode:(NSString *)data
  54. {
  55. if(data == nil || data.length <= 0) {
  56. return nil;
  57. }
  58. NSMutableData *rtnData = [[NSMutableData alloc]init];
  59. int slen = data.length;
  60. int index = 0;
  61. while (true) {
  62. while (index < slen && [data characterAtIndex:index] <= ' ') {
  63. index++;
  64. }
  65. if (index >= slen || index + 3 >= slen) {
  66. break;
  67. }
  68. 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]];
  69. Byte temp1 = (byte >> 16) & 255;
  70. [rtnData appendBytes:&temp1 length:1];
  71. if([data characterAtIndex:index + 2] == '=') {
  72. break;
  73. }
  74. Byte temp2 = (byte >> 8) & 255;
  75. [rtnData appendBytes:&temp2 length:1];
  76. if([data characterAtIndex:index + 3] == '=') {
  77. break;
  78. }
  79. Byte temp3 = byte & 255;
  80. [rtnData appendBytes:&temp3 length:1];
  81. index += 4;
  82. }
  83. return rtnData;
  84. }
  85. +(int)char2Int:(char)c
  86. {
  87. if (c >= 'A' && c <= 'Z') {
  88. return c - 65;
  89. } else if (c >= 'a' && c <= 'z') {
  90. return c - 97 + 26;
  91. } else if (c >= '0' && c <= '9') {
  92. return c - 48 + 26 + 26;
  93. } else {
  94. switch(c) {
  95. case '+':
  96. return 62;
  97. case '/':
  98. return 63;
  99. case '=':
  100. return 0;
  101. default:
  102. return -1;
  103. }
  104. }
  105. }
  106. @end

DESUtils.h:

  1. #import <Foundation/Foundation.h>
  2. #import <CommonCrypto/CommonCrypto.h>
  3. #import "Base64.h"
  4. @interface DESUtils : NSObject
  5. +(NSString *)decryptUseDES:(NSString *)cipherText key:(NSString *)key;
  6. +(NSString *) encryptUseDES:(NSString *)plainText key:(NSString *)key;
  7. @end

DESUtils.m:

  1. #import "DESUtils.h"
  2. @implementation DESUtils
  3. +(NSString *)decryptUseDES:(NSString *)cipherText key:(NSString *)key
  4. {
  5. NSString *plaintext = nil;
  6. NSData *cipherdata = [Base64 decode:cipherText];
  7. unsigned char buffer[1024];
  8. memset(buffer, 0, sizeof(char));
  9. size_t numBytesDecrypted = 0;
  10. CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmDES,
  11. kCCOptionPKCS7Padding,
  12. [key UTF8String], kCCKeySizeDES,
  13. (Byte *)[[key dataUsingEncoding:NSUTF8StringEncoding] bytes],
  14. [cipherdata bytes], [cipherdata length],
  15. buffer, 1024,
  16. &numBytesDecrypted);
  17. if(cryptStatus == kCCSuccess) {
  18. NSData *plaindata = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted];
  19. plaintext = [[NSString alloc]initWithData:plaindata encoding:NSUTF8StringEncoding];
  20. }
  21. return plaintext;
  22. }
  23. +(NSString *) encryptUseDES:(NSString *)plainText key:(NSString *)key
  24. {
  25. NSString *ciphertext = nil;
  26. NSData *textData = [plainText dataUsingEncoding:NSUTF8StringEncoding];
  27. NSUInteger dataLength = [textData length];
  28. unsigned char buffer[1024];
  29. memset(buffer, 0, sizeof(char));
  30. size_t numBytesEncrypted = 0;
  31. CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
  32. kCCOptionPKCS7Padding,
  33. [key UTF8String], kCCKeySizeDES,
  34. (Byte *)[[key dataUsingEncoding:NSUTF8StringEncoding] bytes],
  35. [textData bytes], dataLength,
  36. buffer, 1024,
  37. &numBytesEncrypted);
  38. if (cryptStatus == kCCSuccess) {
  39. NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
  40. ciphertext = [Base64 encode:data];
  41. }
  42. return ciphertext;
  43. }
  44. @end

© 2014, 冰冻鱼. 请尊重作者劳动成果,复制转载保留本站链接! 应用开发笔记

iOS开发:用DES对字符串加解密的更多相关文章

  1. 李洪强iOS开发Swift篇—03_字符串和数据类型

    李洪强iOS开发Swift篇—03_字符串和数据类型 一.字符串 字符串是String类型的数据,用双引号""包住文字内容  let website = "http:// ...

  2. android中使用jni对字符串加解密实现分析

    android中使用jni对字符串加解密实现分析 近期项目有个需求.就是要对用户的敏感信息进行加密处理,比方用户的账户password,手机号等私密信息.在java中,就对字符串的加解密我们能够使用A ...

  3. iOS开发-通过正则表达式判断字符串是否为纯阿拉伯数字

    iOS开发-通过正则表达式判断字符串是否为纯阿拉伯数字 简述:NSString * regex_0 = @"\\d{1,}";   /*允许首位为0*/ NSString * re ...

  4. DES跨(C# Android IOS)三个平台通用的加解密方法

          #region   跨平台加解密(c# 安卓 IOS)       //  public static string sKey = "12345678";       ...

  5. iOS - (base64对字符串加解密)

    今天公司让做支付系统,为了安全起见,需要对一些数据进行加密,然而我首想到的就是 base64 ,严格来说这不是一种加密方式,这只是将原有的一些字符串或者其它的一些文本进行一个转化而已,就是转化成数字, ...

  6. DES,AeS加解密,MD5,SHA加密

    1.DES一共就有4个参数参与运作:明文.密文.密钥.向量.其中这4者的关系可以理解为: 密文=明文+密钥+向量: 明文=密文-密钥-向量: 为什么要向量这个参数呢?因为如果有一篇文章,有几个词重复, ...

  7. 在ios开发中有多少常用的加密解密方式(备用)

    最常用的是MD5和base64编码,还有DES 3DES AES加密 ios怎么实现RAS加密解密 最近几天折腾了一下如何在iOS上使用RSA来加密.iOS上并没有直接的RSA加密API.但是iOS提 ...

  8. [IOS 开发] NSDateFormatter的格式字符串 -- 《整理的笔记》

    在ios开发中, OBjective-C中的NSDate是一个挺讨厌的类型, 自己找不到转换成字符串的类型,还得带一个NSDateFormatter的类型. 官方文档上对NSDateFormatter ...

  9. C#常用字符串加解密方法封装

    C#中常用的字符串加密.解密方法封装,包含只加密但不解密的方法.收藏起来备用. //方法一 //须添加对System.Web的引用 //using System.Web.Security; /// & ...

随机推荐

  1. Python高级语法总结

    1.Python面向对象 创建类 使用class语句来创建一个新类,class之后为类的名称并以冒号结尾,如下实例: class ClassName: '类的帮助信息' #类文档字符串 class_s ...

  2. HAOI2017游记

    HACF的最终成绩已经出炉,但是事情还没有结束. 好多想说的,不知道从何说起,就按照时间顺序说吧. 考前 考前大概一周半就开始复习了,一些比较重要的算法,比如KDT,单纯性,线性基等等没有再继续学,所 ...

  3. K8S dashboard 创建只读账户

    1.创建名字为“Dashboard-viewonly“的Cluster Role,各种资源只给予了list,get,watch的权限.dashboard-viewonly.yaml --- apiVe ...

  4. Spring Boot + Swagger

    前言: 在互联网公司, 微服务的使用者一般分为两种, 客户端和其他后端项目(包括关联微服务),不管是那方对外提供文档 让别人理解接口 都是必不可少的.传统项目中一般使用wiki或者文档, 修改繁琐,调 ...

  5. jQuery UI基本使用方法

    其实jQuery UI早就在我的学习计划中,只不过因为计划安排始终处于待命状态,最近项目要用到jQuery UI,就提前学习一下,也想能够封装自己的UI库,这样就不用老按照别人的套路走了,像使用jQu ...

  6. ArrayList既然继承自AbstractList抽象类,而AbstractList已经实现了List接口,那么ArrayList类为何还要再实现List接口呢?

    https://www.cnblogs.com/bluejavababy/p/4320545.html

  7. koa源码阅读[0]

    koa源码阅读[0] Node.js也是写了两三年的时间了,刚开始学习Node的时候,hello world就是创建一个HttpServer,后来在工作中也是经历过Express.Koa1.x.Koa ...

  8. Unity 添加鼠标右键事件

    把此类放到 Editor下使用就OK using UnityEngine; using System.Collections; using System.Collections.Generic; us ...

  9. android内存回收顺序

    最近做项目的时候,经常会考虑到系统回收进程,释放资源等问题.特别查找了相关资料,了解下android内存回收顺序以及回收场景. 下面内容都为网络查找资料,若有错误,欢迎指出. 以下顺序,依次被回收的可 ...

  10. 【nginx+tomcat集群】Nginx1.12.2+Tomcat7集群+负载均衡+Session共享

    今天想着将项目优化一下,就想的实现集群分布,在本机测试:利用nginx+tomcat实现 通过上一篇博客(http://www.cnblogs.com/qlqwjy/p/8535235.html),N ...