Intereting Posts
Получение токена авторизации Google oauth с Android-return с invalid_scope / Неизвестная ошибка Как изменить содержимое EditText на Javascript? Как создать экран слайдера (как в Tweetdeck) в Android? Сообщение о тостах из потока EGL_emulation не удалось установить соединение с host-android Разрешение отказа: startActivity запрашивает запуск как пользователь -2, но вызывает от пользователя 0; Это требует android.permission.INTERACT_ACROSS_USERS_FULL Android, могу ли я поместить AsyncTask в отдельный класс и иметь обратный вызов? Установка текста буфера обмена через оболочку adb с уровня API 11 Использование ECC Curve25519 для шифрования / дешифрования данных в Java Android, AsyncTask, проверить статус? Разделение больших классов на внутренние классы в Java Что происходит за кулисами, когда я выполняю синхронизацию репо? SwipeRefreshLayout отключить анимацию перетаскивания Переменная «runnable» должна быть инициализирована Как выйти из приложения и показать главный экран?

Ошибка Android «gps требует ACCESS_FINE_LOCATION», хотя мой файл манифеста содержит это

Каждый раз, когда я запускаю приложение, мое SecurityException получает бросок и ошибка от отладчика читается так:

Java.lang.SecurityException: провайдеру местоположения «gps» требуется разрешение ACCESS_COARSE_LOCATION или ACCESS_FINE_LOCATION.

Это кажется простой ошибкой, однако мой файл манифеста совершенно прав. Вот он, и вот мой код MapActivity:

<?xml version="1.0" encoding="utf-8"?> 

 <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" /> <uses-permission android:name="com.dev.cromer.jason.coverme.permission.MAPS_RECEIVE" /> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name=".MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" /> <meta-data android:name="com.google.android.maps.v2.API_KEY" android:value= "@string/google_maps_key" /> <activity android:name=".MapActivity" android:label="@string/title_activity_map" > </activity> </application> 

