安装“无内容提供商”时出现Android错误消息

时间:2012-06-17 17:29:30

标签: android permissions android-contentprovider

我正在尝试编写一个广播接收器,它会在每条SMS文本消息中被调用。所有已发布的代码(我可以找到)都已被弃用或不起作用。

我的代码在安装时失败,在日志中显示此消息(两次):

06-17 10:15:59.316   396   413 W ActivityManager: No content provider found for permission revoke: file:///data/local/tmp/locator.apk
06-17 10:15:59.316   396   413 W ActivityManager: No content provider found for permission revoke: file:///data/local/tmp/locator.apk

我的清单文件如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.example"
  android:versionCode="1"
  android:versionName="1.0">
<uses-sdk android:minSdkVersion="7" />
<uses-permission android:name="android.permission.RECEIVE_SMS"/>
<uses-permission android:name="android.permission.READ_SMS"/>

<application android:icon="@drawable/ic_launcher" android:label="@string/app_name">
    <receiver android:name=".SmsReceiver" > 
        <intent-filter> 
            <action android:name="android.provider.Telephony.SMS_RECEIVED" /> 
        </intent-filter> 
    </receiver>  
</application>

如果有人能指出我做错了什么会很高兴。我开始怀疑没有用于阅读传入短信的API。

我的源代码如下所示:

package com.example;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.gsm.SmsMessage;
import android.util.Log;


public class SmsReceiver extends BroadcastReceiver {
    private static final String SMS_RECEIVED = "android.provider.Telephony.SMS_RECEIVED";
    private static final String TAG = "locator";

    @SuppressWarnings("deprecation")
    @Override
    public void onReceive(Context context, Intent intent) {
        Log.i(TAG, "Intent recieved: " + intent.getAction());

        if (intent.getAction() == SMS_RECEIVED) {
            Bundle bundle = intent.getExtras();
            if (bundle != null) {
                Object[] pdus = (Object[]) bundle.get("pdus");
                final SmsMessage[] messages = new SmsMessage[pdus.length];
                for (int i = 0; i < pdus.length; i++) {
                    messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
                }
                if (messages.length > -1) {
                    Log.i(TAG,
                            "Message recieved: " + messages[0].getMessageBody());
                }
            }
        }
    }
}

2 个答案:

答案 0 :(得分:0)

你的代码(和我的代码)在另一部手机上运行得很好,马克。我曾在这款手机上刷过ICS,我怀疑有些东西有点不对劲。这是手机或构建。谢谢你,彼得

答案 1 :(得分:0)

查找(另一个)错误消息

“未找到任何内容提供商或撤销权限”是一个警告,可能并不意味着任何错误。在包安装的情况下,我调查了它只是一个警告消息,包URI不包含'权限'(用户ID /密码)部分。 handleStartCopy(),(在frameworks / base / services / java / com / android / server / pm / PackageManagerService.java中)确实:

mContext.grantUriPermission(DEFAULT_CONTAINER_PACKAGE, mPackageURI, Intent.FLAG_GRANT_READ_URI_PERMISSION);

一些工作,然后:

mContext.revokeUriPermission(mPackageURI, Intent.FLAG_GRANT_READ_URI_PERMISSION);
消息是真实的,但无关紧要。 (removeUriPermission()在frameworks / base / services / java / com / android / server / pm / ActivityManagerService.java中)

对我来说,.apk安装过程的这一部分工作 - 尽管有警告信息。检查logcat是否显示其他可能表明失败原因的消息。