ios使用加密方式的地方:主要是在HTTP数据传输.那么另一端就是server了.
server的代码,现在一般是java写的
IOS代码
#import <CommonCrypto/CommonCryptor.h>
/******************************************************************************
函数名称 : + (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key
函数描述 : 文本数据进行DES加密
输入参数 : (NSData *)data
(NSString *)key
输出参数 : N/A
返回参数 : (NSData *)
备注信息 : 此函数不可用于过长文本
******************************************************************************/
+ (NSData *)DESEncrypt:(NSData *)data WithKey:(NSString *)key
{
char keyPtr[kCCKeySizeAES256+1];
bzero(keyPtr, sizeof(keyPtr));
[key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
NSUInteger dataLength = [data length];
size_t bufferSize = dataLength + kCCBlockSizeAES128;
void *buffer = malloc(bufferSize);
size_t numBytesEncrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
kCCOptionPKCS7Padding | kCCOptionECBMode,
keyPtr, kCCBlockSizeDES,
NULL,
[data bytes], dataLength,
buffer, bufferSize,
&numBytesEncrypted);
if (cryptStatus == kCCSuccess) {
return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
}
free(buffer);
return nil;
}
注意:
CCCrypt(CCOperation op, CCAlgorithm alg, CCOptions options,constvoid *key, size_t keyLength,constvoid *iv,constvoid *dataIn, size_t dataInLength,void *dataOut, size_t dataOutAvailable, size_t *dataOutMoved)
这个方法中,iv向量 我们设置的null. 如何使用这个方法主要是看服务端的解密代码怎么写的.
NSData *data = [WDCrypto DESEncrypt:[string dataUsingEncoding:NSUTF8StringEncoding] WithKey:@"abcd"];
//转换成16进制字符串
NSString *encodeString = [WDCrypto hexStringFromData:data];
一般情况下,java代码都会转成16进制字符串
下面附上data转16进制字符串的方法
+(NSString *)hexStringFromData:(NSData *)data{
Byte *bytes = (Byte *)[data bytes];
//下面是Byte 转换为16进制。
NSMutableString *hexStr = [NSMutableString string];
for(int i=0;i<[data length];i++){
NSString *newHexStr = [NSString stringWithFormat:@"%x",bytes[i]&0xff];///16进制数
if([newHexStr length]==1){
[hexStr appendFormat:@"0%@",newHexStr];
}else{
[hexStr appendFormat:@"%@",newHexStr];
}
}
return hexStr;
}