国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Swift > 正文

Swift利用指紋識別或面部識別為應用添加私密保護功能

2020-03-09 17:41:54
字體:
來源:轉載
供稿:網友

前言

從最初做應用開始,我就密切關注用戶的反饋和評論。有時他們的要求確實并不合理,但當大多數人提到一項功能時,就該我們做產品的人反思了。 私密保護功能是用戶在評論中提到的,恰好像OneDay這樣比較私密的內容確實可以增加這項功能。

指紋識別和面部識別雖然是兩個很不相同的交互,但從開發的角度他們卻只需要一套代碼就可以搞定。在做之前我先解釋下整個實現過程的重要環節:

swift,指紋識別,人臉識別,應用

原理圖

1.我們需要一個數據來保存開關數據,在設置中心,用戶根據喜好選擇是否開啟保護

2.一旦用戶打開應用,通過判斷是否保護來加載遮擋頁面

3.在遮擋頁面自動實現解鎖過程,同時用戶也可以點擊后解鎖

4.根據機型的不同,在設置中心需要顯示不同的解鎖名稱

一、基礎配置工作

實現指紋識別與面部識別,都是通過添加LocalAuthentication Framework來實現的。

導入LocalAuthentication Framework

之后在需要用到認證的頁面,導入LocalAuthentication即可:

import LocalAuthentication

二、遮蓋頁創建與設置中心開關創建

在設置中心增加一欄開關,暫且叫做Touch ID,最后會進行標題文字的修復。 創建一個單獨的遮蓋頁,只需要放置一句話及按鈕即可,按鈕將調用認證過程,文件為LockViewContrller.swift/292074.html">swift/269454.html">swift。

swift,指紋識別,人臉識別,應用

為了方便調用,給遮蓋頁設置了StoryBoard ID為LockController。

swift,指紋識別,人臉識別,應用

四、設置中心實現數據的修改

利用CoreData將開關的數據存儲在ifProtect中,0表示開,1表示關。 設置數據的過程不會像其他數據那樣直接改變,必須判斷是否為用戶本人進行開關。所以在SettingViewController.swift中,需要添加認證的相關函數。

1.先導入LocalAuthentication:

import LocalAuthentication

2.操作函數:

