แนวทางปฏิบัติที่ดีที่สุดเกี่ยวกับสิทธิ์ของแอป

คำขอสิทธิ์ช่วยปกป้องข้อมูลที่ละเอียดอ่อนที่มีอยู่จากอุปกรณ์ และ ควรใช้เฉพาะเมื่อจำเป็นต้องเข้าถึงข้อมูลเพื่อ การทำงานของแอป เอกสารฉบับนี้ให้เคล็ดลับเกี่ยวกับวิธีที่คุณ สามารถสร้างฟังก์ชันการทำงานเดียวกัน (หรือดีกว่า) ได้โดยไม่ต้องมีสิทธิ์เข้าถึง ข้อมูลดังกล่าว จึงไม่ใช่การพูดคุยเกี่ยวกับวิธีการให้สิทธิ์ ทำงานในระบบปฏิบัติการ Android

หากต้องการดูภาพรวมของสิทธิ์ Android โปรดดูภาพรวมของสิทธิ์ สำหรับรายละเอียดเกี่ยวกับวิธีทำงานกับสิทธิ์ในโค้ด ดูการขอสิทธิ์ของแอป

สิทธิ์ใน Android 6.0 ขึ้นไป

ใน Android 6.0 (API ระดับ 23) ขึ้นไป แอปจะขอสิทธิ์จาก ผู้ใช้ขณะรันไทม์ ไม่ใช่ก่อนการติดตั้ง วิธีนี้ช่วยให้แอปต่างๆ ดำเนินการต่อไปนี้ได้ ขอสิทธิ์เมื่อแอปต้องใช้บริการหรือข้อมูลจริงๆ ได้รับการปกป้องโดยบริการ แม้ว่าการดำเนินการนี้ไม่ได้เปลี่ยนแอปโดยรวม (จำเป็น) แต่สร้างการเปลี่ยนแปลงบางอย่างที่เกี่ยวข้องกับวิธีข้อมูลผู้ใช้ที่ละเอียดอ่อน มีการจัดการ:

เพิ่มบริบทตามสถานการณ์

ในบริบทของแอป ระบบจะแจ้งให้ผู้ใช้ขอสิทธิ์ที่จะ เข้าถึงฟังก์ชันการทำงานที่อยู่ภายใต้กลุ่มสิทธิ์เหล่านั้น ผู้ใช้มากขึ้น ขึ้นอยู่กับบริบทที่มีการขอสิทธิ์ และในกรณีที่ข้อมูลไม่ตรงกัน ระหว่างสิ่งที่คุณขอกับจุดประสงค์ของแอป การให้คำอธิบายโดยละเอียดแก่ผู้ใช้ว่าทำไมคุณจึง ที่กำลังขออนุญาต หากเป็นไปได้ คุณควรระบุ คำอธิบายเกี่ยวกับคำขอ ทั้งในขณะที่ส่งคำขอและใน กล่องโต้ตอบติดตามผลหากผู้ใช้ปฏิเสธคำขอ

ส่งพรอมต์เท่านั้นเพื่อเพิ่มโอกาสที่คำขอสิทธิ์จะได้รับการยอมรับ เมื่อต้องใช้ฟีเจอร์หนึ่งๆ เช่น แจ้งสำหรับไมโครโฟนเท่านั้น เข้าถึงเมื่อผู้ใช้คลิกปุ่มไมโครโฟน ผู้ใช้มีแนวโน้มที่จะ อนุญาตสิทธิ์ที่ผู้ใช้คาดหวัง

การให้สิทธิ์มีความยืดหยุ่นมากขึ้น

ผู้ใช้จะปฏิเสธการเข้าถึงสิทธิ์แต่ละรายการได้ ณ เวลาที่ขอ และในการตั้งค่า แต่ก็ยังอาจประหลาดใจเมื่อฟังก์ชัน ก็ใช้ไม่ได้ เป็นความคิดที่ดีที่จะตรวจสอบจำนวนผู้ใช้ที่ปฏิเสธ (เช่น การใช้ Google Analytics) ซึ่งคุณจะสามารถเปลี่ยนโครงสร้างภายในโค้ด เพื่อหลีกเลี่ยงการใช้สิทธิ์นั้นหรือให้ คำอธิบายเหตุผลที่คุณต้องขอสิทธิ์เพื่อให้แอปทำงานได้อย่างถูกต้อง คุณ ควรตรวจสอบให้แน่ใจว่าแอปของคุณจัดการข้อยกเว้นเมื่อผู้ใช้ ปฏิเสธคำขอสิทธิ์หรือปิดสิทธิ์ในการตั้งค่า

เพิ่มภาระในการทำธุรกรรม

ระบบจะขอให้ผู้ใช้ให้สิทธิ์เข้าถึงสำหรับกลุ่มสิทธิ์ทีละรายการ ไม่ใช่แบบเป็นชุด ช่วงเวลานี้ ทำให้คุณสามารถลดจำนวนสิทธิ์ที่คุณ ที่ขอ ซึ่งเป็นการเพิ่มภาระให้ผู้ใช้ในการให้สิทธิ์ จะเพิ่มความน่าจะเป็นที่คำขออย่างน้อย 1 รายการจะถูกปฏิเสธ

สิทธิ์ที่ต้องกำหนดเป็นเครื่องจัดการเริ่มต้น

