毕业设计_Android短信查询及加密系统_会话加密

2024-06-14 02:18

本文主要是介绍毕业设计_Android短信查询及加密系统_会话加密,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    下面是我的毕业设计,是一个Android的短信查询系统,系统支持根据短信号码、短信内容、短信发生时间进行多条件的短信查询。支持检索条件的与运算和或运算。扩展了会话加密、转发/存短信、收/发短信等功能。需要强调的是本人菜鸟,东西做的不好,路过的大侠见了可不要喷我,谢谢!下面是程序的运行截图:

                               

图1.程序欢迎动画

 

     这里需要做下说明,因为查询系统短信是通过ContentResolver得到Cursor来实现的,正如我上次说到的那样,我无法使用Cursor进行短信数据的多条件查询,又不能得到短信数据库的SQLiteDatabase的引用,所以在做多条件查询时,我是先将要查询的数据备份到我的应用程序中,再得到相应的SQLiteDatabase对象,从而实现多条件查询功能。那么这里的查询数据的准备就是需要考虑的问题,这里设置一个欢迎动画主要就是为了准备查询数据的。

                               

                                

 图2.会话列表界面

 

        这里用户可以通过在某个会话列表项上通过长按弹出操作选项列表,特别的是加密会话。用户可以为任意一个会话指定一个标识符及对应的密码。被加密的会话需要输入正确的密码才能进行访问。

                              

 图3.会话加密过程

       

       上图为一个会话列表项设置了一个标识符Tom及一个密码ttt来实现了一个会话的加密功能。这里主要是通过新建自己的加密数据库,数据库中包含字段:标示符(主键)、会话id(即sms数据表中的thread_id字段)、密码、是否可读、是否上锁。所以会话列表(图2)初始化的过程中首先从短信数据表和联系人数据表中读取到数据,再将得到的数据与加密数据库中的数据比较,从而实现会话列表的显示过程。其实这里,通过Eclipse的File Explorer观察发现在android的mmssms数据库中的threads数据表中是包含会话列表的所需显示信息的(最后一次通信内容、最后一个通信时间、thread_id、包含的短信条数),不过,经过却始终找不到该数据表的引用URI,所以,这能一条条的来检索短信记录,从而得到会话列表中的数据。这里,就是想问一下,哪位大侠知道怎么引用threads中的数据,知道的告诉我一下,这里先谢了!

        这里需要注意的是,有加密就必须要有解密。出于用户数据隐私的考虑,会话数据有三种阅读状态,分别是未加密的正常短信、已加密但却解读的会话、已加密且未解读的短信。这里的解读表示在用户操作本软件的时间里,数据是可读的,一旦程序失去了用户输入焦点,解读的会话内容会自动重新上锁。而解密则表示彻底解锁该会话,即该会话内容会变得和正常会话一样。

                              

 图 4.解读/密过程

 

        如上图所示,解读/密过程需要注意的就是什么时候进行会话解读验证,什么时候进行会话的重新上锁。这里程序是通过设定一个全局变量IS_NEED_LOCK(true表示需要上锁,false表示不需要)来标记是否需要上锁显示。在活动的onStop方法中将上锁标记置true,即表示需要上锁的,在活动的onResume方法中根据上锁标记提交操作到加密数据库。

        这里需要注意的是,因为使用Activity的活动周期方法来实现解密过程。所以这里可能有一种情况,如:从某个具体的会话界面跳转到会话列表,此时会调用会话列表活动的onResume,但此时我们并不需要为会话列表重新上锁。所以,可能使用startActivityForResult方法来实现活动的跳转,并在其中传入标记,来区分什么时候需要为会话重新上锁,什么时候不需要。

        好了,加密过程就这样先。介绍的可能有些粗糙,但实现过程已经大概介绍到了。写的不好,望路过的大侠能够见谅,毕竟我只是一只菜鸟。

这篇关于毕业设计_Android短信查询及加密系统_会话加密的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1059091

相关文章

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序