我正在开发一个Cordova应用程序,该应用程序需要能够获得组文本中涉及的电话号码的列表。我正在为此查询content://mms/[id]/addr
。我正在测试Pixel 2和2018年3月10日之前的MMS消息,效果很好。但是对于该日期或之后的消息,它会失败(返回为null)。我应该查询其他地址吗?还有其他想法吗?
答案 0 :(得分:2)
使用content://mms/
会给您MMS对话列表,使用content://mms-sms/conversations
会给您第一个或第二个,如果其中任何一个都不起作用,您可以尝试两者
所以首先您只需要使用
即可获得彩信列表ContentResolver contentResolver = getContentResolver();
final String[] projection = new String[]{"_id", "ct_t"};
Uri uri = Uri.parse("content://mms-sms/conversations");
Cursor query = contentResolver.query(uri, projection, null, null, null);
if (query.moveToFirst()) {
do {
String itemId = query.getString(query.getColumnIndex("_id"));
int getRowID = Integer.parseInt(itemId);
String string = query.getString(query.getColumnIndex("ct_t"));
if ("application/vnd.wap.multipart.related".equals(string)) {
// this item is MMS so get the number using function getAddressNumber and log it
Log.d("number","address/number:" + getAddressNumber(getRowID));
} else {
// item is sms do nothing
}
} while (query.moveToNext());
}
private String getAddressNumber(int id) {
String selectionAdd = new String("msg_id=" + id);
String uriStr = MessageFormat.format("content://mms/{0}/addr", id);
Uri uriAddress = Uri.parse(uriStr);
Cursor cAdd = getContentResolver().query(uriAddress, null,
selectionAdd, null, null);
String name = null;
if (cAdd.moveToFirst()) {
do {
String number = cAdd.getString(cAdd.getColumnIndex("address"));
if (number != null) {
try {
Long.parseLong(number.replace("-", ""));
name = number;
} catch (NumberFormatException nfe) {
if (name == null) {
name = number;
}
}
}
} while (cAdd.moveToNext());
}
if (cAdd != null) {
cAdd.close();
}
return name;
}
如果上面的函数getAddressNumber不起作用,您也可以尝试一下一下,并尝试一下
public static String getMMSAddress(Context context, String id) {
String addrSelection = "type=137 AND msg_id=" + id;
String uriStr = MessageFormat.format("content://mms/{0}/addr", id);
Uri uriAddress = Uri.parse(uriStr);
String[] columns = { "address" };
Cursor cursor = context.getContentResolver().query(uriAddress, columns,
addrSelection, null, null);
String address = "";
String val;
if (cursor.moveToFirst()) {
do {
val = cursor.getString(cursor.getColumnIndex("address"));
if (val != null) {
address = val;
break;
}
} while (cursor.moveToNext());
}
if (cursor != null) {
cursor.close();
}
return address;
}
这是线路的定义
String addrSelection = "type=137 AND msg_id=" + id;
类型常量来自PduHeadersPduHeaders
class:0x97 / 151是PduHeaders.TO,0x89 / 137是PduHeaders.FROM,您可以更改FROM或TO所需的内容。
如果仍然空白,请尝试以下部分,并在您的代码中实现
Uri uriMms = Uri.parse("content://mms/");
final String[] projection = new String[]{"*"};
Cursor cursor = contentResolver.query(uriMms, projection, null, null, null);
String id = cursor.getString(cursor.getColumnIndex("_id"));
String selectionPart = "mid=" + id;
Uri uri = Uri.parse("content://mms/part");
Cursor cursor2 = getContentResolver().query(uri, null, selectionPart, null, null);
答案 1 :(得分:2)
以下是AOSP(Android开放源代码项目)消息传递应用程序的实现方式:
_ID
的邮件ID id
拉相应消息的线程threads
表中有一个名为recipient_ids
的列,对于组消息,它可能用空格分隔,如下所示:
123 456 789
其中123
456
等是收件人ID。
content://mms-sms/canonical-address
因此获取地址数组的最终方法如下所示:
private fun getAddressFromRecipientId(spaceSepIds: String, context: Context): Array<String?> {
val singleCanonicalAddressUri = Uri.parse("content://mms-sms/canonical-address")
with(spaceSepIds.split(" ")) {
val addressArray: Array<String?> = arrayOfNulls(this.size)
this.forEachIndexed { index, address ->
if (!address.isEmpty()) {
val longId = address.toLong()
context.contentResolver.query(ContentUris.withAppendedId(singleCanonicalAddressUri, longId), null, null, null, null).use { cursor ->
if (cursor != null && cursor.moveToNext())
addressArray[index] = "${cursor.getString(0)} "
}
}
}
return addressArray
}
return arrayOf()
}
希望这会有所帮助。该功能也位于kotlin中,但是很容易弄清楚那里发生了什么。
此外,您已经具有ID,因此您可以使用带空格分隔的ID或不使用ID来调用此方法,该函数可以双向运行。