监听短信数据库的变化,标记为read_already

本文介绍了一种使用Android平台实现短信管理的功能,通过注册短信变化监听并使用ContentObserver类来实时读取指定号码的短信,然后将未读短信状态自动更新为已读。
 

package ying.android;

import android.app.Activity;
import android.content.ContentValues;
import android.database.ContentObserver;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;

public class ScreenTest extends Activity {
 class SmsContent extends ContentObserver {
  private Cursor cursor = null;

  public SmsContent(Handler handler) {
   super(handler);
  }

  /**
   * @Description 当短信表发送改变时,调用该方法 需要两种权限 android.permission.READ_SMS 读取短信
   *              android.permission.WRITE_SMS 写短信
   */
  @Override
  public void onChange(boolean selfChange) {
   // TODO Auto-generated method stub
   super.onChange(selfChange);
   // 读取收件箱中指定号码的短信
   cursor = managedQuery(Uri.parse("content://sms/inbox"),
     new String[] { "_id", "address", "read" },
     " address=? and read=?",
     new String[] { "12345678901", "0" }, "date desc");
   if (cursor != null) {
    ContentValues values = new ContentValues();
    values.put("read", "1"); // 修改短信为已读模式
    cursor.moveToFirst();
    while (cursor.isLast()) {
     // 更新当前未读短信状态为已读
     getContentResolver().update(
       Uri.parse("content://sms/inbox"), values, " _id=?",
       new String[] { "" + cursor.getInt(0) });
     cursor.moveToNext();
    }
   }
  }
 }

 /** Called when the activity is first created. */
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  SmsContent content = new SmsContent(new Handler());
  // 注册短信变化监听
  this.getContentResolver().registerContentObserver(
    Uri.parse("content://sms/"), true, content);
 }
}

#include "server.h" char client_usernames[MAX_CLIENTS][64]; sqlite3 *db; // 全局用户登录状态数组 UserLoginStatus user_status[MAX_CLIENTS]; // 假设在 server.h 中定义 int handle_client(int client_idx, int client_fd) { char buffer[BUFFER_SIZE]; int bytes_read = read(client_fd, buffer, sizeof(buffer) - 1); if (bytes_read <= 0) { printf("客户端断开链接 %d\n", client_fd); // 清除登录状态 if (client_usernames[client_idx][0] != '\0') { for (int i = 0; i < MAX_CLIENTS; i++) { if (user_status[i].logged_in && strcmp(user_status[i].username, client_usernames[client_idx]) == 0) { user_status[i].logged_in = 0; user_status[i].username[0] = '\0'; break; } } } client_usernames[client_idx][0] = '\0'; return -1; } buffer[bytes_read] = '\0'; char cmd[16] = {0}; sscanf(buffer, "%15s", cmd); // 限制命令长度 if (strcmp(cmd, "F") == 0) { // 处理模糊查询命令 char *prefix = buffer + 2; // 跳过命令和空格 while (*prefix == ' ') prefix++; char result[BUFFER_SIZE * 10]; // 结果缓冲区 fuzzy_search(prefix, result, sizeof(result)); write(client_fd, result, strlen(result)); // 发送匹配结果 write(client_fd, "END_FUZZY", strlen("END_FUZZY") + 1); // 发送结束标记 } if (strcmp(cmd, "L") == 0) { char username[64] = {0}, password[64] = {0}; sscanf(buffer + 2, "%63s %63s", username, password); // 去掉命令部分,限制长度 int user_id = login_user(db, username, password); if (user_id > 0) { // 检查是否已登录 int already_logged_in = 0; for (int i = 0; i < MAX_CLIENTS; i++) { if (user_status[i].logged_in && strcmp(user_status[i].username, username) == 0) { already_logged_in = 1; break; } } if (already_logged_in) { write(client_fd, "Already logged in", strlen("Already logged in") + 1); return 0; } // 设置当前客户端登录状态 strncpy(client_usernames[client_idx], username, 63); user_status[client_idx].logged_in = 1; strncpy(user_status[client_idx].username, username, 63); write(client_fd, "Login successful", strlen("Login successful") + 1); } else { write(client_fd, "Login failed", strlen("Login failed") + 1); } } else if (strcmp(cmd, "R") == 0) { char username[64] = {0}, password[64] = {0}; sscanf(buffer + 2, "%63s %63s", username, password); if (register_user(db, username, password)) { strncpy(client_usernames[client_idx], username, 63); write(client_fd, "Registration successful", strlen("Registration successful") + 1); } else { write(client_fd, "Username already exists", strlen("Username already exists") + 1); } } else if (strcmp(cmd, "Q") == 0) { if (strlen(client_usernames[client_idx]) == 0) { write(client_fd, "Please login first", strlen("Please login first") + 1); return 0; } char *word_start = buffer + 2; // Skip "Q " while (*word_start == ' ') word_start++; // Skip spaces char word[64]; sscanf(word_start, "%63s", word); // 支持空格前跳过,但单词不能含空格 const char *meaning = search_meaning(word); write(client_fd, meaning, strlen(meaning) + 1); // 获取用户ID sqlite3_stmt *stmt; const char *sql = "SELECT id FROM users WHERE username = ?;"; if (sqlite3_prepare_v2(db, sql, -1, &stmt, NULL) == SQLITE_OK) { sqlite3_bind_text(stmt, 1, client_usernames[client_idx], -1, SQLITE_STATIC); if (sqlite3_step(stmt) == SQLITE_ROW) { int user_id = sqlite3_column_int(stmt, 0); log_query(db, user_id, word, meaning); } sqlite3_finalize(stmt); } } else if (strcmp(cmd, "H") == 0) { if (strlen(client_usernames[client_idx]) == 0) { write(client_fd, "Please login first", strlen("Please login first") + 1); return 0; } sqlite3_stmt *stmt; const char *sql = "SELECT id FROM users WHERE username = ?;"; if (sqlite3_prepare_v2(db, sql, -1, &stmt, NULL) == SQLITE_OK) { sqlite3_bind_text(stmt, 1, client_usernames[client_idx], -1, SQLITE_STATIC); if (sqlite3_step(stmt) == SQLITE_ROW) { int user_id = sqlite3_column_int(stmt, 0); send_history(db, client_fd, user_id); } sqlite3_finalize(stmt); } } else if (strcmp(cmd, "E") == 0) { // 客户端主动退出,清除登录状态 if (client_usernames[client_idx][0] != '\0') { for (int i = 0; i < MAX_CLIENTS; i++) { if (user_status[i].logged_in && strcmp(user_status[i].username, client_usernames[client_idx]) == 0) { user_status[i].logged_in = 0; user_status[i].username[0] = '\0'; break; } } client_usernames[client_idx][0] = '\0'; } return 1; } else { write(client_fd, "Unknown command", strlen("Unknown command") + 1); } return 0; } 请根据client_handlie模块代码修改main.c代码 #include "server.h" char client_usernames[MAX_CLIENTS][64] = {0}; UserLoginStatus user_status[MAX_CLIENTS] = {0}; // 初始化为0 sqlite3 *db; int main() { init_clients(); if (init_database(&db) != 0) { fprintf(stderr, "初始化数据库失败\n"); return 1; } if (load_dictionary() != 0) { fprintf(stderr, "加载词典失败\n"); sqlite3_close(db); return 1; } int server_fd = start_server(PORT); accept_clients(server_fd); sqlite3_close(db); close(server_fd); return 0; }
08-25
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值