打开activity,报错java.lang.SecurityException: Permission Denial: starting Intent { act=android.intent.ac

问题

Android9 机器,一个应用启动另一个应用

// 启动代码如下
Intent intent = new Intent(Intent.ACTION_MAIN);
                intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                intent.setComponent(new ComponentName(pkg, actName));
                intent.addCategory(Intent.CATEGORY_LAUNCHER);
                mContext.startActivity(intent);
// 被启动应用的AndroidManifest.xml
//非主Activity
        <activity
            android:name=".ui.activity.ActivityX"
            android:launchMode="singleTask"
        </activity>

报错

如下

03-27 09:31:05.648 W/ActivityManager( 1964): Permission Denial: starting Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10000000 cmp=com.exam/.ActivityX } from ProcessRecord{e9fd3c5 3260:com.../u0a36} (pid=3260, uid=10036) not exported from uid 1000
03-27 09:31:05.650 D/AndroidRuntime( 3260): Shutting down VM

03-27 09:31:05.660 E/AndroidRuntime( 3260): FATAL EXCEPTION: main
03-27 09:31:05.660 E/AndroidRuntime( 3260): Process: com.exam.androidA, PID: 3260
03-27 09:31:05.660 E/AndroidRuntime( 3260): java.lang.SecurityException: Permission Denial: starting Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10000000 cmp=com.exam/.ActivityX } from ProcessRecord{e9fd3c5 3260:com.exam.androidA/u0a36} (pid=3260, uid=10036) not exported from uid 1000
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.os.Parcel.createException(Parcel.java:1950)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.os.Parcel.readException(Parcel.java:1918)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.os.Parcel.readException(Parcel.java:1868)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.app.IActivityManager$Stub$Proxy.startActivity(IActivityManager.java:3755)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.app.Instrumentation.execStartActivity(Instrumentation.java:1669)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.app.ContextImpl.startActivity(ContextImpl.java:917)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.app.ContextImpl.startActivity(ContextImpl.java:888)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.content.ContextWrapper.startActivity(ContextWrapper.java:379)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.view.View.performClick(View.java:6597)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.view.View.performClickInternal(View.java:6574)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.view.View.access$3100(View.java:778)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.view.View$PerformClick.run(View.java:25885)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.os.Handler.handleCallback(Handler.java:873)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.os.Handler.dispatchMessage(Handler.java:99)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.os.Looper.loop(Looper.java:193)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at android.app.ActivityThread.main(ActivityThread.java:6671)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at java.lang.reflect.Method.invoke(Native Method)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:871)
03-27 09:31:05.660 E/AndroidRuntime( 3260): Caused by: android.os.RemoteException: Remote stack trace:
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at com.android.server.am.ActivityStackSupervisor.checkStartAnyActivityPermission(ActivityStackSupervisor.java:1781)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at com.android.server.am.ActivityStarter.startActivity(ActivityStarter.java:717)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at com.android.server.am.ActivityStarter.startActivity(ActivityStarter.java:544)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at com.android.server.am.ActivityStarter.startActivityMayWait(ActivityStarter.java:1099)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 	at com.android.server.am.ActivityStarter.execute(ActivityStarter.java:486)
03-27 09:31:05.660 E/AndroidRuntime( 3260): 
03-27 09:31:05.668 W/ActivityManager( 1964):   Force finishing activity com.exam.androidA

解决

此activity加入action属性

<intent-filter>   
        <action android:name="android.intent.action.MAIN" />   
</intent-filter>
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值