参考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. uC/OS-II之入门与介绍20160525

    说一下刚学习uCOS的心得1)首先强调一下实时操作系统(RTOS)的特点,最明显的是提供及时响应和高可靠性2)基于实施操作系统的应用程序设计中,其中很重要的一个概念是"任务",任务 ...

  2. Selective Search for Object Recognition

    http://blog.csdn.net/charwing/article/details/27180421 Selective Search for Object Recognition 是J.R. ...

  3. PID控制算法的C语言实现七 梯形积分的PID控制算法C语言实现

    在PID控制律中积分项的作用是消除余差,为了减小余差,应提高积分项的运算精度,为此,可将矩形积分改为梯形积分. 梯形积分的计算公式为: pid.voltage=pid.Kp*pid.err+index ...

  4. 保护程序猿滴眼睛---修改VS 2012 编辑器颜色

    转载于http://blog.csdn.net/qing666888/article/details/8973216 字体,发现好多人选用 Consolas  ...确实挺好看的. 然后 修改背景色: ...

  5. Codeforce 633.C Spy Syndrome 2

    C. Spy Syndrome 2 time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  6. 1.UiDevice API 详细介绍

    1.UiDevice按键与keycode使用 返回值 方法名 说明 boolean pressBack() 模拟短按返回back键 boolean pressDPadCenter() 模拟按轨迹球中点 ...

  7. Turkey HSD检验法/W法

    sklearn实战-乳腺癌细胞数据挖掘(博主亲自录视频) https://study.163.com/course/introduction.htm?courseId=1005269003&u ...

  8. 在vue中使用animate.css

    animate.css是一款前端动画库,相似的有velocity-animate 用法: 首先 npm install animate.css --save 然后在vue文件的script中引入: i ...

  9. eclipse常用快捷键大全 (转)

    Eclipse中10个最有用的快捷键组合  一个Eclipse骨灰级开发者总结了他认为最有用但又不太为人所知的快捷键组合.通过这些组合可以更加容易的浏览源代码,使得整体的开发效率和质量得到提升.    ...

  10. ZOJ 3778 C - Talented Chef 水题

    LINK:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3778 题意:有n道菜,每道菜需要\(a_i\)道工序,有m个锅可 ...