`
su1216
  • 浏览: 671007 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
Group-logo
深入入门正则表达式(jav...
浏览量:71916
E60283d7-4822-3dfb-9de4-f2377e30189c
android手机的安全问...
浏览量:128766
社区版块
存档分类
最新评论

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

阅读更多

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

 

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

 

导读:

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

 

由于iteye不允许偷和拍放到一起,所以……静音拍照,大家懂的,静音拍照?不就是……

今天的主题是静音拍照与被拍

当然,这里的“被拍”不是指你拿着手机在地铁上深入女同学裙下的女同学(貌似日本人喜欢干这种事情,自行百度其新闻)

这里指的被拍是:你玩着玩着游戏,突然前置摄像头被恶意应用打开,然后咔嚓,然后……

 

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

 

 

下面我们来说正题

首先说静音拍照

其实也就是说静音拍照嘛,怎么实现?当然是先静音再拍照了……最后记得恢复静音前的状态即可。

有的手机直接调解照相快门音量即可,但是没有通用的api,似乎这种手机也很少(第三方的rom可能会有)

另一个办法就是把手机调成静音模式,然后拍照。不过也不是理想的,有些手机虽然调成了静音模式,但是快门不静音,就像闹钟不静音一样。

还有一些其他的静音方式,这里就不说了。如何把手机调成静音?这个没什么技术含量,大家可自行百度。。。

 

mAudioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE);
mAudioManager.setRingerMode(AudioManager.RINGER_MODE_SILENT);

当然,你最好先记录下用户之前的模式

int ringerMode = mAudioManager.getRingerMode();

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

 

下面说一下被拍

被拍呢,我会选择前置摄像头,玩手机的时候一般人不看手机屁股,因为htc嘛

首先说一下android的摄像头

前置摄像头的通用api是在2.3才开始有的,2.2及之前都需要靠反射调用,不过那时有前置摄像头的android手机也很少

这里我们以2.3为基础作为演示

步骤:

0.伪装

1.打开前置摄像头

2.静音+拍照+退出

3.保存

 

首先来看看如何调用前置摄像头(当然,你得有前置摄像头才行)

mCamera = openCamera(CameraInfo.CAMERA_FACING_FRONT);
public static Camera openCamera(int which) {
	return Camera.open(which);
}

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

 

最关键的是伪装,android系统中,调用摄像头必须要有预览画面才行,当然,这也是为了安全

所以拍照时必须有一个窗口,也就是你玩着玩着游戏的时候,突然弹出个窗口给你拍个大头贴

用户看到预览画面了,那傻子都知道他被人黑了,所以病毒不能这么傻,它会给自己穿件外套

我做了一件粗糙的外套来给大家演示


当然这个外套比较烂,真正的病毒会做一个很精致,并且比较常见的外套(这样成功率才会高,如果用户手机根本没有股票软件,而我却弹出这么一个对话框,用户再傻也会知道自己中毒了)

 

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

 

camera.xml对应的代码

<?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对应的代码

<?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里要设置主题为

android:theme="@android:style/Theme.Dialog"

在onCreate里面要设置下面这些属性,我就不一一解释了

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中还需要配置一些权限

<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文件吧

<resources>  
    <color name="button_background">#ffffff</color>
    <color name="canvas_background">#ffffffcc</color>
</resources>  
 

最后再说两句,如果有了root权限,那么病毒就可以替换快门声的音频文件,或者数据库存储指向快门声音的Uri,这样就能彻底的实现静音拍照了

当然,你想静音拍照别人,没准你也被别人静音拍照了,自重

 

 

android手机root后的安全问题 (一)

android手机root后的安全问题 (二)

android手机root后的安全问题 (三)

android手机root后的安全问题 (四)

 

 

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

android安全问题(二) 程序锁

android安全问题(三) 钓鱼程序


 

请大家不要用root的手机随意下载软件,更不要以任何借口制造任何病毒!

 

 

转贴请保留以下链接

本人blog地址

http://su1216.iteye.com/

http://blog.csdn.net/su1216/

3
3
分享到:
评论
2 楼 su1216 2012-11-08  
bing_zz 写道
说得我心头咯噔咯噔直响...

表激动,在官网下载软件情况就会好些,注意声明的权限,有没有什么不该出现的
1 楼 bing_zz 2012-11-08  
说得我心头咯噔咯噔直响...

相关推荐

    Android实现后台连续静默拍照

    总结,实现Android后台连续静默拍照涉及了权限管理、相机API的使用、服务的创建与管理、静音设置、图片存储以及性能优化等多个方面。开发者需要深入理解Android系统的工作原理,才能成功实现这一功能。

    android UVC拍照录像

    Android UVC(Universal Video Class)拍照录像涉及到的是在Android设备上使用USB摄像头进行图像和视频采集的功能。UVC是USB设备类定义的一部分,主要用于统一不同厂商的视频设备接口,使得设备能够即插即用,无需...

    android隐藏拍照无卡顿操作

    10. **安全与隐私**:隐藏拍照功能可能涉及用户隐私,开发者需要确保其合法性并告知用户,遵循应用商店的政策,否则可能导致应用被下架。 通过以上技术点的深入理解和实践,可以实现一个隐藏、无声并且无卡顿的拍照...

    基于Android4.4以上,Android8.0一下平台静默拍照

    在Android平台上实现静默拍照是一项常见的需求,尤其是在自动化测试、安全监控或者隐私保护等场景下。这个主题主要针对的是Android 4.4 (KitKat)及以上版本,但不包括Android 8.0 (Oreo)以下的操作系统。下面将详细...

    Android 2.2/2.3 通用Camera拍照源代码

    在Android平台上,Camera API是开发人员用来实现相机功能的核心接口,尤其在Android 2.2 (Froyo) 和 2.3 (Gingerbread) 版本中,这一接口对于构建拍照应用至关重要。本文将深入探讨这两个版本的相机源代码,帮助...

    Andriod Camera2 后台服务静默定时无预览拍照

    Android Camera2 API是Android系统提供的一种高级相机接口,它允许开发者更深入地控制摄像头设备,包括设置参数、捕获高质量图像和视频等。本项目基于Camera2官方示例代码,针对特定需求进行了改造,实现了在后台...

    android 拍照 照相机

    在Android平台上,拍照功能是移动应用中非常常见且重要的特性,尤其对于社交、记录和分享生活瞬间的应用来说。本文将详细解析如何实现Android拍照功能,包括切换前后置摄像头、照片预览、拍照、控制闪光灯以及调整...

    android 实现拍照功能

    这个"android 实现手机拍照 可直接部署使用"的项目,很可能包含了一个完整的Android应用示例,教你如何集成并使用Android的Camera API来创建一个能够拍照并保存图片的应用。下面将详细解释相关知识点。 1. **...

    android2.3下不预览实现拍照

    这是因为Android的Camera API在早期版本中主要设计为与用户交互,通常需要一个Camera Preview来展示拍摄画面。不过,通过一些技巧和对API的深入理解,我们仍然可以实现这个功能。下面我们将详细探讨如何在Android ...

    Android下使用Camera硬件拍照Demo

    在Android平台上,开发一款应用程序利用硬件相机功能进行拍照是一个常见的需求。`Android下使用Camera硬件拍照Demo`就是这样一个示例项目,它展示了如何在Android应用中集成并使用系统相机硬件来捕捉图片。这个Demo...

    android调用前后置摄像头拍照

    在Android平台上,调用前后置摄像头进行拍照是常见的功能,主要应用于各种社交、影像类应用。下面我们将详细探讨如何实现这一功能。 首先,我们需要创建一个`CameraActivity`,在这个活动中处理相机的相关操作。...

    android 的摄像头 和soundPool播放声音实例

    在Android平台上,开发人员可以利用丰富的API来实现与硬件设备的交互,如摄像头和音频播放。本实例将探讨如何使用Android SDK中的相关组件来实现摄像头功能以及通过SoundPool播放声音。 1. 摄像头操作 在Android中...

    android系统在静音模式下关闭camera拍照声音的方法

    本文将探讨如何在Android系统中实现在静音模式下关闭相机拍照声音。 首先,需要了解的是,Google在框架层面上强制要求相机服务(CameraService)播放拍照声音。这是因为出于隐私考虑,大多数国家和地区都有法规要求...

    android 拍照和聚焦音

    然而,在一些特定的场景下,例如静音模式或者需要无声音拍照的应用场景中,开发者可能需要去掉这些声音。这在Android 2.3.5版本的代码中可以通过对相关API的调用进行实现。 首先,聚焦声音主要是在用户触摸屏幕进行...

    身份证拍照Android自定义相机

    在Android开发中,创建一个能够专门用于拍摄身份证的自定义相机功能是一项常见的需求。这个功能不仅需要考虑相机的基本操作,如拍照、调整亮度等,还要包含特定的增强特性,如自动对焦和不规则图片裁剪,以确保...

    android拍照和上传的例子

    在Android应用开发中,为用户提供拍照和上传功能是一项常见的需求。这个例子将详细讲解如何实现这一功能。首先,我们需要了解几个关键的组件和步骤: 1. **调用系统相机**: - Android提供了Intent机制来启动系统...

    Android自定义相机,切换前后摄像头,照相机拍照

    这个方法接受四个参数:一个ShutterCallback用于拍照快门声音,一个RawImageCallback用于原始图像数据,一个JpegPictureCallback用于JPEG格式的图像,一个PreviewCallback用于预览图像。在实际应用中,通常只关心...

    什么是Android静默拍摄 Android静默拍摄app制作方法

    6. **代码实现**:在示例代码中,可以看到一个简单的Android应用结构,包括Camera对象、SurfaceView预览界面、Button用于触发拍照,以及AudioManager用于尝试静音。`SurfaceView`的`SurfaceHolder`回调用于处理预览...

Global site tag (gtag.js) - Google Analytics