Android:unable to start service Intent {act = com.android.email.ACCOUNT_INTENT}

在安卓中报如下错误:

Android:unable to start service Intent {act = com.android.email.ACCOUNT_INTENT}

解决办法:

在AndroidManifest.xml中加上如下代码:

<service android:name="com.android.email.ACCOUNT_INTENT"></service>

注意:加在Application标签内,与Activity同一个级别。

分析以下报错信息: Failed to execute the transaction: tId:295913160 ClientTransaction{ tId:295913160 transactionItems=[ tId:295913160 LaunchActivityItem{activityToken=android.os.BinderProxy@b6a90f7,intent=Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10000000 xflg=0x4 cmp=com.example.contacts2/.MainActivity },ident=264802081,info=ActivityInfo{4ffa7a8 com.example.contacts2.MainActivity},curConfig={1.0 310mcc260mnc [en_US] ldltr sw411dp w411dp h866dp 420dpi nrml long port finger qwerty/v/v dpad/v winConfig={ mBounds=Rect(0, 0 - 1080, 2400) mAppBounds=Rect(0, 0 - 1080, 2337) mMaxBounds=Rect(0, 0 - 1080, 2400) mDisplayRotation=ROTATION_0 mWindowingMode=fullscreen mActivityType=undefined mAlwaysOnTop=undefined mRotation=ROTATION_0} s.86 fontWeightAdjustment=0},overrideConfig={1.0 310mcc260mnc [en_US] ldltr sw411dp w411dp h866dp 420dpi nrml long port finger qwerty/v/v dpad/v winConfig={ mBounds=Rect(0, 0 - 1080, 2400) mAppBounds=Rect(0, 0 - 1080, 2337) mMaxBounds=Rect(0, 0 - 1080, 2400) mDisplayRotation=ROTATION_0 mWindowingMode=fullscreen mActivityType=standard mAlwaysOnTop=undefined mRotation=ROTATION_0} s.2 fontWeightAdjustment=0},deviceId=0,referrer=com.android.shell,procState=2,state=null,persistentState=null,pendingResults=null,pendingNewIntents=null,sceneTransitionInfo=null,profilerInfo=null,assistToken=android.os.BinderProxy@711f745,shareableActivityToken=android.os.BinderProxy@5b7e9a,activityWindowInfo=ActivityWindowInfo{isEmbedded=false, taskBounds=Rect(0, 0 - 1080, 2400), taskFragmentBounds=Rect(0, 0 - 1080, 2400)}} tId:295913160 ResumeActivityItem{mActivityToken=android.os.BinderProxy@b6a90f7,procState=-1,isForward=true,shouldSendCompatFakeFocus=false} tId:295913160 Target activity: com.example.contacts2.MainActivity tId:295913160 ] tId:295913160 } 2025-07-22 13:25:30.038 10369-10369 AndroidRuntime com.example.contacts2 D Shutting down VM 2025-07-22 13:25:30.039 10369-10369 AndroidRuntime com.example.contacts2 E FATAL EXCEPTION: main Process: com.example.contacts2, PID: 10369 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.contacts2/com.example.contacts2.MainActivity}: android.database.sqlite.SQLiteException: unrecognized token: ":" (code 1 SQLITE_ERROR): , while compiling: SELECT phonetic_name, status_updates.status_res_package AS status_res_package, custom_ringtone, contacts_status_updates.status_ts AS contact_status_ts, account_type, data_version, photo_file_id, contacts_status_updates.status_res_package AS contact_status_res_package, group_sourceid, display_name_alt, sort_key_alt, presence.mode AS mode, 0 AS last_time_used, starred, contacts_status_updates.status_label AS contact_status_label, has_phone_number, presence.chat_capability AS chat_capability, raw_contact_id, carrier_presence, contact_last_updated_timestamp, res_package, photo_uri, data_sync4, phonebook_bucket, 0 AS times_used, display_name, sort_key, data_sync1, version, data_sync2, data_sync3, photo_thumb_uri, status_updates.status_label AS status_label, agg_presence.mode AS contact_presence, in_default_directory, 0 AS times_contacted, _id, account_type_and_data_set, name_raw_contact_id, status_updates.status AS status, phonebook_bucket_alt, 0 AS last_time_contacted, pinned, is_primary, photo_id, contact_id, agg_presence.chat_capability AS contact_chat_capability, contacts_status_updates.status_icon AS contact_status_icon, in_visible_group, phonebook_label, account_name, display_name_source, data9, dirty, sourceid, phonetic_name_style, send_to_voicemail, data8, lookup, data7, data6, phonebook_label_alt, data5, is_super_primary, data4, data3, data2, data1, data_set, contacts_status_updates.status AS contact_status, backup_id, preferred_phone_account_component_name, raw_contact_is_user_profile, status_updates.status_ts AS status_ts, data10, preferred_phone_account_id, data12, mimetype, status_updates.status_icon AS status_icon, data11, data14, data13, hash_id, data15 FROM view_data data LEFT OUTER JOIN agg_presence ON (contact_id = agg_presence.presence_contact_id) LEFT OUTER JOIN status_updates contacts_status_updates ON (status_update_id=contacts_status_updates.status_update_data_id) LEFT OUTER JOIN presence ON (presence_data_id=data._id) LEFT OUTER JOIN status_updates ON (status_updates.status_update_data_id=data._id) LEFT OUTER JOIN (SELECT 0 as STAT_DATA_ID,0 as x_times_used, 0 as x_last_time_used,0 as times_used, 0 as last_time_used where 0) as data_usage_stat ON (STAT_DATA_ID=data._id) WHERE (1 AND mimetype_id=5) AND (content://com.android.contacts/data/phones=1) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:4280) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:4467) at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:222) at android.app.servertransaction.TransactionExecutor.executeNonLifecycleItem(TransactionExecutor.java:133) at android.app.servertransaction.TransactionExecutor.executeTransactionItems(TransactionExecutor.java:103) at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:80) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2823) at android.os.Handler.dispatchMessage(Handler.java:110) at android.os.Looper.loopOnce(Looper.java:248) at android.os.Looper.loop(Looper.java:338) at android.app.ActivityThread.main(ActivityThread.java:9067) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:593) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:932) 2025-07-22 13:25:30.041 10369-10369 AndroidRuntime com.example.contacts2 E Caused by: android.database.sqlite.SQLiteException: unrecognized token: ":" (code 1 SQLITE_ERROR): , while compiling: SELECT phonetic_name, status_updates.status_res_package AS status_res_package, custom_ringtone, contacts_status_updates.status_ts AS contact_status_ts, account_type, data_version, photo_file_id, contacts_status_updates.status_res_package AS contact_status_res_package, group_sourceid, display_name_alt, sort_key_alt, presence.mode AS mode, 0 AS last_time_used, starred, contacts_status_updates.status_label AS contact_status_label, has_phone_number, presence.chat_capability AS chat_capability, raw_contact_id, carrier_presence, contact_last_updated_timestamp, res_package, photo_uri, data_sync4, phonebook_bucket, 0 AS times_used, display_name, sort_key, data_sync1, version, data_sync2, data_sync3, photo_thumb_uri, status_updates.status_label AS status_label, agg_presence.mode AS contact_presence, in_default_directory, 0 AS times_contacted, _id, account_type_and_data_set, name_raw_contact_id, status_updates.status AS status, phonebook_bucket_alt, 0 AS last_time_contacted, pinned, is_primary, photo_id, contact_id, agg_presence.chat_capability AS contact_chat_capability, contacts_status_updates.status_icon AS contact_status_icon, in_visible_group, phonebook_label, account_name, display_name_source, data9, dirty, sourceid, phonetic_name_style, send_to_voicemail, data8, lookup, data7, data6, phonebook_label_alt, data5, is_super_primary, data4, data3, data2, data1, data_set, contacts_status_updates.status AS contact_status, backup_id, preferred_phone_account_component_name, raw_contact_is_user_profile, status_updates.status_ts AS status_ts, data10, preferred_phone_account_id, data12, mimetype, status_updates.status_icon AS status_icon, data11, data14, data13, hash_id, data15 FROM view_data data LEFT OUTER JOIN agg_presence ON (contact_id = agg_presence.presence_contact_id) LEFT OUTER JOIN status_updates contacts_status_updates ON (status_update_id=contacts_status_updates.status_update_data_id) LEFT OUTER JOIN presence ON (presence_data_id=data._id) LEFT OUTER JOIN status_updates ON (status_updates.status_update_data_id=data._id) LEFT OUTER JOIN (SELECT 0 as STAT_DATA_ID,0 as x_times_used, 0 as x_last_time_used,0 as times_used, 0 as last_time_used where 0) as data_usage_stat ON (STAT_DATA_ID=data._id) WHERE (1 AND mimetype_id=5) AND (content://com.android.contacts/data/phones=1) at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:197) at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:153) at android.content.ContentProviderProxy.query(ContentProviderNative.java:495) at android.content.ContentResolver.query(ContentResolver.java:1231) at android.content.ContentResolver.query(ContentResolver.java:1163) at android.content.ContentResolver.query(ContentResolver.java:1119) at com.example.contacts2.MainActivity.readContacts(MainActivity.java:66) at com.example.contacts2.MainActivity.onCreate(MainActivity.java:36) at android.app.Activity.performCreate(Activity.java:9155) at android.app.Activity.performCreate(Activity.java:9133) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1521) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:4262) ... 13 more ---------------------------- PROCESS ENDED (10369) for package com.example.contacts2 ----------------------------
最新发布
07-23
Android 开发过程中,`Unable to start service: Intent not found` 是一个常见的运行时错误,通常发生在尝试启动一个未在 `AndroidManifest.xml` 文件中声明的服务(Service),或者目标服务不存在、包名/类名拼写错误。 该问题的根本原因通常是以下几种之一: - **未正确声明 Service**:如果使用的是显式 Intent 启动服务,但目标 `Service` 没有在 `AndroidManifest.xml` 中注册,则会抛出此异常[^1]。 - **隐式 Intent 无法解析**:如果使用的是隐式 Intent,并且没有匹配的 `Service` 能够处理该 Intent(例如没有对应的 `<intent-filter>`),也会导致此错误[^1]。 - **包名或类名错误**:在构建 Intent 时,若指定了错误的组件名称(Component Name),例如类名拼写错误或包名不一致,系统将无法找到对应的服务[^1]。 - **跨应用调用权限问题**:如果尝试从一个应用启动另一个应用中的服务,而后者未暴露其服务或未设置适当的权限,也可能导致 Intent 找不到目标服务[^1]。 ### 解决方案 #### 1. 确保 Service 已在清单文件中声明 确保你要启动的 `Service` 在 `AndroidManifest.xml` 中被正确声明。例如: ```xml <service android:name=".MyBackgroundService" /> ``` 如果是跨应用访问的服务,还需确认是否设置了导出属性: ```xml <service android:name=".MyExportedService" android:exported="true" /> ``` #### 2. 使用正确的 Intent 构建方式 对于本地服务,建议使用显式 Intent: ```java Intent intent = new Intent(context, MyBackgroundService.class); context.startService(intent); ``` 如果是跨应用或隐式调用,应确保 `Intent` 包含合适的 Action 并配置了 `<intent-filter>`: ```java Intent intent = new Intent("com.example.ACTION_START_SERVICE"); context.startService(intent); ``` 并在目标 Service 的清单中添加: ```xml <service android:name=".MyBackgroundService"> <intent-filter> <action android:name="com.example.ACTION_START_SERVICE" /> </intent-filter> </service> ``` #### 3. 检查日志输出以获取更多线索 使用 `Logcat` 查看详细的错误信息,可以定位是哪个组件未找到: ```bash adb logcat -s ActivityManager ``` 你可能会看到类似如下输出: ``` W ActivityManager: Unable to start service Intent { act=com.example.ACTION_START_SERVICE } without a known service ``` 这说明系统找不到匹配的 Service。 #### 4. 权限检查 如果你尝试访问其他应用提供的服务,需确保你拥有相应的权限,并在 `AndroidManifest.xml` 中声明所需权限: ```xml <uses-permission android:name="com.example.permission.ACCESS_SERVICE" /> ``` 同时,在目标服务的声明中允许外部访问: ```xml <service android:name=".ExternalService" android:permission="com.example.permission.ACCESS_SERVICE" android:exported="true"> ... </service> ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值