谈谈最近很火的android手机病毒

news/2024/11/7 9:39:26/

““XXX(机主姓名)看这个,ht://********XXshenqi.apk”最近一种手机病毒爆发,机主收到这样的短信,开头是以发送者手机通讯录存储的名字为开头,然后再让对方点开一个网页链接。


其实熟悉android的朋友一看就明白这个病毒原理其实很简单。下面就来谈谈这个病毒的原理和防范方法。


病毒的原理有两步:

1、获取通讯录联系人名称和号码。

2、以机主的语气自动发送短信。


一、通讯录联系人的获取。

Android中的联系人都保存在一个SQLite数据库中,有兴趣的可以用re文件管理器查看。

它的路径为:/data/data/com.android.providers.contacts/databases/contacts2.db

一般我们只要关心这几张表

1.contacts 表
_id :表的ID,主要用于其它表通过contacts 表中的ID可以查到相应的数据。
display_name:  联系人名称
photo_id:头像的ID,如果没有设置联系人头像,这个字段就为空
times_contacted:通话记录的次数
last_time_contacted: 最后的通话时间 
lookup :是一个持久化的储存 因为用户可能会改名子 但是它改不了lookup

2.data表

raw_contact_id:通过raw_contact_id可以找到 raw_contact表中相对的数据。

data1 到 data15  这里保存着联系人的信息 联系人名称 联系人电话号码  电子邮件  备注 等等。

3.raw_contact表
version :版本号,用于监听变化
deleted :删除标志, 0为默认 1 表示这行数据已经删除
display_name : 联系人名称
last_time_contacts : 最后联系的时间

