4.4でのパーミッション「WRITE_SECURE_SETTINGS」付与について

5,025 views
Skip to first unread message

heavensfeel21

unread,
Nov 27, 2013, 8:16:33 PM11/27/13
to android-g...@googlegroups.com
はじめまして。

Nexus5(Android4.4)上で位置情報モードを、
高精度やバッテリ節約などに切り替えようとすると、
SecurityExceptionが発生してしまいます。
AndroidManifest.xmlにはandroid.permission.WRITE_SECURE_SETTINGSを付与しており、
署名付きのapkを作成後、adb pushで/system/app/内へインストールしてから実行しています。

該当コードは以下のとおりです。

○コード
android.provider.Settings.Secure.putInt(getContentResolver(), Secure.LOCATION_MODE, Secure.LOCATION_MODE_HIGH_ACCURACY);

○AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.cotetsu.android.providerswitch"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="10" />
    <uses-permission android:name="android.permission.WRITE_SETTINGS" />
    <uses-permission android:name="android.permission.WRITE_SECURE_SETTINGS" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".ProviderSwitchActivity"
            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>
</manifest>


エラーログは以下のようになります。

11-27 10:13:11.862: E/DatabaseUtils(790): Writing exception to parcel
11-27 10:13:11.862: E/DatabaseUtils(790): java.lang.SecurityException: Permission denial: writing to secure settings requires android.permission.WRITE_SECURE_SETTINGS
11-27 10:13:11.862: E/DatabaseUtils(790):     at com.android.providers.settings.SettingsProvider.checkWritePermissions(SettingsProvider.java:282)
11-27 10:13:11.862: E/DatabaseUtils(790):     at com.android.providers.settings.SettingsProvider.insertForUser(SettingsProvider.java:914)
11-27 10:13:11.862: E/DatabaseUtils(790):     at com.android.providers.settings.SettingsProvider.call(SettingsProvider.java:648)
11-27 10:13:11.862: E/DatabaseUtils(790):     at android.content.ContentProvider$Transport.call(ContentProvider.java:325)
11-27 10:13:11.862: E/DatabaseUtils(790):     at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:275)
11-27 10:13:11.862: E/DatabaseUtils(790):     at android.os.Binder.execTransact(Binder.java:404)
11-27 10:13:11.862: E/DatabaseUtils(790):     at dalvik.system.NativeStart.run(Native Method)

ログではandroid.permission.WRITE_SECURE_SETTINGSのパーミッションが必要だと言っている用に思えますが、
すでに付与しているためなぜ発生するのかわかりません。
となたか、ご教授いただけますでしょうか。

よろしくお願い致します。

nagamatu

unread,
Nov 27, 2013, 9:01:02 PM11/27/13
to android-g...@googlegroups.com

heavensfeel21

unread,
Nov 27, 2013, 9:43:41 PM11/27/13
to android-g...@googlegroups.com
返信ありがとうございます。
adb pushにより/system/app配下にアプリをインストールしているのですが、
システムアプリとはみなされないのでしょうか?

記述し忘れてしまいましたが、4.3(Galaxy Nexus)ではこの問題は発生しませんでした。

よろしくお願い致します。

2013年11月28日木曜日 11時01分02秒 UTC+9 nagamatu:

nagamatu

unread,
Nov 27, 2013, 10:03:29 PM11/27/13
to android-g...@googlegroups.com
失礼しました、これですね。

There are multiple instances of people running into instances where their system apps no longer function properly in 4.4, because putting your app in /system/app no longer automatically grants system-level permissions. You have to place your app in/system/priv-app for the proper permissions to be granted.

http://stackoverflow.com/questions/20196921/kitkat-api-19-security-exception-although-using-install-packages

--

heavensfeel21

unread,
Nov 27, 2013, 11:42:35 PM11/27/13
to android-g...@googlegroups.com
ありがとうございます。
インストール先を/system/appから/system/priv-appに変更し、無事に解決出来ました。
とても助かりました。


2013年11月28日木曜日 12時03分29秒 UTC+9 nagamatu:
Reply all
Reply to author
Forward
0 new messages