From 1a281d8354622a3606360f9f9a7fe4bb7d6a2c3a Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期日, 27 四月 2025 13:22:26 +0800
Subject: [PATCH] fix 短信
---
app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt | 144 ++++++++++++++++++++++++++----------------------
1 files changed, 78 insertions(+), 66 deletions(-)
diff --git a/app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt b/app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt
index 8cbd3f3..ed995b6 100644
--- a/app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt
+++ b/app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt
@@ -26,7 +26,10 @@
class SmsReceiver : BroadcastReceiver() {
-
+ // 添加一个静态同步锁对象
+ companion object {
+ private val syncLock = Any()
+ }
// 安全防护关键词数组
private var securityKeywordsList = emptyList<String>()
@@ -70,77 +73,86 @@
val sdf = SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.getDefault())
val createtime = sdf.format(date)
- // 根据不同类型处理数据
- when (response.data.category) {
- "快递" -> {
- val code = CodeUtils.createExpressCode(
- msgId = msgId,
- createTime = createtime,
- post = response.data.details.post,
- company = response.data.details.company,
- pickupCode = response.data.details.pickupCode,
- address = response.data.details.address,
- time = response.data.details.time
- )
- CodeUtils.saveCode(code)
- }
+ // 使用同步块处理保存操作
+ synchronized(syncLock) {
+ // 根据不同类型处理数据
+ when (response.data.category) {
+ "快递" -> {
+ val code = CodeUtils.createExpressCode(
+ msgId = msgId,
+ createTime = createtime,
+ post = response.data.details.post,
+ company = response.data.details.company,
+ pickupCode = response.data.details.pickupCode,
+ address = response.data.details.address,
+ time = response.data.details.time
+ )
+ //判断如果post不为空且长度超过10就不报错
+ if (response.data.details.pickupCode != null && response.data.details.pickupCode.length > 10) {
+ Log.e("SmsReceiver", "快递信息中的post字段为空或超过10")
+ } else {
+ CodeUtils.saveCode(code)
+ }
+ }
- "还款" -> {
- val code = CodeUtils.createRepaymentCode(
- msgId = msgId,
- createTime = createtime,
- type = response.data.details.type,
- bank = response.data.details.bank,
- amount = response.data.details.amount,
- date = response.data.details.date,
- address = response.data.details.address,
- minAmount = response.data.details.min_amount,
- number = response.data.details.number
- )
- CodeUtils.saveCode(code)
- }
+ "还款" -> {
+ val code = CodeUtils.createRepaymentCode(
+ msgId = msgId,
+ createTime = createtime,
+ type = response.data.details.type,
+ bank = response.data.details.bank,
+ amount = response.data.details.amount,
+ date = response.data.details.date,
+ address = response.data.details.address,
+ minAmount = response.data.details.min_amount,
+ number = response.data.details.number
+ )
+ CodeUtils.saveCode(code)
+ }
- "收入" -> {
- val code = CodeUtils.createIncomeCode(
- msgId = msgId,
- createTime = createtime,
- bank = response.data.details.bank,
- amount = response.data.details.amount,
- datetime = response.data.details.datetime,
- address = response.data.details.address,
- balance = response.data.details.balance
- )
- CodeUtils.saveCode(code)
- }
+ "收入" -> {
+ val code = CodeUtils.createIncomeCode(
+ msgId = msgId,
+ createTime = createtime,
+ bank = response.data.details.bank,
+ amount = response.data.details.amount,
+ datetime = response.data.details.datetime,
+ address = response.data.details.address,
+ balance = response.data.details.balance
+ )
+ CodeUtils.saveCode(code)
+ }
- "航班" -> {
- val code = CodeUtils.createFlightCode(
- msgId = msgId,
- createTime = createtime,
- company = response.data.details.company,
- start = response.data.details.start,
- end = response.data.details.end,
- seat = response.data.details.seat,
- time = response.data.details.time,
- address = response.data.details.address
- )
- CodeUtils.saveCode(code)
- }
+ "航班" -> {
+ val code = CodeUtils.createFlightCode(
+ msgId = msgId,
+ createTime = createtime,
+ company = response.data.details.company,
+ start = response.data.details.start,
+ end = response.data.details.end,
+ seat = response.data.details.seat,
+ time = response.data.details.time,
+ address = response.data.details.address
+ )
+ CodeUtils.saveCode(code)
+ }
- "火车票" -> {
- val code = CodeUtils.createTrainTicketCode(
- msgId = msgId,
- createTime = createtime,
- company = response.data.details.company,
- seat = response.data.details.seat,
- time = response.data.details.time,
- address = response.data.details.address,
- trips = response.data.details.trips
- )
- CodeUtils.saveCode(code)
+ "火车票" -> {
+ val code = CodeUtils.createTrainTicketCode(
+ msgId = msgId,
+ createTime = createtime,
+ company = response.data.details.company,
+ seat = response.data.details.seat,
+ time = response.data.details.time,
+ address = response.data.details.address,
+ trips = response.data.details.trips
+ )
+ CodeUtils.saveCode(code)
+ }
+
+ else -> {}
}
}
-
// 发送广播通知数据已更新
val updateIntent = Intent("com.example.firstapp.DATA_UPDATED")
context.sendBroadcast(updateIntent)
--
Gitblit v1.9.3