当前位置: 首页 > 面试题库 >

创建适用于SmsMessage.createFromPdu()(GSM 3gpp)的Android PDU

缪朝
2023-03-14
问题内容

目标:(注意:选择的答案会生成CDMA(3gpp2)的GSM(3gpp)PDU)

创建可以传入的PDU SmsMessage.createFromPdu(byte[]pdu)。我正在“广播意图”到我的其中一个BroadcastReciever侦听SMS消息的人。

之一 BroadcastReciever

使用android.provider.Telephony.SMS_RECEIVED“真正的” 短信的

intent-filter对这些新的 “应用程序SMS” 使用自定义操作。

@Override
public void onReceive(Context context, Intent intent) {

    Bundle bundle = intent.getExtras();

    if (bundle != null) {
        Object[] pdusObj = (Object[]) bundle.get("pdus");
        SmsMessage[] messages = new SmsMessage[pdusObj.length];

        // getting SMS information from Pdu.
        for (int i = 0; i < pdusObj.length; i++) {
            messages[i] = SmsMessage.createFromPdu((byte[]) pdusObj[i]);
        }

        for (SmsMessage currentMessage : messages) {
            //the currentMessage.getDisplayOriginatingAddress() 
            //or .getDisplayMessageBody() is null if I Broadcast a fake sms
            Log.i("BB", "address:"+currentMessage.getDisplayOriginatingAddress()+" message:"+currentMessage.getDisplayMessageBody());
    ...

所以我希望我BroadcastReciever能够处理两种类型的消息而无需添加额外的代码

(是的,我知道我可以BroadcastReciever针对不同的intent-filter动作采取不同的做法,但我想实际完成这项工作,因为我很固执)

研究:

我整夜都在做研究。即使我对数学和转换非常糟糕,也尝试编写自己的算法,并创建了合适的算法。我查看了PDU上的Stack主题,并创建了AndroidPDU,但答案中的链接已断开。我什至看过com.google.android.mms.pdu源代码

到目前为止,我只能使用http://www.wrankl.de/JavaPC/SMSTools.html中的一些代码来创建没有“
始发地址 ” 的PDU

PDU:

目的地:555消息:helloworld

"1100038155f50000aa0ae8329bfdbebfe56c32"

这显然是无效的…

注意事项:

除了本地使用外,我不打算对PDU进行任何操作,我不希望在代码中使用硬编码的PDU,因为我不会重复使用PDU。

如果有什么可以添加到我要添加 “发件人地址” 的代码中的,那将起作用。还是有人知道我不知道的图书馆信息?

谢谢

更新:

试过了

byte[] by =(byte[])(SmsMessage.getSubmitPdu("12345", "1234", "hello", false).encodedMessage);

这给我以下内容(以十六进制表示)

"0000100200000000000000000000000004010203040000000e000320ec400107102e8cbb366f00"

没用


问题答案:

也许此代码片段没有您想要的许多详细信息字段,但是出于我的 简单目的, 它可以像其他短信一样调用通知。

    private static void createFakeSms(Context context, String sender,
        String body) {
    byte[] pdu = null;
    byte[] scBytes = PhoneNumberUtils
            .networkPortionToCalledPartyBCD("0000000000");
    byte[] senderBytes = PhoneNumberUtils
            .networkPortionToCalledPartyBCD(sender);
    int lsmcs = scBytes.length;
    byte[] dateBytes = new byte[7];
    Calendar calendar = new GregorianCalendar();
    dateBytes[0] = reverseByte((byte) (calendar.get(Calendar.YEAR)));
    dateBytes[1] = reverseByte((byte) (calendar.get(Calendar.MONTH) + 1));
    dateBytes[2] = reverseByte((byte) (calendar.get(Calendar.DAY_OF_MONTH)));
    dateBytes[3] = reverseByte((byte) (calendar.get(Calendar.HOUR_OF_DAY)));
    dateBytes[4] = reverseByte((byte) (calendar.get(Calendar.MINUTE)));
    dateBytes[5] = reverseByte((byte) (calendar.get(Calendar.SECOND)));
    dateBytes[6] = reverseByte((byte) ((calendar.get(Calendar.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) sender.length());
        bo.write(senderBytes);
        bo.write(0x00);
        bo.write(0x00); // encoding: 0 for default 7bit
        bo.write(dateBytes);
        try {
            String sReflectedClassName = "com.android.internal.telephony.GsmAlphabet";
            Class cReflectedNFCExtras = Class.forName(sReflectedClassName);
            Method stringToGsm7BitPacked = cReflectedNFCExtras.getMethod(
                    "stringToGsm7BitPacked", new Class[] { String.class });
            stringToGsm7BitPacked.setAccessible(true);
            byte[] bodybytes = (byte[]) stringToGsm7BitPacked.invoke(null,
                    body);
            bo.write(bodybytes);
        } catch (Exception e) {
        }

        pdu = bo.toByteArray();
    } catch (IOException e) {
    }

    Intent intent = new Intent();
    intent.setClassName("com.android.mms",
            "com.android.mms.transaction.SmsReceiverService");
    intent.setAction("android.provider.Telephony.SMS_RECEIVED");
    intent.putExtra("pdus", new Object[] { pdu });
    intent.putExtra("format", "3gpp");
    context.startService(intent);
}

private static byte reverseByte(byte b) {
    return (byte) ((b & 0xF0) >> 4 | (b & 0x0F) << 4);
}

希望你会发现有用的东西

更新:

 public static final SmsMessage[] getMessagesFromIntent(
                Intent intent) {
            Object[] messages = (Object[]) intent.getSerializableExtra("pdus");
            byte[][] pduObjs = new byte[messages.length][];

            for (int i = 0; i < messages.length; i++) {
                pduObjs[i] = (byte[]) messages[i];
            }
            byte[][] pdus = new byte[pduObjs.length][];
            int pduCount = pdus.length;
            SmsMessage[] msgs = new SmsMessage[pduCount];
            for (int i = 0; i < pduCount; i++) {
                pdus[i] = pduObjs[i];
                msgs[i] = SmsMessage.createFromPdu(pdus[i]);
            }
            return msgs;
        }


 类似资料:
  • 问题内容: 我正在竭尽全力试图找出为什么鼠标悬停事件无法与具有从ajax动态创建的元素的.on处理程序一起使用的原因。似乎唯一起作用的是带有.live的代码,但我知道它已被弃用。 但是,当我尝试使用.on时,它将不起作用-无论我尝试了什么变体(document.ready,.mouseover等) 事件处理程序位于代码的底部,因此它们最后执行。有人知道我在做什么错吗? 问题答案: 使用与新生成的元

  • 问题内容: 我有一段jQuery,它会循环遍历给定div()中的每个元素,并且每次单击范围时都会发出JavaScript警报。如果的值是静态的,则效果很好。 但是,如果我使用如下代码: jQuery代码不会触发。奇怪的是 我的问题是:我的Click事件是否不适用于动态创建的项目?我想我必须在我的文档中添加准备好的内容或心跳脚本(每100毫秒触发一次)来关联事件? 问题答案: 做这个: 其中,在其中

  • 注意: Adobe Muse 不再添加新增功能,并将于 2020 年 3 月 26 日停止支持。有关详细信息和帮助,请参阅 Adobe Muse 服务结束页面。 通过使用 Adobe Muse 中的响应式网页设计,您可以创建并设计适用于移动设备的网站。通过使用响应性布局,您可以使用一个 Muse 文件来创建适用于所有设备的网站,包括移动设备。 首先,您应该确定要为其设计网站的浏览器宽度。然后,您可

  • Navicat 为视觉化地创建查询、视图和实体化视图提供了一个有用的工具,称为“SQL 创建工具”。它让你不需要 SQL 知识就能创建和编辑查询。即使你熟悉 SQL,便捷而流畅的图形界面也可以让你更轻松地创建关系并可视化查询。 在查询设计器中,点击 “查询创建工具”按钮来打开可视化的 SQL 创建工具。 所有数据库对象都显示在左侧的“对象”窗格中。在中间的窗格中,它分为两部分:上面的“图表”窗格和

  • Navicat 为视觉化地创建查询、视图和实体化视图提供了一个有用的工具,称为“SQL 创建工具 ”。它让你不需要 SQL 知识就能创建和编辑查询。即使你熟悉 SQL,便捷而流畅的图形界面也可以让你更轻松地创建关系并可视化查询。 在查询设计器中,点击 钮来打开可视化的 SQL 创建工具。 所有数据库对象都显示在左侧的“对象”窗格中。在中间的窗格中,它分为两部分:上面的“图表”窗格和下面的“准则”窗

  • Navicat 为视觉化地创建查询、视图和实体化视图提供了一个有用的工具,称为“SQL 创建工具”。它让你不需要 SQL 知识就能创建和编辑查询。即使你熟悉 SQL,便捷而流畅的图形界面也可以让你更轻松地创建关系并可视化查询。 在查询设计器中,点击 “查询创建工具”按钮来打开可视化的 SQL 创建工具。 所有数据库对象都显示在左侧的“对象”窗格中。在中间的窗格中,它分为两部分:上面的“图表”窗格和