本文将演示如何使用Swift实现原生的SHA1加密。
首先创建一个桥接头文件,因为需要使用到OC语言的通用加密解密类库。
在项目文件夹【DemoApp】上点击鼠标右键,弹出右键菜单。
【New File】->【Header File】->【Next】->【Save As】:Header.h->【Create】
在该文件中,添加需要引用到的框架。
1 //添加需要引用到的框架 2 #ifndef _4_1_2SecurityProject_SHA1_Bridging_Header_h 3 #define _4_1_2SecurityProject_SHA1_Bridging_Header_h 4 5 #import <CommonCrypto/CommonCrypto.h> 6 7 #endif /* _4_1_2SecurityProject_SHA1_Bridging_Header_h */
点击项目名称【DemoApp】,显示项目的属性信息,
将头文件添加到桥接头选项中->【Build Settings】
->在搜索框内,输入需要定位的设置项目的名称:【Objective-C Bridging Hader】
->鼠标双击选项右侧【Objective-C Bridging Hader】,弹出桥接头文件设置窗口。
->在打开的输入窗口中,输入刚刚创建的头文件的相对路径:【DemoApp/Header.h】
现在创建类文件,实现具体加密操作。
在项目文件夹【DemoApp】上点击鼠标右键,弹出右键菜单。
【New File】->【Swift File】->【Next】->【Save As】:StringSHA1.swift->【Create】
1 import Foundation 2 3 //首先添加一个Int扩展 4 extension Int 5 { 6 //添加一个扩展方法,用来将整数类型,转换成十六进制的字符串。 7 func hexedString() -> String 8 { 9 //通过设置十六进制的格式, 10 //将自身转换成十六进制的字符串, 11 //并返回该字符串。 12 return NSString(format:"%02x", self) as String 13 } 14 } 15 16 //添加一个数据类型的扩展 17 extension NSData 18 { 19 //添加一个扩展方法,用来将数据类型,转换成十六进制的字符串。 20 func hexedString() -> String 21 { 22 //初始化一个字符串对象 23 var string = String() 24 25 //将不安全原始指针格式的字节, 26 //转换成不安全指针的格式 27 let unsafePointer = bytes.assumingMemoryBound(to: UInt8.self) 28 //添加一个循环语句 29 for i in UnsafeBufferPointer<UInt8>(start: unsafePointer, count: length) 30 { 31 //通过整形对象的扩展方法,将二进制数据转换成十六进制的字符串。 32 string += Int(i).hexedString() 33 } 34 //返回十六进制的字符串。 35 return string 36 } 37 38 //添加一个扩展方法,实现对数据的SHA1加密功能 39 func SHA1() -> NSData 40 { 41 //首先创建一个20位长度的可变数据对象。 42 let result = NSMutableData(length: Int(CC_SHA1_DIGEST_LENGTH))! 43 //将不安全原始指针格式的字节,转换成不安全指针的格式。 44 let unsafePointer = result.mutableBytes.assumingMemoryBound(to: UInt8.self) 45 //通过调用加密方法,对数据进行加密,并将加密后的数据,存储在可变数据对象中。 46 CC_SHA1(bytes, CC_LONG(length), UnsafeMutablePointer<UInt8>(unsafePointer)) 47 //最后将结果转换成数据格式对象并返回。 48 return NSData(data: result as Data) 49 } 50 } 51 52 //添加一个字符串类型的扩展。 53 extension String 54 { 55 //添加一个扩展方法,实现SHA1加密的功能。 56 func SHA1() -> String 57 { 58 //将字符串对象,转换成自定编码的数据对象 59 let data = (self as NSString).data(using: String.Encoding.utf8.rawValue)! as NSData 60 //调用数据对象的扩展方法,进行加密操作 61 //并返回十六进制的结果。 62 return data.SHA1().hexedString() 63 } 64 }
在项目导航区,打开视图控制器的代码文件【ViewController.swift】
现在开始编写代码,实现原生的SHA1加密。
1 import UIKit 2 3 class ViewController: UIViewController { 4 5 override func viewDidLoad() { 6 super.viewDidLoad() 7 // Do any additional setup after loading the view, typically from a nib. 8 9 //初始化一个待加密的字符串。 10 let message = "https://www.cnblogs.com/strengthen/" 11 //对字符串进行加密,并在控制台输出加密后的结果 12 print("Result:"+message.SHA1()) 13 //输出加密后的字符串的长度。 14 print("Length:\(message.SHA1().lengthOfBytes(using: String.Encoding.utf8))") 15 } 16 17 override func didReceiveMemoryWarning() { 18 super.didReceiveMemoryWarning() 19 // Dispose of any resources that can be recreated. 20 } 21 }