android apk反编译安全检查----shared_preferences任意读写漏洞

本文介绍了如何检查和处理Android APK中的shared_prefs任意读写漏洞,通过反编译APK,查找getSharedPreferences方法,分析参数以确定安全风险,并提出了修改mode值和增强安全性的建议。
摘要由CSDN通过智能技术生成

测试某apk时,使用http://appscan.360.cn进行首次分析,报出存在shred_prefs任意读写的问题。于是研究一下测试思路。此文纯属个人分析,若有不对指出,还请指出。


一、shared_prefs任意读写漏洞的检查思路

1.apk进行反编译成smali语言

使用apktool的命令apktool d XX.apk -o OutputFolder即可。

2.遍历搜索

遍历OutputFolder文件夹中.samli文件,搜索里面是否有  getSharedPreferences方法。

3.判断getSharedPreferences方法传入的参数值

检查到getSharedPreferences方法后,进一步查看该方法的参数值,是否为0x01\0x02\0x03,它们分别表示可读、可写、可读可写

一个smali语言例子:


                
好的,这是一个使用 Flutter 操作 shared_preferences 的例程: ```dart import 'package:flutter/material.dart'; import 'package:shared_preferences/shared_preferences.dart'; class MyHomePage extends StatefulWidget { @override _MyHomePageState createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { int _counter = 0; @override void initState() { super.initState(); _loadCounter(); } Future<void> _loadCounter() async { SharedPreferences prefs = await SharedPreferences.getInstance(); setState(() { _counter = (prefs.getInt('counter') ?? 0); }); } Future<void> _incrementCounter() async { SharedPreferences prefs = await SharedPreferences.getInstance(); setState(() { _counter++; prefs.setInt('counter', _counter); }); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text("Flutter Shared Preferences Demo"), ), body: Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ Text( 'You have pushed the button this many times:', ), Text( '$_counter', style: Theme.of(context).textTheme.headline4, ), ], ), ), floatingActionButton: FloatingActionButton( onPressed: _incrementCounter, tooltip: 'Increment', child: Icon(Icons.add), ), ); } } ``` 这个例程演示了如何在 Flutter 中使用 shared_preferences 库来读取和写入应用程序的持久化数据。在这个例子中,我们使用一个整型变量 `_counter` 来记录用户点击按钮的次数。在 `initState` 方法中,我们调用 `_loadCounter` 方法来从 shared_preferences 中读取 `_counter` 的值。在 `_incrementCounter` 方法中,我们调用 `prefs.setInt('counter', _counter)` 来将 `_counter` 的值写入 shared_preferences。每当用户点击按钮时,我们调用 `_incrementCounter` 方法来增加 `_counter` 的值并更新 UI。 注意:为了使用 shared_preferences 库,你需要在 `pubspec.yaml` 文件中添加以下依赖项: ```yaml dependencies: shared_preferences: ^2.0.5 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值