android6,0申請許可權

来源:https://www.cnblogs.com/cwhan/archive/2020/06/11/13095865.html
-Advertisement-
Play Games

#android6.0開啟許可權遇到的一些坑 一個小白,記錄學習遇到的一些坑 最近在做android方面的實驗,做到用LocationManager進行定位,發現單獨在AndroidManifest.xml文件中 聲明開啟許可權,不能夠真正的開啟想要的許可權,說是安全問題,其實在日常中我們都很清楚的一個權 ...


android6.0開啟許可權遇到的一些坑

一個小白,記錄學習遇到的一些坑


最近在做android方面的實驗,做到用LocationManager進行定位,發現單獨在AndroidManifest.xml文件中

聲明開啟許可權,不能夠真正的開啟想要的許可權,說是安全問題,其實在日常中我們都很清楚的一個許可權開啟方式。

遇到問題,第一個想到的就是上網搜索,但是能解決問題的答案少的可憐,所以就記錄下來,防止下次在遇到,不知所措。


廢話不多說,其實很簡單。在你報錯的地方加上一個判斷語句,判斷當前的sdk版本是否大於23,大於就申請開啟許可權;否則直接跳過去執行你的代碼

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
    if (checkSelfPermission(Manifest.permission.ACCESS_FINE_LOCATION) != PERMISSION_GRANTED && checkSelfPermission(Manifest.permission.ACCESS_COARSE_LOCATION) != PERMISSION_GRANTED) {
        ActivityCompat.requestPermissions(this,new String[]{
                Manifest.permission.ACCESS_FINE_LOCATION,
                Manifest.permission.ACCESS_COARSE_LOCATION
        },2);
        return;
    }
}

下麵是我要執行的代碼,這段代碼就是要申請開啟許可權的核心

locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 1000, 0,
        locationListener);

原函數是

public static void requestPermissions(final @NonNull Activity activity,
        final @NonNull String[] permissions, final @IntRange(from = 0) int requestCode) {

參數:

  1. activity: 顧名思義,就是要申請許可權的那個activity。

  2. permissions: 要申請的許可權名稱,比如我申請的有

      Manifest.permission.ACCESS_FINE_LOCATION,衛星定位要用到
     Manifest.permission.ACCESS_COARSE_LOCATION.基站定位要用到
    
  3. requestCode: 隨便填個數,目前我瞭解這個參數在重寫onRequestPermissionsResult這個方法用的到,重寫這個方法可以瞭解到許可權有沒有開啟成功。

    可以通過重寫該函數去顯示許可權開啟成功還是失敗

    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions,
                                           int[] grantResults) {
        if (requestCode == 2) {
            for (int i = 0; i < permissions.length; i++) {
                if (grantResults[i] == PERMISSION_GRANTED) {
                    Toast.makeText(this, "" + "許可權" + permissions[i] + "申請成功", Toast.LENGTH_SHORT).show();
                } else {
                    Toast.makeText(this, "" + "許可權" + permissions[i] + "申請失敗", Toast.LENGTH_SHORT).show();
                }
            }
        }
    }
    

下麵我貼出我本次做的一個實驗

  • 佈局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">
    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/t1"/>
    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/t2"/>
</LinearLayout>
  • java代碼
package com.example.locationmanage;

import android.Manifest;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.location.LocationProvider;
import android.os.Build;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;

import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;

import java.text.SimpleDateFormat;
import java.util.Date;

import static android.content.pm.PackageManager.PERMISSION_GRANTED;

