更新时间:2023-11-10 17:40:22
Swift 2.0
Swift 2.0
没有必要使用bzero,getCString,malloc,这是一个不包含以下示例:
It is not necessary to use bzero, getCString, malloc, here is an example that does not:
将Security.framework添加到项目中
将#import添加到桥接头中.
Add Security.framework to the project
Add #import to the bridging header.
// operation is either 'kCCEncrypt' or 'kCCDecrypt'
func testCrypt(data data:NSData, keyData:NSData, operation:Int) -> NSData? {
let keyBytes = UnsafePointer<UInt8>(keyData.bytes)
let dataLength = Int(data.length)
let dataBytes = UnsafePointer<UInt8>(data.bytes)
let cryptData: NSMutableData! = NSMutableData(length: Int(dataLength) + kCCBlockSizeAES128)
let cryptPointer = UnsafeMutablePointer<UInt8>(cryptData.mutableBytes)
let cryptLength = size_t(cryptData.length)
let keyLength = size_t(kCCKeySizeAES128)
let algoritm: CCAlgorithm = UInt32(kCCAlgorithmAES128)
let options: CCOptions = UInt32(kCCOptionECBMode + kCCOptionPKCS7Padding)
var numBytesEncrypted :size_t = 0
let cryptStatus = CCCrypt(CCOperation(operation),
algoritm,
options,
keyBytes, keyLength,
nil,
dataBytes, dataLength,
cryptPointer, cryptLength,
&numBytesEncrypted)
if UInt32(cryptStatus) == UInt32(kCCSuccess) {
cryptData.length = Int(numBytesEncrypted)
} else {
print("Error: \(cryptStatus)")
}
return cryptData;
}
示例用法:
let keyData = "12345678901234567890123456789012".dataUsingEncoding(NSUTF8StringEncoding)
let messageData = "Don´t try to read this text. Top Secret Stuff".dataUsingEncoding(NSUTF8StringEncoding)
let encrypted = testCrypt(data:messageData!, keyData:keyData!, operation:kCCEncrypt)
这是UInt8的Swift Arrays
中的版本,没有NSData
对象:
Here is version in Swift Arrays
of UInt8 with no NSData
objects:
func testCrypt(data data:[UInt8], keyData:[UInt8], operation:Int) -> [UInt8]? {
let keyBytes = UnsafeMutablePointer<UInt8>(keyData)
let dataLength = data.count
let dataBytes = UnsafeMutablePointer<UInt8>(data)
var cryptData = [UInt8](count:data.count+kCCBlockSizeAES128, repeatedValue:0)
let cryptPointer = UnsafeMutablePointer<UInt8>(cryptData)
let cryptLength = size_t(cryptData.count)
let keyLength = size_t(kCCKeySizeAES128)
let algoritm: CCAlgorithm = UInt32(kCCAlgorithmAES128)
let options: CCOptions = UInt32(kCCOptionECBMode + kCCOptionPKCS7Padding)
var numBytesEncrypted :size_t = 0
let cryptStatus = CCCrypt(CCOperation(operation),
algoritm,
options,
keyBytes, keyLength,
nil,
dataBytes, dataLength,
cryptPointer, cryptLength,
&numBytesEncrypted)
if UInt32(cryptStatus) == UInt32(kCCSuccess) {
cryptData.removeRange(numBytesEncrypted..<cryptData.count)
} else {
print("Error: \(cryptStatus)")
}
return cryptData;
}
示例用法:
let keyData = Array("12345678901234567890123456789012".utf8)
let messageData = Array("Don´t try to read this text. Top Secret Stuff".utf8)
let encrypted = testCrypt(data:messageData, keyData:keyData, operation:kCCEncrypt)