แอปบางแอปอาศัยสิทธิ์เข้าถึงข้อมูลที่ละเอียดอ่อนของผู้ใช้ซึ่งเกี่ยวข้องกับประวัติการโทร และข้อความ SMS หากต้องการขอสิทธิ์เฉพาะสำหรับประวัติการโทร และข้อความ SMS และเผยแพร่แอปไปยัง Play Store คุณจะต้องแจ้ง ผู้ใช้สามารถตั้งค่าแอปของคุณเป็นตัวแฮนเดิลเริ่มต้นสําหรับฟังก์ชันหลักของระบบก่อน ที่ขอสิทธิ์รันไทม์เหล่านี้

สําหรับข้อมูลเพิ่มเติมเกี่ยวกับตัวแฮนเดิลเริ่มต้น รวมถึงคําแนะนําเกี่ยวกับการแสดง ข้อความแจ้งของตัวแฮนเดิลเริ่มต้นแก่ผู้ใช้ โปรดดูคำแนะนำเกี่ยวกับสิทธิ์ที่ใช้เฉพาะใน ตัวแฮนเดิลเริ่มต้น

รู้จักห้องสมุดที่คุณกำลังใช้งาน

บางครั้งไลบรารีที่คุณใช้ในแอปจำเป็นต้องใช้สิทธิ์ สำหรับ เช่น ไลบรารีโฆษณาและไลบรารีการวิเคราะห์อาจต้องมีสิทธิ์เข้าถึง LOCATION กลุ่มสิทธิ์เพื่อติดตั้งใช้งาน แต่จากมุมมองของผู้ใช้ คำขอสิทธิ์มาจาก จากแอป ไม่ใช่ไลบรารี

เช่นเดียวกับที่ผู้ใช้เลือกแอปที่ใช้สิทธิ์น้อยกว่าสำหรับ นักพัฒนาซอฟต์แวร์ควรตรวจสอบไลบรารีของตนและเลือก SDK ของบุคคลที่สามที่ไม่ได้ใช้สิทธิ์ที่ไม่จำเป็น ตัวอย่างเช่น หาก คุณกำลังใช้ไลบรารีที่ให้บริการข้อมูลตำแหน่ง ดูให้แน่ใจว่าคุณ ไม่ได้ขอสิทธิ์ FINE_LOCATION เว้นแต่ว่าคุณจะ โดยใช้ฟังก์ชันการกำหนดเป้าหมายตามสถานที่

จำกัดการเข้าถึงตำแหน่งในเบื้องหลัง

เมื่อแอปของคุณทำงานในพื้นหลัง การเข้าถึง ตำแหน่งควรเป็นส่วนสำคัญสำหรับหัวใจสำคัญของแอป ฟังก์ชันการทำงานและแสดงประโยชน์ที่ชัดเจนต่อผู้ใช้

ทดสอบรูปแบบสิทธิ์ทั้ง 2 แบบ

ใน Android 6.0 (API ระดับ 23) ขึ้นไป ผู้ใช้ให้สิทธิ์และเพิกถอนแอปได้ สิทธิ์ขณะเรียกใช้แอป แทนการดำเนินการเมื่อผู้ใช้ติดตั้งแอป เพื่อ คุณจะต้องทดสอบแอปภายใต้เงื่อนไขที่กว้างกว่า ก่อนหน้า ของ Android 6.0 คุณอาจคาดเดาได้อย่างสมเหตุสมผลว่าหากแอปของคุณกำลังทำงาน ทั้งหมด ไฟล์ก็มีสิทธิ์ทั้งหมดที่ประกาศไว้ในไฟล์ Manifest ของแอป ตอนนี้ ผู้ใช้ สามารถเปิดหรือปิดสิทธิ์สำหรับแอปใดก็ได้โดยไม่คำนึงถึงระดับ API คุณควรทดสอบเพื่อให้มั่นใจว่าแอปทำงานได้อย่างถูกต้อง สถานการณ์ต่างๆ เกี่ยวกับสิทธิ์

เคล็ดลับต่อไปนี้จะช่วยคุณค้นหาปัญหาเกี่ยวกับโค้ดเกี่ยวกับสิทธิ์ ในอุปกรณ์ที่ใช้ API ระดับ 23 ขึ้นไป

  • ระบุสิทธิ์ปัจจุบันของแอปและเส้นทางโค้ดที่เกี่ยวข้อง
  • ทดสอบโฟลว์ของผู้ใช้ในบริการและข้อมูลที่ได้รับการคุ้มครองสิทธิ์
  • ทดสอบกับชุดค่าผสมต่างๆ ของสิทธิ์ที่ได้รับอนุญาตหรือเพิกถอน สำหรับ เช่น แอปกล้องอาจแสดง CAMERA, READ_CONTACTS และ ACCESS_FINE_LOCATION ในไฟล์ Manifest คุณควรทดสอบแอปด้วยสิทธิ์เหล่านี้แต่ละรายการ เปิดและปิดเพื่อให้แน่ใจว่าแอปสามารถจัดการสิทธิ์ทั้งหมด การกำหนดค่าอย่างมีชั้นเชิง
  • ใช้เครื่องมือ adb เพื่อจัดการ จากบรรทัดคำสั่ง:
    • แสดงรายการสิทธิ์และสถานะตามกลุ่ม:
      $ adb shell pm list permissions -d -g
    • ให้หรือเพิกถอนสิทธิ์อย่างน้อย 1 รายการ
      $ adb shell pm [grant|revoke] <permission-name> ...
  • วิเคราะห์แอปเพื่อหาบริการที่ใช้สิทธิ์

แหล่งข้อมูลเพิ่มเติม