目标:(注意:选择的答案会生成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 创建工具。 所有数据库对象都显示在左侧的“对象”窗格中。在中间的窗格中,它分为两部分:上面的“图表”窗格和