App 数据安全测试

一、简介

Android App 本地数据存储是使用 SQLite 数据库,SQLite 是遵守ACID 的关系数据库管理系统,它包含在一个相对小的 C 程序库中。与许多其他数据库管理系统不同,SQLite 不是一个客户端/服务端结构的数据库引擎,而是被集成在用户程序中。

在 Android 中选择 SQLite 的原因是其内存占用较低不需要设置或配置数据库,并且可以在应用程序中直接调用。

二、获取 SQLite 文件

SQLite 数据库默认在 Android 中存储在 /data/data/[package name]/databases/ 位置,拓展名为 .db 文件,注意 Android 设备需要root。

1、进入设备的 /data/data目录,查找对应的测试包.

2、这里获取包 com.xueqiu.android 的db文件为例,进入包文件 databases 目录内部可以看到如下 db 文件。

3、退出adb shell ,将需要的db文件拷贝出来

三、查看SQLite 文件

导出 db 文件后可以使用 DB Browser for SQLite 来查看数据内容。

下载地址  Downloads - DB Browser for SQLite  根据自己的系统版本来选择安装即可。

1、启动应用,依次点击菜单栏: 文件->打开数据库,选择打开拷贝出来的db文件即可查看数据库表结构和内容

2、点击 浏览数据 菜单可以查看表具体数据内容,或者点击 执行SQL 进行查询

四、SQLite 数据安全

SQL注入

如果通过应用获取用户输入的数据并将其插入 SQLite数据库,就有可能发生SQL注入攻击的安全问题。

SQL注入,就是通过把SQL命令插入到表单提交或者输入域名的查询字符串,最终达到欺骗服务器执行恶意的 SQL 命令

例如,有一个表单,用户可以输入name

$name = $_GET['name'];

$dbh->query("SELECT * FROM users WHERE name='{$name}'");

那么当用户输入的name为 python';DELETE FROM user; ' 时会变成什么?

SELECT * FROM users WHERE name='python';DELETE FROM user;'';

这条语句执行运行一下,会把我们的user 表清空。

五、预防SQL注入

防止 SQL 注入,需要注意以下几个要点:

1、不要相信用户的输入

2、对用户的输入进行校验,可以通过正则表达式,或者限制长度;对单引号和双引号进行转换等。

3、不要使用动态拼装 SQL ,可以使用 SQL 预处理语句

4、不要使用管理员权限的数据库连接,为每个应用使用单独的权限有限的数据库连接。

5、不要把机密信息直接存放,加密或者 hash 掉密码和敏感的信息。

6、应用的异常信息应该给出尽可能少的提示,最好使用自定义的错误信息对原始错误信息进行包装。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于应用程序的安全性测试,可以采取以下步骤: 1. 静态代码分析:使用静态代码分析工具来检测潜在的安全漏洞,如未经验证的输入、不安全的函数使用等。 2. 动态应用程序安全测试(DAST):使用自动化工具模拟攻击,测试应用程序的弱点和漏洞。这包括输入验证、身份验证、会话管理、访问控制等方面的测试。 3. 漏洞扫描:使用漏洞扫描工具对应用程序进行扫描,以发现已知的漏洞和安全弱点。这些工具可以检查操作系统、应用程序、数据库等方面的安全漏洞。 4. 安全代码审查:仔细审查应用程序的代码,查找潜在的安全风险和漏洞。这需要对应用程序的源代码进行详细分析,以确保没有存在安全问题的代码。 5. 渗透测试:雇佣安全专家模拟真实攻击来测试应用程序的安全性。他们会尝试从外部或内部入侵系统,以评估应用程序的安全性,并提供改进建议。 6. 数据加密和安全传输:确保应用程序中的敏感数据在传输和存储过程中得到适当的加密保护。使用安全的传输协议(如HTTPS)来保护数据的传输。 7. 访问控制和权限管理:实施适当的访问控制和权限管理机制,以确保只有授权用户可以访问敏感数据和功能。 8. 安全更新和漏洞修复:定期更新应用程序的组件和库,修复已知的漏洞,并监测新的安全威胁。 以上是一些常见的应用程序安全性测试方法,根据应用程序的特点和需求,可以灵活选择适合的测试方法来确保应用程序的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值