{"id":2446,"date":"2024-07-05T12:32:46","date_gmt":"2024-07-05T04:32:46","guid":{"rendered":"https:\/\/cocozq.com\/?p=2446"},"modified":"2024-07-05T12:33:23","modified_gmt":"2024-07-05T04:33:23","slug":"%e5%8d%87%e7%ba%a7targetsdk%e5%88%b034%e5%90%8e%e5%9c%a8android-14%e4%b8%8a%e5%90%8e%e5%8f%b0%e6%9c%8d%e5%8a%a1%e7%9b%b4%e6%8e%a5%e5%b4%a9%e6%ba%83","status":"publish","type":"post","link":"https:\/\/cocozq.com\/?p=2446","title":{"rendered":"\u5347\u7ea7targetSDK\u523034\u540e\u5728Android 14\u4e0a\u540e\u53f0\u6d88\u606f\u901a\u77e5\u670d\u52a1\u76f4\u63a5\u5d29\u6e83"},"content":{"rendered":"<p>\u6700\u8fd1\u6211\u7684<code>\u53ef\u53ef\u4fbf\u7b7e<\/code>\u5f00\u53d1\u5df2\u7ecf\u5230\u6536\u5c3e\u9636\u6bb5\uff0c\u5f53\u6211\u628a<code>targetSDK<\/code>\u5347\u7ea7\u5230<code>34<\/code>\uff0c\u5728<code>Android 14<\/code>\u4e0a\u542f\u52a8\u540e\u53f0\u670d\u52a1\u7684\u76f4\u63a5\u5d29\u4e86<\/p>\n<h2>Service\u914d\u7f6e\u7c7b\u4f3c\u5982\u4e0b<\/h2>\n<pre><code class=\"line-numbers\">&lt;service\n    android:name=\".service.CocoNotificationService\"\n    android:permission=\"android.permission.BIND_NOTIFICATION_LISTENER_SERVICE\"\n    android:foregroundServiceType=\"specialUse|dataSync\"\n    android:exported=\"false\"&gt;\n    &lt;intent-filter&gt;\n        &lt;action android:name=\"android.service.notification.NotificationListenerService\" \/&gt;\n    &lt;\/intent-filter&gt;\n&lt;\/service&gt;\n<\/code><\/pre>\n<h2>\u5d29\u6e83\u65e5\u5fd7<\/h2>\n<blockquote>\n<blockquote><p>\n    FATAL EXCEPTION: main<br \/>\n                                                                                                        Process: com.cocozq.note, PID: 29314<br \/>\n                                                                                                        java.lang.RuntimeException: Unable to create service com.cocozq.coco_flutter.service.CocoNotificationService: java.lang.SecurityException: Starting FGS with type connectedDevice callerApp=ProcessRecord{d54bbf8 29314:com.cocozq.note\/u0a438} targetSDK=34 requires permissions: all of the permissions allOf=true [android.permission.FOREGROUND_SERVICE_CONNECTED_DEVICE] any of the permissions allOf=false [android.permission.BLUETOOTH_ADVERTISE, android.permission.BLUETOOTH_CONNECT, android.permission.BLUETOOTH_SCAN, android.permission.CHANGE_NETWORK_STATE, android.permission.CHANGE_WIFI_STATE, android.permission.CHANGE_WIFI_MULTICAST_STATE, android.permission.NFC, android.permission.TRANSMIT_IR, android.permission.UWB_RANGING, USB Device, USB Accessory]<br \/>\n                                                                                                            at android.app.ActivityThread.handleCreateService(ActivityThread.java:4953)<br \/>\n                                                                                                            at android.app.ActivityThread.-$$Nest$mhandleCreateService(Unknown Source:0)<br \/>\n                                                                                                            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2456)<br \/>\n                                                                                                            at android.os.Handler.dispatchMessage(Handler.java:106)<br \/>\n                                                                                                            at android.os.Looper.loopOnce(Looper.java:257)<br \/>\n                                                                                                            at android.os.Looper.loop(Looper.java:368)<br \/>\n                                                                                                            at android.app.ActivityThread.main(ActivityThread.java:8848)<br \/>\n                                                                                                            at java.lang.reflect.Method.invoke(Native Method)<br \/>\n                                                                                                            at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:572)<br \/>\n                                                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1049)<br \/>\n                                                                                                        Caused by: java.lang.SecurityException: Starting FGS with type connectedDevice callerApp=ProcessRecord{d54bbf8 29314:com.cocozq.note\/u0a438} targetSDK=34 requires permissions: all of the permissions allOf=true [android.permission.FOREGROUND_SERVICE_CONNECTED_DEVICE] any of the permissions allOf=false [android.permission.BLUETOOTH_ADVERTISE, android.permission.BLUETOOTH_CONNECT, android.permission.BLUETOOTH_SCAN, android.permission.CHANGE_NETWORK_STATE, android.permission.CHANGE_WIFI_STATE, android.permission.CHANGE_WIFI_MULTICAST_STATE, android.permission.NFC, android.permission.TRANSMIT_IR, android.permission.UWB_RANGING, USB Device, USB Accessory]<br \/>\n                                                                                                            at android.os.Parcel.createExceptionOrNull(Parcel.java:3087)<br \/>\n                                                                                                            at android.os.Parcel.createException(Parcel.java:3071)<br \/>\n                                                                                                            at android.os.Parcel.readException(Parcel.java:3054)<br \/>\n                                                                                                            at android.os.Parcel.readException(Parcel.java:2996)<br \/>\n                                                                                                            at android.app.IActivityManager$Stub$Proxy.setServiceForeground(IActivityManager.java:6761)<br \/>\n                                                                                                            at android.app.Service.startForeground(Service.java:775)<br \/>\n                                                                                                            at com.cocozq.coco_flutter.service.CocoNotificationService.initNotify(CocoNotificationService.java:101)<br \/>\n                                                                                                            at com.cocozq.coco_flutter.service.CocoNotificationService.onCreate(CocoNotificationService.java:50)<br \/>\n                                                                                                            at android.app.ActivityThread.handleCreateService(ActivityThread.java:4928)<br \/>\n                                                                                                            at android.app.ActivityThread.-$$Nest$mhandleCreateService(Unknown Source:0)<br \/>\n                                                                                                            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2456)<br \/>\n                                                                                                            at android.os.Handler.dispatchMessage(Handler.java:106)<br \/>\n                                                                                                            at android.os.Looper.loopOnce(Looper.java:257)<br \/>\n                                                                                                            at android.os.Looper.loop(Looper.java:368)<br \/>\n                                                                                                            at android.app.ActivityThread.main(ActivityThread.java:8848)<br \/>\n                                                                                                            at java.lang.reflect.Method.invoke(Native Method)<br \/>\n                                                                                                            at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:572)<br \/>\n                                                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1049)<br \/>\n                                                                                                        Caused by: android.os.RemoteException: Remote stack trace:<br \/>\n                                                                                                            at com.android.server.am.ActiveServices.validateForegroundServiceType(ActiveServices.java:2698)<br \/>\n                                                                                                            at com.android.server.am.ActiveServices.setServiceForegroundInnerLocked(ActiveServices.java:2402)<br \/>\n                                                                                                            at com.android.server.am.ActiveServices.setServiceForegroundLocked(ActiveServices.java:1754)<br \/>\n                                                                                                            at com.android.server.am.ActivityManagerService.setServiceForeground(ActivityManagerService.java:14277)<br \/>\n                                                                                                            at android.app.IActivityManager$Stub.onTransact(IActivityManager.java:3385)<br \/>\n    2024-06-30 23:03:27.791 29314-29314 com.cocozq.note         com.cocozq.note                      W  Attempt to remove non-JNI local reference<br \/>\n    2024-06-30 23:03:27.817 29314-29314 Process                 com.cocozq.note                      I  Sending signal. PID: 29314 SIG: 9\n  <\/p><\/blockquote>\n<\/blockquote>\n<h2>\u539f\u56e0<\/h2>\n<p>\u4ece\u65e5\u5fd7\u770b\u51fa<code>Android 14<\/code>\u5f00\u59cb\u5bf9Forgroud\u670d\u52a1\u8fdb\u884c\u4e86\u6743\u9650\u68c0\u6d4b\uff0c\u4f46\u662f\u52a0\u4e0a\u6743\u9650\u5e76\u4e14\u786e\u8ba4\u83b7\u5f97\u6743\u9650\u7684\u60c5\u51b5\u4e0b\u4f9d\u7136\u5d29\u6e83\uff0c\u6700\u540e\u5728google\u5b98\u65b9\u95ee\u9898\u8ffd\u8e2a\u7cfb\u7edf\u770b\u5230\u8fd9\u662f\u7cfb\u7edfbug\u3002<\/p>\n<h2>\u89e3\u51b3\u529e\u6cd5<\/h2>\n<ol>\n<li>targetSDK\u56de\u900033\uff0c\u63a8\u8350\u4f7f\u7528<\/li>\n<li>\u5728\u5bf9\u5e94\u6743\u9650\u4e0a\u52a0\u4e0aremove\u5c5e\u6027<\/li>\n<\/ol>\n<pre><code class=\"line-numbers\">&lt;uses-permission android:name=\"android.permission.FOREGROUND_SERVICE_SPECIAL_USE\" tools:remove=\"\"\/&gt;\n&lt;uses-permission android:name=\"android.permission.FOREGROUND_SERVICE_DATA_SYNC\" tools:remove=\"\"\/&gt;\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u6700\u8fd1\u6211\u7684\u53ef\u53ef\u4fbf\u7b7e\u5f00\u53d1\u5df2\u7ecf\u5230\u6536\u5c3e\u9636\u6bb5\uff0c\u5f53\u6211\u628atargetSDK\u5347\u7ea7\u523034\uff0c\u5728Android 14\u4e0a\u542f\u52a8\u540e\u53f0\u670d\u52a1\u7684 &hellip; <a href=\"https:\/\/cocozq.com\/?p=2446\" class=\"more-link\">Continue reading<span class=\"screen-reader-text\"> &#8220;\u5347\u7ea7targetSDK\u523034\u540e\u5728Android 14\u4e0a\u540e\u53f0\u6d88\u606f\u901a\u77e5\u670d\u52a1\u76f4\u63a5\u5d29\u6e83&#8221;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[22],"tags":[97],"class_list":["post-2446","post","type-post","status-publish","format-standard","hentry","category-22","tag-android","hfeed"],"_links":{"self":[{"href":"https:\/\/cocozq.com\/index.php?rest_route=\/wp\/v2\/posts\/2446","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/cocozq.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/cocozq.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/cocozq.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/cocozq.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2446"}],"version-history":[{"count":2,"href":"https:\/\/cocozq.com\/index.php?rest_route=\/wp\/v2\/posts\/2446\/revisions"}],"predecessor-version":[{"id":2448,"href":"https:\/\/cocozq.com\/index.php?rest_route=\/wp\/v2\/posts\/2446\/revisions\/2448"}],"wp:attachment":[{"href":"https:\/\/cocozq.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2446"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/cocozq.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2446"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/cocozq.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2446"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}