แม้ว่าข้อมูลเข้าสู่ระบบ FIDO เช่น พาสคีย์ มีไว้เพื่อแทนที่รหัสผ่าน แต่ข้อมูลส่วนใหญ่ยังช่วยให้ผู้ใช้ไม่ต้องพิมพ์ชื่อผู้ใช้ด้วย ซึ่งช่วยให้ผู้ใช้ตรวจสอบสิทธิ์ได้โดยเลือกบัญชีจากรายการพาสคีย์ที่มีสำหรับเว็บไซต์ปัจจุบัน
คีย์ความปลอดภัยเวอร์ชันเก่าออกแบบมาเพื่อใช้ตรวจสอบสิทธิ์แบบ 2 ขั้นตอน และต้องใช้รหัสของข้อมูลเข้าสู่ระบบที่เป็นไปได้ จึงต้องมีการป้อนชื่อผู้ใช้ ข้อมูลเข้าสู่ระบบที่คีย์ความปลอดภัยค้นหาได้โดยไม่ต้องทราบรหัสเรียกว่าข้อมูลเข้าสู่ระบบที่ค้นพบได้ ข้อมูลเข้าสู่ระบบ FIDO ส่วนใหญ่ที่สร้างในปัจจุบันคือข้อมูลเข้าสู่ระบบที่ค้นพบได้ โดยเฉพาะพาสคีย์ที่เก็บไว้ในเครื่องมือจัดการรหัสผ่านหรือในคีย์ความปลอดภัยสมัยใหม่
หากต้องการตรวจสอบว่าระบบสร้างข้อมูลเข้าสู่ระบบเป็นพาสคีย์ (ข้อมูลเข้าสู่ระบบที่ค้นพบได้) ให้ระบุ residentKey
และ requireResidentKey
เมื่อสร้างข้อมูลเข้าสู่ระบบแล้ว
ฝ่ายที่เกี่ยวข้อง (RP) สามารถใช้ข้อมูลเข้าสู่ระบบที่ค้นพบได้โดยละเว้น
allowCredentials
ระหว่างการตรวจสอบสิทธิ์พาสคีย์ ในกรณีเหล่านี้ เบราว์เซอร์หรือระบบจะแสดงรายการพาสคีย์ที่ใช้ได้ให้ผู้ใช้เห็น โดยระบุด้วยพร็อพเพอร์ตี้ user.name
ที่ตั้งค่าไว้ ณ เวลาที่สร้าง หากผู้ใช้เลือกค่าใดค่าหนึ่ง ค่า user.id
จะรวมอยู่ในลายเซ็นที่ได้ จากนั้นเซิร์ฟเวอร์จะใช้รหัสดังกล่าวหรือรหัสข้อมูลเข้าสู่ระบบที่แสดงผลเพื่อค้นหาบัญชีแทนชื่อผู้ใช้ที่พิมพ์
UI ตัวเลือกบัญชี อย่างเช่นที่พูดถึงก่อนหน้านี้ จะไม่แสดง ข้อมูลเข้าสู่ระบบ
requireResidentKey
และ residentKey
หากต้องการสร้างพาสคีย์ ให้ระบุ authenticatorSelection.residentKey
และ authenticatorSelection.requireResidentKey
ใน navigator.credentials.create()
ด้วยค่าที่ระบุไว้ดังต่อไปนี้
async function register () {
// ...
const publicKeyCredentialCreationOptions = {
// ...
authenticatorSelection: {
authenticatorAttachment: 'platform',
residentKey: 'required',
requireResidentKey: true,
}
};
const credential = await navigator.credentials.create({
publicKey: publicKeyCredentialCreationOptions
});
// This does not run until the user selects a passkey.
const credential = {};
credential.id = cred.id;
credential.rawId = cred.id; // Pass a Base64URL encoded ID string.
credential.type = cred.type;
// ...
}
residentKey
:
'required'
: ต้องสร้างข้อมูลเข้าสู่ระบบที่ค้นพบได้ หากสร้างไม่ได้ ระบบจะแสดงผลNotSupportedError
'preferred'
: RP ต้องการสร้างข้อมูลเข้าสู่ระบบที่ค้นพบได้ แต่ยอมรับข้อมูลเข้าสู่ระบบที่ค้นพบไม่ได้'discouraged'
: RP ต้องการสร้างข้อมูลเข้าสู่ระบบที่ค้นพบไม่ได้ แต่ยอมรับข้อมูลเข้าสู่ระบบที่ค้นพบได้
requireResidentKey
:
- ระบบจะเก็บพร็อพเพอร์ตี้นี้ไว้เพื่อใช้งานร่วมกับ WebAuthn ระดับ 1 ซึ่งเป็นข้อกำหนดเวอร์ชันเก่าได้ ตั้งค่าเป็น
true
หากresidentKey
คือ'required'
หรือตั้งค่าเป็นfalse
allowCredentials
RP สามารถใช้ allowCredentials
ใน navigator.credentials.get()
เพื่อควบคุมประสบการณ์การตรวจสอบสิทธิ์พาสคีย์ โดยปกติแล้วประสบการณ์การตรวจสอบสิทธิ์พาสคีย์จะมี 3 ประเภทดังนี้
แสดงตัวเลือกบัญชีแบบโมดอล
เมื่อใช้ข้อมูลเข้าสู่ระบบที่ค้นพบได้ RP สามารถแสดงตัวเลือกบัญชีแบบโมดัลเพื่อให้ผู้ใช้เลือกบัญชีที่จะใช้ลงชื่อเข้าใช้ ตามด้วยการยืนยันผู้ใช้ ซึ่งเหมาะสำหรับขั้นตอนการตรวจสอบสิทธิ์ด้วยพาสคีย์ที่เริ่มต้นด้วยการกดปุ่มสำหรับการตรวจสอบสิทธิ์ด้วยพาสคีย์โดยเฉพาะ
เพื่อให้ผู้ใช้ได้รับประสบการณ์เช่นนี้ ให้ข้ามหรือส่งอาร์เรย์ว่างไปยังพารามิเตอร์ allowCredentials
ใน navigator.credentials.get()
async function authenticate() {
// ...
const publicKeyCredentialRequestOptions = {
// Server generated challenge:
challenge: ****,
// The same RP ID as used during registration:
rpId: 'example.com',
// You can omit `allowCredentials` as well:
allowCredentials: []
};
const credential = await navigator.credentials.get({
publicKey: publicKeyCredentialRequestOptions,
signal: abortController.signal
});
// This does not run until the user selects a passkey.
const credential = {};
credential.id = cred.id;
credential.rawId = cred.id; // Pass a Base64URL encoded ID string.
credential.type = cred.type;
// ...
}
แสดงการป้อนข้อความอัตโนมัติของแบบฟอร์มพาสคีย์
ตัวเลือกบัญชีโมดัลที่อธิบายข้างต้นจะทำงานได้ดีหากผู้ใช้ส่วนใหญ่ใช้พาสคีย์และพร้อมใช้งานในอุปกรณ์ภายใน สำหรับผู้ใช้ที่ไม่มีพาสคีย์ในเครื่อง กล่องโต้ตอบแบบโมดัลจะยังคงปรากฏขึ้นและจะเสนอให้ผู้ใช้แสดงพาสคีย์จากอุปกรณ์เครื่องอื่น ขณะเปลี่ยนให้ผู้ใช้ไปใช้พาสคีย์ คุณอาจต้องการหลีกเลี่ยง UI นั้นสำหรับผู้ใช้ที่ยังไม่ได้ตั้งค่า
แต่อาจมีการพับการเลือกพาสคีย์ไว้ในข้อความแจ้งให้ป้อนข้อความอัตโนมัติสำหรับช่องต่างๆ ในแบบฟอร์มการลงชื่อเข้าใช้แบบดั้งเดิม พร้อมกับชื่อผู้ใช้และรหัสผ่านที่บันทึกไว้ วิธีนี้จะช่วยให้ผู้ใช้ที่มีพาสคีย์ "กรอก" ได้ แบบฟอร์มลงชื่อเข้าใช้ด้วยการเลือกพาสคีย์ ผู้ใช้ที่มีคู่ชื่อผู้ใช้/รหัสผ่านที่บันทึกไว้จะเลือกได้ และผู้ใช้ที่ไม่มีทั้ง 2 อย่างจะยังพิมพ์ชื่อผู้ใช้และรหัสผ่านได้
ประสบการณ์ของผู้ใช้นี้เหมาะที่สุดเมื่อ RP อยู่ระหว่างการย้ายข้อมูลซึ่งมีการใช้รหัสผ่านและพาสคีย์แบบผสม
หากต้องการให้ผู้ใช้ได้รับประสบการณ์การใช้งานนี้ นอกเหนือจากการส่งอาร์เรย์ว่างไปยังพร็อพเพอร์ตี้ allowCredentials
หรือการละเว้นพารามิเตอร์แล้ว ให้ระบุ mediation: 'conditional'
ใน navigator.credentials.get()
และกำกับเนื้อหาในช่องป้อนข้อมูล username
ของ HTML ด้วย autocomplete="username webauthn"
หรือกำกับเนื้อหาในช่องป้อนข้อมูล password
ด้วย autocomplete="password webauthn"
การเรียก navigator.credentials.get()
จะไม่แสดง UI แต่หากผู้ใช้โฟกัสช่องป้อนข้อมูลที่มีคำอธิบายประกอบ พาสคีย์ที่ใช้ได้จะรวมอยู่ในตัวเลือกการป้อนข้อความอัตโนมัติ หากผู้ใช้เลือกแบบใดแบบหนึ่ง การดำเนินการจะผ่านการยืนยันการปลดล็อกอุปกรณ์ปกติ และจากนั้นสัญญาที่ .get()
ส่งคืนมาก็จะได้รับการแก้ไขจนเป็นผล หากผู้ใช้ไม่ได้เลือกพาสคีย์ คำสัญญาจะไม่มีทางได้รับการแก้ไข
async function authenticate() {
// ...
const publicKeyCredentialRequestOptions = {
// Server generated challenge:
challenge: ****,
// The same RP ID as used during registration:
rpId: 'example.com',
// You can omit `allowCredentials` as well:
allowCredentials: []
};
const cred = await navigator.credentials.get({
publicKey: publicKeyCredentialRequestOptions,
signal: abortController.signal,
// Specify 'conditional' to activate conditional UI
mediation: 'conditional'
});
// This does not run until the user selects a passkey.
const credential = {};
credential.id = cred.id;
credential.rawId = cred.id; // Pass a Base64URL encoded ID string.
credential.type = cred.type;
// ...
}
<input type="text" name="username" autocomplete="username webauthn" ...>
คุณดูวิธีสร้างประสบการณ์ของผู้ใช้นี้ได้ที่ลงชื่อเข้าใช้ด้วยพาสคีย์ผ่านการป้อนแบบฟอร์มอัตโนมัติ รวมถึง Codelab ของใช้พาสคีย์กับการป้อนข้อความอัตโนมัติในเว็บแอป
การตรวจสอบสิทธิ์ซ้ำ
ในบางกรณี เช่น เมื่อใช้พาสคีย์ในการตรวจสอบสิทธิ์ซ้ำ ระบบจะรู้จักตัวระบุของผู้ใช้อยู่แล้ว ในกรณีนี้ เราต้องการใช้พาสคีย์โดยที่เบราว์เซอร์หรือระบบปฏิบัติการไม่แสดงตัวเลือกบัญชีในรูปแบบใดๆ เลย ซึ่งทำได้โดยการส่งรายการรหัสข้อมูลเข้าสู่ระบบในพารามิเตอร์ allowCredentials
ในกรณีนี้ หากมีข้อมูลเข้าสู่ระบบที่มีชื่ออยู่ในเครื่อง ระบบจะแจ้งให้ผู้ใช้ปลดล็อกอุปกรณ์ทันที หากไม่ ระบบจะแจ้งให้ผู้ใช้แสดงอุปกรณ์อื่น (โทรศัพท์หรือคีย์ความปลอดภัย) ที่มีข้อมูลเข้าสู่ระบบที่ถูกต้อง
เพื่อให้ผู้ใช้ได้รับประสบการณ์ในการใช้งานนี้ โปรดระบุรายการรหัสข้อมูลเข้าสู่ระบบสำหรับผู้ใช้ที่ลงชื่อเข้าใช้ RP ควรค้นหาได้แล้วเนื่องจากรู้จักผู้ใช้ดังกล่าวอยู่แล้ว ระบุรหัสข้อมูลเข้าสู่ระบบเป็นออบเจ็กต์ PublicKeyCredentialDescriptor
ในพร็อพเพอร์ตี้ allowCredentials
ใน navigator.credentials.get()
async function authenticate() {
// ...
const publicKeyCredentialRequestOptions = {
// Server generated challenge:
challenge: ****,
// The same RP ID as used during registration:
rpId: 'example.com',
// Provide a list of PublicKeyCredentialDescriptors:
allowCredentials: [{
id: ****,
type: 'public-key',
transports: [
'internal',
'hybrid'
]
}, {
id: ****,
type: 'public-key',
transports: [
'internal',
'hybrid'
]
}, ...]
};
const credential = await navigator.credentials.get({
publicKey: publicKeyCredentialRequestOptions,
signal: abortController.signal
});
// This does not run until the user selects a passkey.
const credential = {};
credential.id = cred.id;
credential.rawId = cred.id; // Pass a Base64URL encoded ID string.
credential.type = cred.type;
// ...
}
ออบเจ็กต์ PublicKeyCredentialDescriptor
ประกอบด้วย
id
: รหัสของข้อมูลเข้าสู่ระบบคีย์สาธารณะที่ RP ได้รับในการลงทะเบียนพาสคีย์type
: ช่องนี้โดยปกติจะเป็น'public-key'
transports
: คำแนะนำการนำส่งซึ่งอุปกรณ์ที่มีข้อมูลเข้าสู่ระบบนี้รองรับ ซึ่งเบราว์เซอร์ใช้เพื่อเพิ่มประสิทธิภาพ UI ที่ขอให้ผู้ใช้นำเสนออุปกรณ์ภายนอก รายการนี้ (หากมี) ควรประกอบด้วยผลลัพธ์ของการเรียกใช้getTransports()
ระหว่างการลงทะเบียนข้อมูลเข้าสู่ระบบแต่ละรายการ
สรุป
ข้อมูลเข้าสู่ระบบที่ค้นพบได้ช่วยให้การลงชื่อเข้าใช้ด้วยพาสคีย์นั้นใช้งานง่ายยิ่งขึ้นด้วยการอนุญาตให้ข้ามการป้อนชื่อผู้ใช้ การใช้ residentKey
, requireResidentKey
และ allowCredentials
ร่วมกันช่วยให้ RP มีประสบการณ์การลงชื่อเข้าใช้ที่มีลักษณะดังนี้
- แสดงตัวเลือกบัญชีแบบโมดอล
- แสดงการป้อนข้อความอัตโนมัติของแบบฟอร์มพาสคีย์
- การตรวจสอบสิทธิ์ซ้ำ
ใช้ข้อมูลเข้าสู่ระบบที่ค้นพบได้อย่างชาญฉลาด ซึ่งจะช่วยให้คุณออกแบบประสบการณ์การลงชื่อเข้าใช้ด้วยพาสคีย์ที่ซับซ้อนซึ่งผู้ใช้จะพบว่าราบรื่นและมีโอกาสมีส่วนร่วมมากขึ้น