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