Моя активность:

  package com.dev.cromer.jason.coverme; import android.location.Criteria; import android.location.Location; import android.location.LocationListener; import android.location.LocationManager; import android.support.v4.app.FragmentActivity; import android.os.Bundle; import android.util.Log; import com.google.android.gms.common.ConnectionResult; import com.google.android.gms.common.api.GoogleApiClient; import com.google.android.gms.location.LocationServices; import com.google.android.gms.maps.CameraUpdateFactory; import com.google.android.gms.maps.GoogleMap; import com.google.android.gms.maps.SupportMapFragment; import com.google.android.gms.maps.model.LatLng; import com.google.android.gms.maps.model.MarkerOptions; public class MapActivity extends FragmentActivity implements LocationListener { private GoogleMap mMap; // Might be null if Google Play services APK is not available. @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_map); setUpMapIfNeeded(); } @Override protected void onResume() { super.onResume(); setUpMapIfNeeded(); } private void setUpMapIfNeeded() { // Do a null check to confirm that we have not already instantiated the map. if (mMap == null) { // Try to obtain the map from the SupportMapFragment. mMap = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)) .getMap(); // Check if we were successful in obtaining the map. if (mMap != null) { //mMap.setMyLocationEnabled(true); //mMap.setOnMyLocationChangeListener(this); setUpMap(); } } } private void setUpMap() { mMap.addMarker(new MarkerOptions().position(new LatLng(0, 0)).title("Marker")); mMap.setMyLocationEnabled(true); LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE); try { Location myLocation = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER); if (myLocation != null) { Log.d("TAG", "Not null"); } else { Log.d("TAG", "NULL"); locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, this); } } catch (SecurityException se) { Log.d("TAG", "SE CAUGHT"); se.printStackTrace(); } } @Override public void onLocationChanged(Location location) { Log.d("CHANGED", "LOCATION UPDATED"); } @Override public void onStatusChanged(String provider, int status, Bundle extras) { } @Override public void onProviderEnabled(String provider) { } @Override public void onProviderDisabled(String provider) { } } 

Solutions Collecting From Web of "Ошибка Android «gps требует ACCESS_FINE_LOCATION», хотя мой файл манифеста содержит это"

ACCESS_COARSE_LOCATION , ACCESS_FINE_LOCATION и WRITE_EXTERNAL_STORAGE – все это часть системы разрешений времени исполнения Android 6.0 . Помимо того, что они есть в манифесте, как и вы, вы также должны запросить их у пользователя во время выполнения (используя requestPermissions() ) и посмотреть, есть ли у вас их (используя checkSelfPermission() ).

Одним из targetSdkVersion обхода в краткосрочной перспективе является снижение targetSdkVersion до 23.

Но, в конце концов, вы захотите обновить свое приложение, чтобы использовать систему разрешения времени выполнения.

Например, эта работа работает с пятью разрешениями. Четыре – это разрешения времени выполнения, хотя в настоящее время он обрабатывает только три (я написал их до того, как WRITE_EXTERNAL_STORAGE был добавлен в список разрешений времени исполнения).

 /*** Copyright (c) 2015 CommonsWare, LLC Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0. Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. From _The Busy Coder's Guide to Android Development_ https://commonsware.com/Android */ package com.commonsware.android.permmonger; import android.Manifest; import android.app.Activity; import android.content.pm.PackageManager; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.widget.TextView; import android.widget.Toast; public class MainActivity extends Activity { private static final String[] INITIAL_PERMS={ Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.READ_CONTACTS }; private static final String[] CAMERA_PERMS={ Manifest.permission.CAMERA }; private static final String[] CONTACTS_PERMS={ Manifest.permission.READ_CONTACTS }; private static final String[] LOCATION_PERMS={ Manifest.permission.ACCESS_FINE_LOCATION }; private static final int INITIAL_REQUEST=1337; private static final int CAMERA_REQUEST=INITIAL_REQUEST+1; private static final int CONTACTS_REQUEST=INITIAL_REQUEST+2; private static final int LOCATION_REQUEST=INITIAL_REQUEST+3; private TextView location; private TextView camera; private TextView internet; private TextView contacts; private TextView storage; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); location=(TextView)findViewById(R.id.location_value); camera=(TextView)findViewById(R.id.camera_value); internet=(TextView)findViewById(R.id.internet_value); contacts=(TextView)findViewById(R.id.contacts_value); storage=(TextView)findViewById(R.id.storage_value); if (!canAccessLocation() || !canAccessContacts()) { requestPermissions(INITIAL_PERMS, INITIAL_REQUEST); } } @Override protected void onResume() { super.onResume(); updateTable(); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.actions, menu); return(super.onCreateOptionsMenu(menu)); } @Override public boolean onOptionsItemSelected(MenuItem item) { switch(item.getItemId()) { case R.id.camera: if (canAccessCamera()) { doCameraThing(); } else { requestPermissions(CAMERA_PERMS, CAMERA_REQUEST); } return(true); case R.id.contacts: if (canAccessContacts()) { doContactsThing(); } else { requestPermissions(CONTACTS_PERMS, CONTACTS_REQUEST); } return(true); case R.id.location: if (canAccessLocation()) { doLocationThing(); } else { requestPermissions(LOCATION_PERMS, LOCATION_REQUEST); } return(true); } return(super.onOptionsItemSelected(item)); } @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { updateTable(); switch(requestCode) { case CAMERA_REQUEST: if (canAccessCamera()) { doCameraThing(); } else { bzzzt(); } break; case CONTACTS_REQUEST: if (canAccessContacts()) { doContactsThing(); } else { bzzzt(); } break; case LOCATION_REQUEST: if (canAccessLocation()) { doLocationThing(); } else { bzzzt(); } break; } } private void updateTable() { location.setText(String.valueOf(canAccessLocation())); camera.setText(String.valueOf(canAccessCamera())); internet.setText(String.valueOf(hasPermission(Manifest.permission.INTERNET))); contacts.setText(String.valueOf(canAccessContacts())); storage.setText(String.valueOf(hasPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE))); } private boolean canAccessLocation() { return(hasPermission(Manifest.permission.ACCESS_FINE_LOCATION)); } private boolean canAccessCamera() { return(hasPermission(Manifest.permission.CAMERA)); } private boolean canAccessContacts() { return(hasPermission(Manifest.permission.READ_CONTACTS)); } private boolean hasPermission(String perm) { return(PackageManager.PERMISSION_GRANTED==checkSelfPermission(perm)); } private void bzzzt() { Toast.makeText(this, R.string.toast_bzzzt, Toast.LENGTH_LONG).show(); } private void doCameraThing() { Toast.makeText(this, R.string.toast_camera, Toast.LENGTH_SHORT).show(); } private void doContactsThing() { Toast.makeText(this, R.string.toast_contacts, Toast.LENGTH_SHORT).show(); } private void doLocationThing() { Toast.makeText(this, R.string.toast_location, Toast.LENGTH_SHORT).show(); } } 

(Из этого образца проекта )

Для функции requestPermissions (), должны ли параметры просто быть «ACCESS_COARSE_LOCATION»? Или мне следует включить полное имя «android.permission.ACCESS_COARSE_LOCATION»?

Я бы использовал константы, определенные в Manifest.permission , как показано выше.

Кроме того, что такое код запроса?

Это будет передано вам в качестве первого параметра onRequestPermissionsResult() , так что вы можете сказать одному requestPermissions() от другого.

Мое простое решение – это

 if (ContextCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED && ContextCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_COARSE_LOCATION) == PackageManager.PERMISSION_GRANTED) { googleMap.setMyLocationEnabled(true); googleMap.getUiSettings().setMyLocationButtonEnabled(true); } else { Toast.makeText(this, R.string.error_permission_map, Toast.LENGTH_LONG).show(); } 

Или вы можете открыть диалоговое окно разрешений иначе, как это

 } else { ActivityCompat.requestPermissions(this, new String[] { Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.ACCESS_COARSE_LOCATION }, TAG_CODE_PERMISSION_LOCATION); } 

ПРИЧИНА: «Начиная с Android 6.0 (API-уровень 23) пользователи предоставляют разрешения для приложений во время работы приложения, а не при установке приложения». В этом случае «ACCESS_FINE_LOCATION» является «опасным разрешением, и по этой причине вы получаете это» java.lang.SecurityException: «поставщик местоположения gps» требует разрешения ACCESS_FINE_LOCATION ». Error ( https://developer.android.com/training/permissions/requesting.html ).

РЕШЕНИЕ: Внедрение кода, представленного на странице https://developer.android.com/training/permissions/requesting.html, в разделе «Запросить разрешения, необходимые вам» и «Обработать ответ на запрос разрешения».