func touchID(){  let context = LAContext()  var error: NSError?  if context.canEvaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, error: &error) {   // 開始進入識別狀態,以閉包形式返回結果。閉包的 success 是布爾值,代表識別成功與否。error 為錯誤信息。   context.evaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, localizedReason: "請用指紋解鎖", reply: {success, error in    if success {     // 成功之后的邏輯, 通常使用多線程來實現跳轉邏輯。     print("解鎖成功 success,允許設置")     if self.appDelegate.mysetting.ifProtect == Int64(1){      self.appDelegate.mysetting.ifProtect = Int64(0)     }else{      self.appDelegate.mysetting.ifProtect = Int64(1)     }     self.appDelegate.saveContext()    }else {     if let error = error as? NSError {      // 獲取錯誤信息      let message = self.errorMessageForLAErrorCode(errorCode: error.code)      print(message)     }     //失敗之后     print("失敗了")    }    self.SettingTableView.reloadData()   })  } }

當是用戶本人且認證成功時,開關數據被改變;當不是用戶本人或認證不成功,開關數據不會改變。 為了保持頁面與數據統一,函數執行后我們需要刷新頁面self.SettingTableView.reloadData()

3.獲取錯誤情況:

func errorMessageForLAErrorCode(errorCode: Int) -> String {  var message = ""  switch errorCode {  case LAError.appCancel.rawValue:   message = "Authentication was cancelled by application"  case LAError.authenticationFailed.rawValue:   message = "The user failed to provide valid credentials"  case LAError.invalidContext.rawValue:   message = "The context is invalid"  case LAError.passcodeNotSet.rawValue:   message = "Passcode is not set on the device"  case LAError.systemCancel.rawValue:   message = "Authentication was cancelled by the system"  case LAError.touchIDLockout.rawValue:   message = "Too many failed attempts."  case LAError.touchIDNotAvailable.rawValue:   message = "TouchID is not available on the device"   //   showPassWordInput()  case LAError.userCancel.rawValue:   message = "The user did cancel"  case LAError.userFallback.rawValue:   message = "The user chose to use the fallback"  default:   message = "Did not find error code on LAError object"  }  return message }

swift,指紋識別,人臉識別,應用

五、首頁加載遮蓋頁

來到首頁HomeViewController,在viewDidLoad中加入下面代碼,來判斷每一次打開應用是否需要認證解鎖。 如果不需要,首頁可以正常顯示; 如果需要,將直接跳轉到LockController。

if self.appDelegate.mysetting.ifProtect == Int64(1){ print(self.appDelegate.mysetting.ifProtect) print("需要解鎖")  if let lockVC = storyboard?.instantiateViewController(withIdentifier: "LockController") as? LockViewController {   self.present(lockVC,animated: false,completion: nil)  }else{  } }else{ print("不需要解鎖")}

六、在遮蓋頁中實現認證

遮蓋頁LockController的背景通過虛化處理,可以到達遮蓋的目的。同時擁有認證函數,當認證成功后頁面自動消失返回首頁。 因為需要認證過程,因此也需要三個核心步驟。

1.導入LocalAuthentication:

import LocalAuthentication

2.操作函數:

func touchID(){ let context = LAContext() var error: NSError? if context.canEvaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, error: &error) {  // 開始進入識別狀態,以閉包形式返回結果。閉包的 success 是布爾值,代表識別成功與否。error 為錯誤信息。  context.evaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, localizedReason: "請用指紋解鎖", reply: {success, error in   if success {    // 成功之后的邏輯, 通常使用多線程來實現跳轉邏輯。    print("解鎖成功 success")    self.dismiss(animated: true, completion: nil)   }else {    if let error = error as? NSError {     // 獲取錯誤信息     let message = self.errorMessageForLAErrorCode(errorCode: error.code)     print(message)    }    //失敗之后    print("失敗了")   }  }) }}

認證過程成功后,頁面會自動消失:self.dismiss(animated: true, completion: nil)

3.當用戶進入頁面時自動調取認證過程:

override func viewWillAppear(_ animated: Bool) {  touchID()}

4.或者通過手動點擊開始認證:

@IBAction func AuthenAction(_ sender: Any) {  touchID()}

5.捕獲錯誤跟設置頁面一樣。

swift,指紋識別,人臉識別,應用

七、根據屏幕尺寸修改開關標題

最后,我們來修復設置中心按鈕的標題文字。當判斷手機為iPhone X時,文字顯示為“面部識別”或“Touch ID”;當不是iPhone X時,顯示為“指紋識別”或“Touch ID”。這里我們用到了UIDevice來獲取了屏幕的高度:

if UIDevice().userInterfaceIdiom == .phone && UIScreen.main.nativeBounds.height == 2436 { cell.SwitchTitle.text = "Face ID" cell.SwitchImage.image = UIImage(named: "btn_setting_faceid")?.withRenderingMode(.alwaysTemplate)}else{ cell.SwitchTitle.text = "Touch ID" cell.SwitchImage.image = UIImage(named: "btn_setting_touchid")?.withRenderingMode(.alwaysTemplate)}

以上的過程便可實現私密保護,不過不會像系統解鎖那樣可以通過密碼解鎖。要實現密碼解鎖,還需要單獨開發該功能。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到swift教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 新泰市| 湘西| 水城县| 冕宁县| 饶河县| 黑龙江省| 综艺| 洛宁县| 扶风县| 康乐县| 尼玛县| 攀枝花市| 宜丰县| 盱眙县| 彩票| 福海县| 南雄市| 海城市| 子长县| 左权县| 莲花县| 南漳县| 宝兴县| 咸丰县| 毕节市| 娄底市| 琼海市| 田阳县| 洞头县| 青龙| 鹤壁市| 寿宁县| 新野县| 探索| 安仁县| 新绛县| 玛纳斯县| 玉山县| 印江| 弥勒县| 东乡族自治县|