From c3edd4a3122b711bc6a0bfef56b6ff6bf5ae03e2 Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期二, 13 五月 2025 09:09:23 +0800
Subject: [PATCH] feat(generallibrary): 优化用户开卡流程并添加支付方式功能

---
 generallibrary/src/main/java/com/dayu/general/tool/GeBaseHelper.kt |   44 ++++++++++++++++++++++++--------------------
 1 files changed, 24 insertions(+), 20 deletions(-)

diff --git a/generallibrary/src/main/java/com/dayu/general/tool/GeBaseHelper.kt b/generallibrary/src/main/java/com/dayu/general/tool/GeBaseHelper.kt
index 1a80899..c007a9b 100644
--- a/generallibrary/src/main/java/com/dayu/general/tool/GeBaseHelper.kt
+++ b/generallibrary/src/main/java/com/dayu/general/tool/GeBaseHelper.kt
@@ -1,43 +1,47 @@
 package com.dayu.general.tool
 
 import android.content.Context
-import android.util.Base64
 import com.dayu.baselibrary.tools.HexUtil
 import com.dayu.baselibrary.tools.nfc.BaseNFCHelper
-import java.nio.charset.StandardCharsets
-import javax.crypto.Cipher
-import javax.crypto.spec.SecretKeySpec
 
 open class GeBaseHelper(private val context: Context) : BaseNFCHelper() {
 
-
     companion object {
         init {
-            System.loadLibrary("general-native-lib")
+            try {
+                System.loadLibrary("general-native-lib")
+            } catch (e: UnsatisfiedLinkError) {
+                e.printStackTrace()
+            }
         }
     }
 
     private external fun getM1SectorKeySecure(context: Context, sectorIndex: Int): String
 
     init {
-        try {
-            // 鑾峰彇鎵�鏈夋墖鍖哄瘑閽�
-            val allKeys: String = getM1SectorKeySecure(context, 0)
-            val keys: Array<String> =
-                allKeys.split(",").dropLastWhile { it.isEmpty() }.toTypedArray()
-            for (i in keys.indices) {
-                val key = keys[i]
-                listA_PS.add(HexUtil.hexToByteArray(key))
+        if(listA_PS.isEmpty()){
+            try {
+                // 鑾峰彇鎵�鏈夋墖鍖哄瘑閽�
+                val allKeys: String = getM1SectorKeySecure(context, 0)
+                if (allKeys.isNotEmpty()) {
+                    val keys: Array<String> = allKeys.split(",").dropLastWhile { it.isEmpty() }.toTypedArray()
+                    for (i in keys.indices) {
+                        val key = keys[i]
+                        if (key.isNotEmpty()) {
+                            listA_PS.add(HexUtil.hexToByteArray(key))
+                        }
+                    }
+                }
+                defauleKey = HexUtil.hexToByteArray("FFFFFFFFFFFF")
+            } catch (e: Exception) {
+                e.printStackTrace()
+                // 璁剧疆榛樿瀵嗛挜
+                defauleKey = HexUtil.hexToByteArray("FFFFFFFFFFFF")
             }
-            defauleKey = HexUtil.hexToByteArray("FFFFFFFFFFFF")
-
-
-        } catch (e: Exception) {
-            e.printStackTrace()
         }
     }
 
     fun getKeyList(): List<ByteArray> {
-        return listKeyA
+        return listA_PS
     }
 }
\ No newline at end of file

--
Gitblit v1.8.0