iOS 11 新特性 - App密码自动填充实现

在WWDC17上,苹果发布了iOS11,其中带来了App密码自动填充的这一新的API。这一功能的实现能够让用户更方便的管理密码,更容易在我们的应用上登录。

原文地址:http://www.zlucy.com/archives/84/

WWDC17相关视频地址:Introducing Password AutoFill for Apps

注意:要实现此功能,我们的网站需支持Https协议。

效果图

GitHub:Autofill-Demo

Demo App密码自动填充.jpeg
Demo App密码自动填充.jpeg

当需要用户填充用户名和密码时,在键盘的QuickType Bar(快速输入条)会给出候选的用户名与密码。

App的设置

  1. 设置 TextField 的 ContentType

在iOS11中,TextContentType新增加了UsernamePassword类型,我们只需要将相应的TextField设置为对应的ContentType即可。

TextContentType
TextContentType
XIB中设置ContentType
XIB中设置ContentType

这时候,用户已经可以在输入用户名与密码时,通过点击QuickType bar右侧的钥匙串按钮,在所有的保存的密码中选择要输入的用户名和密码了。

Demo
Demo

但是,这样还不是很方便,如果用户保存的密码很多,需要在列表中查找也并不很方便。我们需要在QuickType的候选区列出用户曾经在我们的网站保存过的密码,就像效果图那样。

  1. 设置Associated Domains
设置 Associated Domains
设置 Associated Domains

webcredentials后填写我们网站的Domain,即我们要关联的域名。

登录Apple开发者网站,

Apple开发者
Apple开发者
Apple开发者
Apple开发者
Apple开发者
Apple开发者

确认Associated Domains已经启用。同时,我们要记录一下当前应用的Prefix,后面会用到。

网站的设置

新建文件,内容如下:

{
    "webcredentials":{
        "apps":["${Prefix}.com.zlucy.Autofill-Demo"] //${Prefix}处填写我们上面记录下来的Prefix,后加上需关联的应用的 Bundle ID
    }
}

保存文件,命名为apple-app-site-association

我们需要在我们要关联的网站上添加这个文件,路径如下:

https://Domain.com/apple-app-site-association

网站设置完成。

再次运行我们的App,App会在启动时访问如上的地址进行验证,验证通过后,就可以看到如效果图一样的功能了。

验证时可能会出现错误:

Request for 'https://wrong.example.com/apple-app-site-association' denied: 404/0x194 Not Found

我们可以通过浏览器访问上面的地址,检查此文件是否可以正常访问。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容