Android:将声音保存为铃声/ SQLiteConstraintException

时间:2010-10-12 18:55:15

标签: android exception sqlite ringtone

我正在尝试使用this代码将声音保存为Android中的铃声。它就像一个魅力,但如果我试图保存已经插入的铃声,它将会失败。

保存时出现“SQLiteConstraintException”,但我无法捕获异常,事实上,我无法捕获任何 execption。

以下是我的代码部分:

Uri uri = MediaStore.Audio.Media.getContentUriForPath(k.getAbsolutePath());

try {
  this.getContentResolver().insert(uri, values);
} catch (SQLiteConstraintException e) {
  Log.e("error", e.getMessage());
} catch (SQLiteException e) {
  Log.e("error", e.getMessage());
} catch (Exception e) {
  Log.e("error", e.getMessage());
}

所以我试图抓住任何可能的异常,但是 none 被捕获。

这是LogCat:

10-12 18:32:51.627: ERROR/Database(217): Error inserting album_id=-1 title=Applause is_notification=true title_key=%,%J%J%B%,%T%P%4% mime_type=audio/ogg date_added=1286908371 _display_name=Applause.ogg is_alarm=true is_ringtone=true artist_id=1 is_music=false _data=/mnt/sdcard/media/audio/ringtones/Applause.ogg
10-12 18:32:51.627: ERROR/Database(217): android.database.sqlite.SQLiteConstraintException: error code 19: constraint failed
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteStatement.native_execute(Native Method)
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteStatement.execute(SQLiteStatement.java:55)
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1549)
10-12 18:32:51.627: ERROR/Database(217):     at android.database.sqlite.SQLiteDatabase.insert(SQLiteDatabase.java:1410)
10-12 18:32:51.627: ERROR/Database(217):     at com.android.providers.media.MediaProvider.insertInternal(MediaProvider.java:1813)
10-12 18:32:51.627: ERROR/Database(217):     at com.android.providers.media.MediaProvider.insert(MediaProvider.java:1638)
10-12 18:32:51.627: ERROR/Database(217):     at android.content.ContentProvider$Transport.insert(ContentProvider.java:174)
10-12 18:32:51.627: ERROR/Database(217):     at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:146)
10-12 18:32:51.627: ERROR/Database(217):     at android.os.Binder.execTransact(Binder.java:288)
10-12 18:32:51.627: ERROR/Database(217):     at dalvik.system.NativeStart.run(Native Method)

我找到了一个解决方法:在调用.insert方法之前检查声音文件是否存在(如果文件已经存在,则不要调用它),但我真的很想理解为什么没有捕到异常。希望任何人都可以帮助我。

亲切的问候, Select0r

2 个答案:

答案 0 :(得分:1)

它没有被捕获,因为您的代码中没有异常。它甚至不在你的过程中。它正在MediaStore内容提供商的过程中。

答案 1 :(得分:1)

我遇到了同样的问题....这是因为你的清单中没有此权限

<uses-permission android:name="android.permission.WRITE_SETTINGS"/>

此外,如果您正在使用该教程,请确保您的清单中也包含此内容...

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

我花了大约半个小时左右试图找出代码无效的原因。我实际上删除了try / catch只是为了看看它会在logcat中抛出什么类型的错误,它告诉我我错过了那些权限。