上文基本完成了整个笔记本的笔记功能的实现, 接下来记录实现指纹识别加密以及一些小注意事项.
首先判断该手机是否具备指纹识别的硬件功能和用户是否开启指纹识别.
- public boolean isFinger() {
- // 用来检查是否有指纹识别权限
- if(checkCallingOrSelfPermission(Manifest.permission.USE_FINGERPRINT) ==
- PackageManager.PERMISSION_GRANTED) {
- if (!manager.isHardwareDetected()) {
- Toast.makeText(this, "没有指纹识别模块", Toast.LENGTH_SHORT).show();
- return false;
- }
- if (!mKeyManager.isKeyguardSecure()) {
- Toast.makeText(this, "没有开启锁屏密码", Toast.LENGTH_SHORT).show();
- return false;
- }
- if (!manager.hasEnrolledFingerprints()) {
- Toast.makeText(this, "没有录入指纹", Toast.LENGTH_SHORT).show();
- return false;
- }
- }
- return true;
- }
开始指纹识别
- public void startListening(FingerprintManager.CryptoObject cryptoObject) {
- //android studio 上, 没有这个会报错
- if (ActivityCompat.checkSelfPermission(this, Manifest.permission.USE_FINGERPRINT) != PackageManager.PERMISSION_GRANTED) {
- Toast.makeText(this, "没有指纹识别权限", Toast.LENGTH_SHORT).show();
- }
- manager.authenticate(cryptoObject, mCancellationSignal, 0, mSelfCancelled, null);
- }
首先查验用户是否赋予了本软件使用指纹识别的权限, 然后进行指纹识别请求. 其中 authentication 方法需要五个参数, 如下
- @RequiresPermission(USE_FINGERPRINT)
- public void authenticate(@Nullable CryptoObject crypto, @Nullable CancellationSignal cancel,
- int flags, @NonNull AuthenticationCallback callback, @Nullable Handler handler) {
- authenticate(crypto, cancel, flags, callback, handler, UserHandle.myUserId());
- }
第一个参数是加密对象可以使用对称式和非对称式加密, 或者不使用加密直接用 null
第二个参数是一个被用来取消认证的对象, 直接 new CancellationSignal()就可以.
第三个参数是可选标志, 推荐是 0
第四个参数是一个接受认证事件的对象
第五个参数是一个可选的回调事件处理器
以下是第四个认证事件的处理, 每个结果的处理过程如下
- FingerprintManager.AuthenticationCallback mSelfCancelled = new FingerprintManager.AuthenticationCallback() {
- @Override
- public void onAuthenticationError(int errorCode, CharSequence errString) {
- // 但多次指纹密码验证错误后, 进入此方法; 并且, 不能短时间内调用指纹验证
- Toast.makeText(MainActivity.this, errString, Toast.LENGTH_SHORT).show();
- showAuthenticationScreen();
- }
- @Override
- public void onAuthenticationHelp(int helpCode, CharSequence helpString) {
- // 出现错误, 可能是手指移动过快等问题
- Toast.makeText(MainActivity.this, helpString, Toast.LENGTH_SHORT).show();
- }
- @Override
- public void onAuthenticationSucceeded(FingerprintManager.AuthenticationResult result) {
- // 认证成功, 可以进入加密文档
- noteAdapter.openNote();
- }
- @Override
- public void onAuthenticationFailed() {
- Toast.makeText(MainActivity.this, "指纹识别失败", Toast.LENGTH_SHORT).show();
- }
- };
为防止多次验证不成功, 但是想通过锁屏密码进行解锁, 可以使用
- private void showAuthenticationScreen() {
- Intent intent = mKeyManager.createConfirmDeviceCredentialIntent("finger", "指纹识别失败次数过多, 请输入锁屏密码");
- if (intent != null) {
- startActivityForResult(intent, REQUEST_CODE_CONFIRM_DEVICE_CREDENTIALS);
- }
- }
- @Override
- protected void onActivityResult(int requestCode, int resultCode, Intent data) {
- if (requestCode == REQUEST_CODE_CONFIRM_DEVICE_CREDENTIALS) {
- // Challenge completed, proceed with using cipher
- if (resultCode == RESULT_OK) {
- noteAdapter.openNote();
- } else {
- Toast.makeText(this, "密码验证失败", Toast.LENGTH_SHORT).show();
- }
- }
- }
这样整个指纹解锁的流程就完成了
下面叙述一下整个项目中需要注意的一些地方
1. 关于新建笔记刷新问题, 之前是在 noteactivity 的 ondestory 的时候存储笔记, 在 noteadaper 的 getItemCount 中刷新数据库中笔记数量, 进行显示. 然而回到主页面的时候发现最新建的笔记没有出现在列表上, 这是因为 activity 生命周期的问题, 通过 log 记录下来, 发现 noteadapter 的 getItemCount 的执行要早于 noteactivity 的 ondestory 函数, 而晚于 onpause 函数, 所以将 storeNote 放在 onpause 中, 而不是 ondestory.
2. 修改笔记则可以直接在 mainactivity 的 onresume 函数中写 noetAdapter.notifyDataSetChanged 就可以了.
2. 新建一个笔记的时候, 可能用户只是不小心点击了一下新建笔记, 而并不想新增一条, 则可以在存储笔记的时候进行个简单判断, 内容是否为空.
3. 主页面笔记内容全显示问题, 可以设置 TextView 的以下属性, 来显示部分内容即可
- android:maxLines="1"
- android:lines="2"
- android:ellipsize="end"
同时, 还要注意在加载内容的时候要将加密信息内容隐去, 在这里我将加密信息统一显示为 "核心机密!!!".
来源: http://www.bubuko.com/infodetail-2573642.html