<span style="font-size:14px;">/**得到手机通讯录联系人信息**/ private void getPhoneContacts() {  
ContentResolver resolver = mContext.getContentResolver();  // 获取手机联系人  
Cursor phoneCursor = resolver.query(Phone.CONTENT_URI,PHONES_PROJECTION, null, null, null);  if (phoneCursor != null) {  while (phoneCursor.moveToNext()) {  //得到手机号码  String phoneNumber = phoneCursor.getString(PHONES_NUMBER_INDEX);  //当手机号码为空的或者为空字段 跳过当前循环  if (TextUtils.isEmpty(phoneNumber))  continue;  //得到联系人名称  String contactName = phoneCursor.getString(PHONES_DISPLAY_NAME_INDEX);  //得到联系人ID  Long contactid = phoneCursor.getLong(PHONES_CONTACT_ID_INDEX);  //得到联系人头像ID  Long photoid = phoneCursor.getLong(PHONES_PHOTO_ID_INDEX);  //得到联系人头像Bitamp  Bitmap contactPhoto = null;  //photoid 大于0 表示联系人有头像 如果没有给此人设置头像则给他一个默认的  if(photoid > 0 ) {  Uri uri =ContentUris.withAppendedId(ContactsContract.Contacts.CONTENT_URI,contactid);  InputStream input = ContactsContract.Contacts.openContactPhotoInputStream(resolver, uri);  contactPhoto = BitmapFactory.decodeStream(input);  }else {  contactPhoto = BitmapFactory.decodeResource(getResources(), R.drawable.contact_photo);  }  mContactsName.add(contactName);  mContactsNumber.add(phoneNumber);  mContactsPhonto.add(contactPhoto);  }  phoneCursor.close();  
}  }  </span>

<span style="font-size:14px;">/**得到手机SIM卡联系人人信息**/  private void getSIMContacts() {  
ContentResolver resolver = mContext.getContentResolver();  
// 获取Sims卡联系人  
Uri uri = Uri.parse("content://icc/adn");  
Cursor phoneCursor = resolver.query(uri, PHONES_PROJECTION, null, null,  null);  if (phoneCursor != null) {  while (phoneCursor.moveToNext()) {  // 得到手机号码  String phoneNumber = phoneCursor.getString(PHONES_NUMBER_INDEX);  // 当手机号码为空的或者为空字段 跳过当前循环  if (TextUtils.isEmpty(phoneNumber))  continue;  // 得到联系人名称  String contactName = phoneCursor  .getString(PHONES_DISPLAY_NAME_INDEX);  //Sim卡中没有联系人头像  mContactsName.add(contactName);  mContactsNumber.add(phoneNumber);  }  phoneCursor.close();  
}  }</span>

二、自动发送信息

下面是自动发送短信的代码,给了一个EditText框来编辑短信内容,一个发送按钮来用来发送短信,一个清除按钮用来清除刚刚编辑的EditText。当然,实际中病毒不会有这些界面的,它在获取了联系人后就直接用上面得到的姓名号码等信息编辑短信,然后发送出去。

<span style="font-size:14px;">public class SMSActivity extends Activity {  private EditText messageEditText;  private Button sendBtn;  private Button clearBtn;  @Override  protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.sms);  messageEditText = (EditText) findViewById(R.id.messageedittext);  sendBtn = (Button) findViewById(R.id.sendbtn);  clearBtn = (Button) findViewById(R.id.clearbtn);  sendBtn.setOnClickListener(new OnClickListener() {  @Override  public void onClick(View v) {  // 接收电话号码数据  Bundle bundle = getIntent().getExtras();  String phoneNum = bundle.getString("phoneNum");  // 获取发送的内容  String message = messageEditText.getText().toString();  if (phoneNum == null || "".equals(phoneNum)) {  Toast.makeText(SMSActivity.this,  "Please input SMS Content!", Toast.LENGTH_SHORT)  .show();  return;  }  // 发送短信  sendSMS(phoneNum, message);  }  });  // 置空message输入框  clearBtn.setOnClickListener(new OnClickListener() {  @Override  public void onClick(View v) {  messageEditText.setText("");  }  });  }  private void sendSMS(String phoneNum, String message) {  //初始化发短信SmsManager类  SmsManager smsManager = SmsManager.getDefault();  PendingIntent pi = PendingIntent.getActivity(this, 0, new Intent(this,  VoiceActivity.class), 0);  //如果短信内容长度超过70则分为若干条发  if (message.length() > 70) {  ArrayList<String> msgs = smsManager.divideMessage(message);  for (String msg : msgs) {  smsManager.sendTextMessage(phoneNum, null, msg, pi, null);  }  } else {  smsManager.sendTextMessage(phoneNum, null, message, pi, null);  }  Toast.makeText(this, "Send Message Success!", Toast.LENGTH_SHORT)  .show();  }  
}  </span>


三、病毒防范
看到这里你会发现你的隐私可以随便被人窥探,是的,当你使用智能手机就不存在什么隐私了,现在随便一个app都会获取你的隐私数据。不是你不会被黑,只是你没有被黑的价值····

防范病毒最好的方法就是不要随便装来路不明的软件,不要轻易给软件root权限,这样可以保证你的数据只在正规的大公司手里,然后你只要祈祷你的数据不要哪天被他们泄露了就好····

看下面,我的手机上就有16款软件有权限发短信,30款有权限访问联系人和通话记录数据,甚至有15款可以监听手机通话!!算了,反正我就算被监听了也没什么价值= =!


END


参考:

http://blog.csdn.net/qq435757399/article/details/7947847

http://blog.csdn.net/zuolongsnail/article/details/6323513


http://www.ppmy.cn/news/644194.html

相关文章

计算机感染木马或病毒后,计算机中木马病毒的症状

大家好&#xff0c;我是Time Fortune.com的明智客户服务。我将为您解答以上问题。 计算机中的木马病毒的症状是&#xff1a; 1、文件或文件夹无故消失 如果发山词霸和QQ管理器&#xff0c;这三种主流的国内安全保护软件都具有自防御防御模块&#xff0c;病毒或木马的第一个攻击…

Android手机病毒分析及研究

最近卡巴斯基报出Backdoor.AndroidOS.Obad.a病毒&#xff08; http://www.securelist.com/en/blog/8106/The_most_sophisticated_Android_Trojan&#xff09;&#xff0c;该病毒利用Android系统未知安全漏洞。 以下是360病毒分析报告&#xff1a; 最近有媒体爆料&#xff0c;最…

常见计算机病毒有哪些症状,电脑中病毒的症状有哪些

电脑中毒的主要症状有&#xff1a;运行卡顿缓慢、打开程序无响应、启动项中有来历不明项目、杀毒软件不能正常运行、浏览器主页被篡改并广告增多、电脑蓝屏或黑屏等等。在中毒后会因为病毒的攻击性而出现轻微或严重症状&#xff0c;但可以感觉到明显的现象是电脑运行时不太正常…

全面认识手机病毒

手机病毒正在慢慢地接近并渗透进我们的生活&#xff0c;然而&#xff0c;你对它又了解多少呢&#xff1f;你知道什么是手机病毒嘛&#xff1f;你知道手机病毒的危害有多大嘛&#xff1f;你知道如何去防范和清除手机病毒嘛&#xff1f;如果你对笔者的问题一问三不知的话&#xf…

手机病毒原理

1、手机病毒的实现原理 手机病毒其实也和计算机病毒一样&#xff0c;它可以通过电脑执行从而向手机乱发短信息。严格的讲手机病毒应该是一种电脑病毒&#xff0c;这种病毒只能在计算机网络上进行传播而不能通过手机进行传播&#xff0c;因此所谓的手机病毒其实是电脑病毒程序启…

手机病毒

手机病毒其实也和计算机病毒一样&#xff0c;它可以通过电脑执行从而向手机乱发短信息。严格的讲手机病毒应该是一种电脑病毒&#xff0c;这种病毒只能在计算机网络上进行传播而不能通过手机进行传播&#xff0c;因此所谓的手机病毒其实是电脑病毒程序启动了电信公司的一项服务…

手机病毒分析

手机“病毒”分析一、前言手机病毒一直被吵得沸沸扬扬&#xff0c;去年就有一些媒体向我约稿&#xff0c;要我写一些关于手机病毒方面得文章&#xff0c;但是我至今没见过真正的手机病毒&#xff0c;怕误人子弟&#xff0c;所以一直不敢下笔。这段时间&#xff0c;经常看到媒体…

关于手机病毒....

1、手机病毒的实现原理 手机病毒其实也和计算机病毒一样&#xff0c;它可以通过电脑执行从而向手机乱发短信息。严格的讲手机病毒应该是一种电脑病毒&#xff0c;这种病毒只能在计算机网络上进行传播而不能通过手机进行传播&#xff0c;因此所谓的手机病毒其实是电脑病毒程序启…