public class MainActivity extends AppCompatActivity {
    TextView info;
    TextView location;
    LocationManager locationManager;
    LocationListener locationListener;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        info = findViewById(R.id.t1);
        location = findViewById(R.id.t2);
        //locationManger初始化
        locationListener_init();
        locationManager_init();
    }


    void locationManager_init() {
        locationManager = (LocationManager) this.getSystemService(LOCATION_SERVICE);
        locationListener_init();


        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            if (checkSelfPermission(Manifest.permission.ACCESS_FINE_LOCATION) != PERMISSION_GRANTED && checkSelfPermission(Manifest.permission.ACCESS_COARSE_LOCATION) != PERMISSION_GRANTED) {
                // TODO: Consider calling
                //    Activity#requestPermissions
                // here to request the missing permissions, and then overriding
                //   public void onRequestPermissionsResult(int requestCode, String[] permissions,
                //                                          int[] grantResults)
                // to handle the case where the user grants the permission. See the documentation
                // for Activity#requestPermissions for more details.
                ActivityCompat.requestPermissions(this,new String[]{
                        Manifest.permission.ACCESS_FINE_LOCATION,
                        Manifest.permission.ACCESS_COARSE_LOCATION
                },2);
                return;
            }
        }
        locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 1000, 0,
                locationListener);

    }

    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions,
                                           int[] grantResults) {
        if (requestCode == 2) {
            for (int i = 0; i < permissions.length; i++) {
                if (grantResults[i] == PERMISSION_GRANTED) {
                    Toast.makeText(this, "" + "許可權" + permissions[i] + "申請成功", Toast.LENGTH_SHORT).show();
                } else {
                    Toast.makeText(this, "" + "許可權" + permissions[i] + "申請失敗", Toast.LENGTH_SHORT).show();
                }
            }
        }
    }


    void locationListener_init() {
        locationListener = new LocationListener() {
            @Override
            public void onLocationChanged(Location location) {
                SimpleDateFormat dateFormat = (SimpleDateFormat)
                        SimpleDateFormat.getTimeInstance(2);
                String str = dateFormat.format(new Date(location.getTime()));
                info.setText("時間:" + str + "\n");
                info.append("經度:" + location.getLongitude() + "\n");
                info.append("緯度:" + location.getLatitude() + "\n");
                info.append("海拔:" + location.getAltitude() + "\n");
            }

            @Override
            public void onStatusChanged(String provider, int status, Bundle extras) {
                if (status == LocationProvider.AVAILABLE)
                    info.setText("當前的gps可見的\n");
                else if (status == LocationProvider.OUT_OF_SERVICE)
                    info.setText("當前的gps服務區外\n");
                else if (status == LocationProvider.TEMPORARILY_UNAVAILABLE)
                    info.setText("當前的gps被暫停\n");
            }

            @Override
            public void onProviderEnabled(String provider) {
                info.setText("當前的gps被啟動\n");
            }

            //被警用時觸發
            @Override
            public void onProviderDisabled(String provider) {
                info.setText("當前的gps被禁用\n");
            }
        };

    }
}
  • 應用清單文件AndroidManifest
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.locationmanage">

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

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

繼續努力!~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Redis 發佈訂閱(pub/sub)是一種消息通信模式:發送者(pub)發送消息,訂閱者(sub)接收消息,它的發佈與訂閱功能由PUBLISH、SUBSCRIBE、PSUBSCRIBE等命令組成。 通過執行SUBSCRIBE命令,客戶端可以訂閱一個或多個頻道,從而成為這些頻道的訂閱者:每當有其他客 ...
  • select * from a where id in (select id from b) 等價於: for select id from b for select 8 from a where a.id = b.id 當b表數據必須小於a表數據時,in優於exists select * from ...
  • 紙上得來終覺淺,絕知此事要躬行。 概述 複製是指將主資料庫的DDL 和 DML 操作通過二進位日誌傳到從庫伺服器中,然後在從庫上對這些日誌重新執行(也叫重做),從而使得從庫和主庫的數據保持同步。 MySQL支持一臺主庫同時向多台從庫進行複製, 從庫同時也可以作為其他從伺服器的主庫,實現鏈狀複製。 優 ...
  • 參考文章: MySQL百萬級數據量分頁查詢方法及其優化 MySQL分頁查詢優化 重點提一下: 在優化分頁語句過程中,一定註意查詢的語句添加排序欄位,一定自己建表實踐,有的可能不一定有效果哦 比如下麵這兩個語句,返回的結果就不是一樣的。具體什麼原因可以看看我另一篇博客 MySQL 預設排序是什麼 SE ...
  • 紙上得來終覺淺,絕知此事要躬行。 InnoDB行鎖 開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖衝突的概率最低,併發度也最高。 InnoDB 實現了以下兩種類型的行鎖。 共用鎖(S):又稱為讀鎖,簡稱S鎖,共用鎖就是多個事務對於同一數據可以共用一把鎖,都能訪問到數據,但是只能讀不能修改。 排他鎖 ...
  • 紙上得來終覺淺,絕知此事要躬行。 鎖的分類 從對數據操作的粒度分 : 表鎖:操作時,會鎖定整個表。 行鎖:操作時,會鎖定當前操作行。 從對數據操作的類型分: 讀鎖(共用鎖):針對同一份數據,多個讀操作可以同時進行而不會互相影響。 寫鎖(排它鎖):當前操作沒有完成之前,它會阻斷其他寫鎖和讀鎖。 MyS ...
  • 問題 在上一篇文章中,我們使用Telegraf自帶的Plugin配置好了的監控,但是自帶的Plugin並不能完全覆蓋我們想要的監控指標,就需要收集額外的自定義的監控數據,實現的方法有: 開發自己的Telegraf Plugin 使用可以執行自定義腳本的inputs plugin 此處收集的監控項不多 ...
  • ​ 數據接入 數據的接入可以通過將數據實時寫入Kafka進行接入,不管是直接的寫入還是通過oracle和mysql的實時接入方式,比如oracle的ogg,mysql的binlog ogg Golden Gate(簡稱OGG)提供異構環境下交易數據的實時捕捉、變換、投遞。 通過OGG可以實時的將or ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...