在使用人脸安卓端SDK的时候,往往有不少同学纠结于包名和MD5的事情,因为客户端SDK需要配合license授权文件使用,所以安卓端的包名和md5即为license生成的主要依据,下面分别仔细讲解一下,希望对大家有些帮助(微笑脸)
什么是包名?
每个 Android 应用均有一个唯一的应用 ID。安卓以 Java 包的形式管理应用。 具体说明见官方文档:https://developer.android.com/studio/build/application-id.html
什么是签名文件?
安卓apk需要开发者进行签名。开发调试过程中,IDE(android studio,Eclipse) 会使用默认的debug 签名文件进行签名。但发布apk时必须使用,自己生成的签名文件进行签名。签名文件确保了开发者对 该应用的所有权,因为不同签名文件签名的apk不能覆盖原有的。该文件扩展名为jks
如何生成新的签名文件?
您可以使用Android Studio生成应用签名或上传密钥,步骤如下:
- 在菜单栏中,点击Build->GenerateSignedAPK
- 从下拉菜单中选择一个模块,然后点击Next
- 点击Create new以创建一个新密钥和密钥库
- 在New Key Store窗口上,为您的密钥库和密钥提供以下信息,如下图所示:
密钥库
- Key store path:选择创建密钥库的位置。
- Password:为您的密钥库创建并确认一个安全的密码。
密钥
- Alias:为您的密钥输入一个标识名;
- Password:为您的密钥创建并确认一个安全的密码。此密码应当与您为密钥库选择的密码不同;
- Validity (years):以年为单位设置密钥的有效时长。密钥的有效期应至少为 25 年,以便您可以在应用的整个生命期内使用相同的密钥签署应用更新;
- Certificate:为证书输入一些关于您自己的信息。此信息不会显示在应用中,但会作为APK的一部分包含在您的证书中;
填写完表单后,请点击 OK。
具体说明见官方文档:https://developer.android.com/studio/publish/app-signing.html
什么是签名 MD5? 如何获取
每个签名文件都有一个数字指纹。相当于是公钥,同一个签名文件的指纹是一样的,不同的签名文件指纹不一样。可以通过检查这个指纹确定是不是使用的同一个签名文件。百度人脸鉴权服务使用的是 MD5方式的指纹。
命令行输入:
keytool –list –v –keystore <签名文件路径>
然后输入密码,会打印出该签名文件相关的信息。其中的一项是证书指纹 MD5,如下图所示:
为什么需要签名 MD5?
安卓的应用是以包名做为唯一ID的。百度的人脸服务也是以包名做为单位进行 授权的。因为包名是开发者填写的,所以别的开发者也可以写个应用来冒充其他人的应用。百度人脸服务会涉及到用户的信息,使用过程中也有费用产生。所以为了保护APP不会他人冒充,我们对应用的签名进行校验。刚才也提到了,因为MD5算法的不可逆性,可以当做公钥使用。用户在申请时在后台填写签名的MD5值,发布/测试时,使用该签名文件。人脸服务在运行时会对当前应用的签名MD5 进行校验,如果信息不一致会拒绝服务。
??郑凯启鹅??5310129??输入网??456qy點vip??输入網自带邀请玛??一 对 一 经历。最重要还是要找对一个能引领你的人我是这么认为的:心态只能让我们锦上添花,但是并不能给我们雪中送炭,一个人光有心态,肯定是不够的,只不过良好的心态可能让你亏的比较少而已,但是你也是在亏,因为心态根本解决不了概率的问题,概率问题是只有技术才能解决举个例子,一个人如果技术够好,那么他挂的可能性就比较小,一个人之所以心态不好,很多时候是因为连着挂,所以技术如果足够好,很多时候可以弥补我们心态的一些缺陷,所以技术远远要比心态重要的多,因为技术是肯本,心态只是辅助,两者缺一不可! 做任何一个行业,做任何一个事情,领路的人都是非常关键的,但是自己也要清楚,自身有实力才是真的,所以说有一句话师傅领进门修行靠个人,我玩这个这么多年了,我可以带你们!毕竟玩这个想要盈,只有两条路:一是靠自己的亏来学经验,不过很多人即使亏也未必能学到精髓;二是跟着过来人学习现成的经验;领路人一定要找对,会让你受益一生;选择大于 努力,眼光比能力跟重要,跟过我你就知道
666
111
哦诶日韩工【reh
大家可以通过这个方法试试