From 0cf0870889d65f5d11d0b2c8af7bca9442a7ba19 Mon Sep 17 00:00:00 2001 From: cloudroam <cloudroam> Date: 星期一, 21 四月 2025 17:14:50 +0800 Subject: [PATCH] Merge branch 'master' of http://47.96.225.205:8888/r/FirstApp2 --- app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt | 194 ++++++++++++++++++++++++++---------------------- 1 files changed, 105 insertions(+), 89 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 3ee32a5..8cbd3f3 100644 --- a/app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt +++ b/app/src/main/java/com/example/firstapp/receiver/SmsReceiver.kt @@ -12,28 +12,27 @@ import com.example.firstapp.core.Core import com.example.firstapp.database.entity.Code import com.example.firstapp.database.entity.Msg -import com.example.firstapp.database.repository.KeywordRepository -import com.example.firstapp.entity.Rule +import com.example.firstapp.database.service.RetrofitClient +import com.example.firstapp.database.service.RetrofitModelClient import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch import java.text.SimpleDateFormat import java.time.LocalDateTime import java.time.ZoneId -import java.time.format.DateTimeFormatter import java.util.Date import java.util.Locale +import com.example.firstapp.utils.CodeUtils class SmsReceiver : BroadcastReceiver() { + // 安全防护关键词数组 + private var securityKeywordsList = emptyList<String>() @RequiresApi(Build.VERSION_CODES.O) override fun onReceive(context: Context, intent: Intent) { - - // 检查广播的 Action 是否为短信接收 if (Telephony.Sms.Intents.SMS_RECEIVED_ACTION == intent.action) { - // 获取短信内容 val bundle: Bundle? = intent.extras bundle?.let { val pdus = it.get("pdus") as Array<*> @@ -45,95 +44,112 @@ messageBody.append(messages[i]?.messageBody) } - // 输出短信内容到控制台 - Log.d("SmsReceiver", "Received SMS: ${messageBody.toString()}") - val msg = Msg(0, "1111", "111111", messageBody.toString(),1, "111", 1, 1) + // 保存原始短信 + val msg = Msg(0, "1111", "111111", messageBody.toString(), 1, "111", 1, 1) val msgId = Core.msg.insert(msg) - Log.d("SmsReceiver", "Received SMS msgId: ${msgId}") - // 这里我要写个数组,并创建个对象存放一些内容,如这个对象的属性有匹配内容,正则表达式,并循环遍历 - val ruleList = mutableListOf( - Rule("快递","京东","\\d{6}"), - Rule("快递","菜鸟驿站","\\d{1,2}-\\d{1,2}-\\d{4}") - ) - - CoroutineScope(Dispatchers.IO).launch { - Log.d("SmsReceiver", "CoroutineScope started") - // 获取最新的关键词配置 - val keywords = Core.keyword.getKeywords() - Log.d("keywords", keywords.toString()) - keywords.forEach { keyword -> - ruleList.add( - Rule( - keyword.type, - keyword.keyword, - "\\d{1,2}-\\d{1,2}-\\d{4}" - ) - ) - } - Log.d("RuleList", ruleList.toString()) - - for (rule in ruleList) { - val code = rule.extractCodeFromMessage(messageBody.toString()) - if (code!==null) { - // 转换为 Date 对象 - val currentTime = LocalDateTime.now() - // 将 LocalDateTime 转换为 Date - val date = Date.from(currentTime.atZone(ZoneId.systemDefault()).toInstant()) - // 如果需要格式化显示 - val sdf = SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.getDefault()) - val overtime = sdf.format(date) - val existingCode = Core.code.queryByTypeAndCodeAndDate(rule.content, code, overtime) - if (existingCode == null) { - val code = Code(0, rule.type, 1, rule.content, 1, 1, msgId, code, overtime, "中通") - Core.code.insert(code) - Log.d("SMS_DEBUG", "新短信已保存到数据库") - - // 发送广播通知数据已更新 - //"com.example.firstapp.DATA_UPDATED" 是一个自定义的广播 Action,相当于一个标识符或者说是一个频道名称。这个名称是我们自己定义的,通常使用应用的包名作为前缀,以避免与其他应用的广播冲突。 - val updateIntent = Intent("com.example.firstapp.DATA_UPDATED") - context.sendBroadcast(updateIntent) - Log.d("SMS_DEBUG", "发送数据更新广播") - }else{ - Log.d("SmsReceiver", "Received SMS code: 已存在相同记录,不保存") - } - }else{ - Log.d("SmsReceiver", "Received SMS code: 没有匹配到内容") - } - } + // 这里需要查看消息是否含有securityKeywordsList这个列表中的关键词,如果含有,则不进行下一步操作 + if (securityKeywordsList.any { it in messageBody.toString() }) { + Log.d("SmsReceiver", "含有禁用关键词,${it}") + return } + Log.d("SmsReceiver", "运行到正则匹配") - // kotlin 怎么创建一个类 -// for (rule in ruleList) { -// val code = rule.extractCodeFromMessage(messageBody.toString()) -// -// if (code!==null) { -// Log.d("SmsReceiver", "Received SMS code: ${code}") -// -// -// // 获取当前时间 -// val currentTime = LocalDateTime.now() -// // 加2小时 -// val futureTime = currentTime.plusHours(2) -// // 定义时间格式 -// val formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss") -// // 转换为字符串 -// val overtime = futureTime.format(formatter) -// // 封装成一个Code对象,并保存在数据库中 -// val code = Code(0, rule.type,1, rule.content,1, 1, msgId, code, overtime) -// Core.code.insert(code) -// Log.d("SMS_DEBUG", "新短信已保存到数据库") -// // 发送广播通知数据已更新 -// //"com.example.firstapp.DATA_UPDATED" 是一个自定义的广播 Action,相当于一个标识符或者说是一个频道名称。这个名称是我们自己定义的,通常使用应用的包名作为前缀,以避免与其他应用的广播冲突。 -// val updateIntent = Intent("com.example.firstapp.DATA_UPDATED") -// context.sendBroadcast(updateIntent) -// Log.d("SMS_DEBUG", "发送数据更新广播") -// }else{ -// Log.d("SmsReceiver", "Received SMS code: 没有匹配到内容") -// } -// } + // 调用API处理短信 + CoroutineScope(Dispatchers.IO).launch { + try { + val response = + RetrofitModelClient.modelService.processSms(mapOf("content" to messageBody.toString())) + if (response.status == "success") { + // 获取当前时间 + val currentTime = LocalDateTime.now() + val date = + Date.from(currentTime.atZone(ZoneId.systemDefault()).toInstant()) + 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) + } + + "还款" -> { + 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.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 updateIntent = Intent("com.example.firstapp.DATA_UPDATED") + context.sendBroadcast(updateIntent) + Log.d("SMS_DEBUG", "新短信已保存到数据库") + } + } catch (e: Exception) { + Log.e("SmsReceiver", "Error processing SMS", e) + } + } } } } -- Gitblit v1.9.3