получить список контактов пользователей в android 8.0 через приложение [duplicate]

>>> a = "545.2222"
>>> float(a)
545.22220000000004
>>> int(float(a))
545
12
задан duggu 3 June 2014 в 07:25
поделиться

3 ответа

, но кажется, что все правильно

Не совсем.

<permission android:name="READ_DATABASE" android:label="@string/app_read"       android:protectionLevel="normal"></permission>
<permission android:name="WRITE_DATABASE" android:label="@string/app_write" android:protectionLevel="normal"></permission>

Во-первых, вы действительно действительно действительно действительно должны помещать пространство имен по этим именам разрешений. Сделайте их com.company.contentprovider.READ_DATABASE и com.company.contentprovider.WRITE_DATABASE.

<provider android:name="AplicacaoContentProvider"
    android:authorities="com.company.contentprovider"
    android:exported="true"
    android:readPermission="@string/app_read"
    android:writePermission="@string/app_write"
   />

Во-вторых, ваши android:readPermission и android:writePermission значения должны использовать значение android:name от <permission>, а не android:label. android:label - только отображаемое имя. Таким образом, приведенный выше фрагмент должен быть:

<provider android:name="AplicacaoContentProvider"
    android:authorities="com.company.contentprovider"
    android:exported="true"
    android:readPermission="com.company.contentprovider.READ_DATABASE"
    android:writePermission="com.company.contentprovider.WRITE_DATABASE"
   />

(хотя бонусные баллы для явного ввода android:exported="true", что является хорошей идеей)

<uses-permission android:name="android.permissions.READ_DATABASE"/>
<uses-permission android:name="android.permissioms.WRITE_DATABASE"/>

В-третьих, ваш другой манифест не использует ваши старые android:name, а также мои предложенные исправленные android:name или android:label, но что-то еще полностью, где вы решили сказать, что они находятся в пространстве имен android.permission, а это не так. Это должно быть:

<uses-permission android:name="com.company.contentprovider.READ_DATABASE"/>
<uses-permission android:name="com.company.contentprovider.WRITE_DATABASE"/>

(хотя возможно, что com.company.contentprovider.WRITE_DATABASE будет достаточным - я не знаю, будет ли android:writePermission автоматически подразумевать android:readPermission или нет)

Внесите эти изменения, и я думаю, вам повезет больше.

15
ответ дан CommonsWare 23 August 2018 в 23:04
поделиться

Ответ, приведенный выше, был для меня непонятным. Но я понял это сейчас. Я также хочу опубликовать свое решение. Возможно, для кого-то это лучше понять.

Первое приложение A - это приложение, в котором есть SQLite-база данных и «пользовательский поставщик контента». Приложение B использует с ContentResolver базу данных из App A.

Это AndroidManifest.xml-файл из приложения A:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="de.test"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk android:minSdkVersion="10" />


<permission android:name="de.test.READ_DATABASE" android:protectionLevel="normal" />
<permission android:name="de.test.WRITE_DATABASE" android:protectionLevel="normal" />

<application
    android:debuggable="true"
    ... >
    ...
    ...
    <provider
        android:name="de.test.TestContentProvider"
        android:authorities="de.test.ContentProvider"
        android:exported="true"
        android:readPermission="de.test.READ_DATABASE"
        android:writePermission="de.test.WRITE_DATABASE" />
    ...
    ...
</application>

Хорошо и это файл AndroidManifest.xml из приложения B. Важно, что часть с «uses-permission»:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="de.test.testercontentprovider"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk
    android:minSdkVersion="15"
    android:targetSdkVersion="17" />

<uses-permission android:name="de.test.READ_DATABASE" />
<uses-permission android:name="de.test.WRITE_DATABASE" />

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="de.test.testercontentprovider.MainActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

И выглядит код ContentProvider для App A например:

public class TestContentProvider extends ContentProvider {

public static final String AUTHORITY = "de.test.TestContentProvider";

public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY
        + "/" + "nameoftable");


@Override
public boolean onCreate() {
    ...
    return true;
}

@Override
public Cursor query(Uri uri, String[] projection, String selection,
        String[] selectionArgs, String sortOrder) {
    // TODO Auto-generated method stub
            return null;
}

@Override
public int update(Uri uri, ContentValues values, String selection,
        String[] selectionArgs) {
    // TODO Auto-generated method stub
    return 0;
}

@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
    // TODO Auto-generated method stub
    return 0;
}

@Override
public Uri insert(Uri uri, ContentValues values) {
    // TODO Auto-generated method stub
    return null;
}

@Override
public String getType(Uri uri) {
    // TODO Auto-generated method stub
    return null;
}
}

И код для ContentResolver из приложения B:

public class MainActivity extends Activity {

private static final String TAG = MainActivity.class.getSimpleName();
public static final String AUTHORITY = "de.test.TestContentProvider";
public static final String TABLE_NAME = "nameoftable";

    ...

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    ContentResolver cr = getContentResolver();

    // show entries of db
    listEntries(cr);
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

private void listEntries(ContentResolver cr) {
    Uri uri = Uri.parse("content://" + AUTHORITY + "/" + TABLE_NAME);
    Cursor c = cr.query(uri, null, null, null, null);

    if (c == null) {
        Log.d(TAG, "Cursor c == null.");
        return;
    }
    while (c.moveToNext()) {
        String column1 = c.getString(0);
        String column2 = c.getString(1);
        String column3 = c.getString(2);

        Log.d(TAG, "column1=" + column1 + " column2=" + column2 + " column3=" + column3);
    }
    c.close();
}
}

Надеюсь, это поможет кому-то лучше понять его.

16
ответ дан KingAlex1985 23 August 2018 в 23:04
поделиться
public static final String AUTHORITY = "de.test.TestContentProvider";
//......

Возникает вопрос, должно ли оно быть

android:authorities="de.test.ContentProvider"
<--- 
-3
ответ дан Sanoop 23 August 2018 в 23:04
поделиться
Другие вопросы по тегам:

Похожие вопросы: