สร้างอุปกรณ์เพื่อใช้ประโยชน์จาก WebUSB API อย่างเต็มที่
บทความนี้อธิบายวิธีสร้างอุปกรณ์เพื่อใช้ประโยชน์จาก WebUSB API สำหรับข้อมูลเบื้องต้นเกี่ยวกับ API เอง โปรดดูที่เข้าถึงอุปกรณ์ USB บนเว็บ
ข้อมูลเบื้องต้น
Universal Serial Bus (USB) ได้กลายมาเป็นอินเทอร์เฟซที่ใช้กันมากที่สุดสำหรับ เชื่อมต่ออุปกรณ์ต่อพ่วงกับอุปกรณ์คอมพิวเตอร์เดสก์ท็อปและอุปกรณ์เคลื่อนที่ นอกจาก การกำหนดลักษณะทางไฟฟ้าของรถบัสและรุ่นทั่วไปของ ในการสื่อสารกับอุปกรณ์ ข้อมูลจำเพาะของ USB จะรวมชุดคลาสของอุปกรณ์ นี่เป็นโมเดลทั่วไปสำหรับอุปกรณ์บางประเภท เช่น เป็นพื้นที่เก็บข้อมูล เสียง วิดีโอ เครือข่าย และอื่นๆ ที่ผู้ผลิตอุปกรณ์สามารถ สำหรับการใช้งานจริง ข้อดีของข้อกำหนดจำเพาะระดับอุปกรณ์เหล่านี้คือ ผู้ให้บริการระบบปฏิบัติการ สามารถติดตั้งใช้งานไดรเวอร์เดี่ยวโดยพิจารณาจากคลาส ("ไดรเวอร์คลาส") และอุปกรณ์ใดๆ ที่นำคลาสดังกล่าวไปใช้ ที่รองรับ นี่เป็นการพัฒนาที่ยอดเยี่ยมสำหรับผู้ผลิตทุกรายที่ต้องเขียน ไดรเวอร์อุปกรณ์ของตนเอง
แต่อุปกรณ์บางเครื่องไม่เข้ากับคลาสอุปกรณ์มาตรฐานเหล่านี้ ต ผู้ผลิตอาจเลือกที่จะติดป้ายกำกับอุปกรณ์ของตนว่า คลาสเฉพาะผู้ให้บริการ ในกรณีนี้ ระบบปฏิบัติการจะเลือกอุปกรณ์ ไดรเวอร์ที่จะโหลดโดยอิงจากข้อมูลที่ให้ไว้ในแพ็กเกจคนขับของผู้ให้บริการ โดยปกติเป็นชุดผู้ให้บริการและรหัสผลิตภัณฑ์ซึ่งเป็นที่ทราบว่าควรใช้ โปรโตคอลเฉพาะผู้ให้บริการ
ฟีเจอร์อีกอย่างหนึ่งของ USB คืออุปกรณ์อาจมีอินเทอร์เฟซที่หลากหลาย โฮสต์ที่อุปกรณ์เชื่อมต่ออยู่ แต่ละอินเทอร์เฟซสามารถใช้ คลาสที่เป็นมาตรฐานหรือเจาะจงผู้ให้บริการ เมื่อระบบปฏิบัติการเลือก ในการจัดการอุปกรณ์ อินเทอร์เฟซแต่ละแบบสามารถอ้างสิทธิ์ คนขับ ตัวอย่างเช่น เว็บแคม USB มักมีอินเทอร์เฟซ 2 แบบ ได้แก่ ใช้คลาสวิดีโอ USB (สำหรับกล้อง) และอีกชุดหนึ่งใช้ USB คลาสเสียง (สำหรับไมโครโฟน) ระบบปฏิบัติการไม่ได้โหลด "ไดรเวอร์เว็บแคม" แต่จะโหลดไดรเวอร์คลาสวิดีโอและเสียงอิสระแทน ซึ่งทำหน้าที่แยกฟังก์ชันต่างๆ ของอุปกรณ์ ช่วงเวลานี้ องค์ประกอบของคลาสอินเทอร์เฟซมีความยืดหยุ่นมากขึ้น
ข้อมูลเบื้องต้นเกี่ยวกับ API
คลาส USB มาตรฐานจำนวนมากมี API ของเว็บที่สอดคล้องกัน ตัวอย่างเช่น
หน้าสามารถบันทึกวิดีโอจากอุปกรณ์คลาสวิดีโอโดยใช้ getUserMedia()
หรือได้รับเหตุการณ์อินพุตจากอุปกรณ์คลาสที่มนุษย์สร้างขึ้น (HID) ด้วยการฟัง
สำหรับ KeyboardEvents หรือ PointerEvents หรือใช้เกมแพดหรือ
WebHID API
เช่นเดียวกับอุปกรณ์บางประเภทที่ใช้คำจำกัดความคลาสมาตรฐาน ไม่ใช่ทุกอุปกรณ์
จะใช้ฟีเจอร์ที่สอดคล้องกับ API ของแพลตฟอร์มเว็บที่มีอยู่ วันและเวลา
ในกรณีนี้ WebUSB API สามารถเติมเต็มช่องว่างดังกล่าวโดยมอบวิธีสำหรับเว็บไซต์
เพื่ออ้างสิทธิ์อินเทอร์เฟซเฉพาะผู้ให้บริการ และใช้การสนับสนุนโดยตรงจาก
ภายในหน้าเว็บ
ข้อกำหนดเฉพาะสำหรับอุปกรณ์ที่เข้าถึงได้ผ่าน WebUSB จะแตกต่างกันไปเล็กน้อย จากแต่ละแพลตฟอร์ม เพราะวิธีที่ระบบปฏิบัติการจัดการ USB แตกต่างกัน อุปกรณ์ แต่ข้อกำหนดเบื้องต้นคือ อุปกรณ์ไม่ควรมี ไดรเวอร์ที่อ้างสิทธิ์อินเทอร์เฟซที่หน้าเว็บต้องการควบคุม ซึ่งอาจเป็น ไดรเวอร์คลาสทั่วไปที่จัดหาให้โดยผู้ให้บริการระบบปฏิบัติการหรือไดรเวอร์อุปกรณ์ที่จัดหาให้ ผู้ให้บริการ เนื่องจากอุปกรณ์ USB สามารถให้บริการได้หลายอินเทอร์เฟซ ซึ่งแต่ละอินเทอร์เฟซอาจ มีไดรเวอร์ของตัวเอง คุณสามารถสร้างอุปกรณ์สำหรับอินเทอร์เฟซบางรายการได้ ถูกอ้างสิทธิ์โดยคนขับและบุคคลอื่นๆ สามารถเข้าถึงได้โดยเบราว์เซอร์
ตัวอย่างเช่น แป้นพิมพ์ USB ระดับไฮเอนด์อาจมีอินเทอร์เฟซคลาส HID ที่ จะถูกอ้างสิทธิ์โดยระบบย่อยของระบบปฏิบัติการและข้อมูลเฉพาะผู้ให้บริการ ที่ยังคงพร้อมใช้งานกับ WebUSB เพื่อการใช้งานโดยเครื่องมือกำหนดค่า ช่วงเวลานี้ ในเว็บไซต์ของผู้ผลิต เพื่อให้ผู้ใช้สามารถเปลี่ยน ลักษณะการทํางานของอุปกรณ์ เช่น แป้นมาโคร และเอฟเฟกต์แสงโดยไม่มี ติดตั้งซอฟต์แวร์เฉพาะแพลตฟอร์ม ข้อบ่งชี้การกำหนดค่าของอุปกรณ์ดังกล่าว ซึ่งจะมีลักษณะดังนี้
ค่า | ช่อง | คำอธิบาย |
---|---|---|
ข้อบ่งชี้การกำหนดค่า | ||
0x09 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x02 |
bDescriptorType | ข้อบ่งชี้การกำหนดค่า |
0x0039 |
wTotalLength | ความยาวรวมของข้อบ่งชี้ชุดนี้ |
0x02 |
bNumInterfaces | จำนวนอินเทอร์เฟซ |
0x01 |
bConfigurationValue | การกำหนดค่า 1 |
0x00 |
iConfiguration | ชื่อการกำหนดค่า (ไม่มี) |
0b1010000 |
bmAttributes | อุปกรณ์ที่ขับเคลื่อนโดยตัวเองพร้อมการปลุกระบบจากระยะไกล |
0x32 |
bMaxPower | กำลังสูงสุดจะแสดงโดยเพิ่มครั้งละ 2 mA |
ข้อบ่งชี้อินเทอร์เฟซ | ||
0x09 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x04 |
bDescriptorType | ข้อบ่งชี้อินเทอร์เฟซ |
0x00 |
bInterfaceNumber | อินเทอร์เฟซ 0 |
0x00 |
bAlternateSetting | การตั้งค่าอื่น 0 (ค่าเริ่มต้น) |
0x01 |
bNumEndpoints | 1 ปลายทาง |
0x03 |
bInterfaceClass | คลาสอินเทอร์เฟซ HID |
0x01 |
bInterfaceSubClass | คลาสย่อยของอินเทอร์เฟซการเปิดเครื่อง |
0x01 |
bInterfaceProtocol | แป้นพิมพ์ |
0x00 |
iInterface | ชื่ออินเทอร์เฟซ (ไม่มี) |
ข้อบ่งชี้ HID | ||
0x09 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x21 |
bDescriptorType | ข้อบ่งชี้ HID |
0x0101 |
bcdHID | HID เวอร์ชัน 1.1 |
0x00 |
bCountryCode | ประเทศเป้าหมายของฮาร์ดแวร์ |
0x01 |
bNumDescriptors | จำนวนข้อบ่งชี้คลาส HID ที่จะติดตาม |
0x22 |
bDescriptorType | ประเภทข้อบ่งชี้รายงาน |
0x003F |
wDescriptorLength | ความยาวรวมของข้อบ่งชี้รายงาน |
ข้อบ่งชี้ปลายทาง | ||
0x07 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x05 |
bDescriptorType | ข้อบ่งชี้ปลายทาง |
0b10000001 |
bEndpointAddress | ปลายทาง 1 (IN) |
0b00000011 |
bmAttributes | ขัดจังหวะ |
0x0008 |
wMaxPacketSize | แพ็กเก็ต 8 ไบต์ |
0x0A |
bInterval | ช่วงเวลา 10 มิลลิวินาที |
ข้อบ่งชี้อินเทอร์เฟซ | ||
0x09 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x04 |
bDescriptorType | ข้อบ่งชี้อินเทอร์เฟซ |
0x01 |
bInterfaceNumber | อินเทอร์เฟซ 1 |
0x00 |
bAlternateSetting | การตั้งค่าอื่น 0 (ค่าเริ่มต้น) |
0x02 |
bNumEndpoints | 2 ปลายทาง |
0xFF |
bInterfaceClass | คลาสอินเทอร์เฟซเฉพาะผู้ให้บริการ |
0x00 |
bInterfaceSubClass | |
0x00 |
bInterfaceProtocol | |
0x00 |
iInterface | ชื่ออินเทอร์เฟซ (ไม่มี) |
ข้อบ่งชี้ปลายทาง | ||
0x07 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x05 |
bDescriptorType | ข้อบ่งชี้ปลายทาง |
0b10000010 |
bEndpointAddress | ปลายทาง 1 (IN) |
0b00000010 |
bmAttributes | เป็นกลุ่ม |
0x0040 |
wMaxPacketSize | แพ็กเก็ต 64 ไบต์ |
0x00 |
bInterval | ไม่มีสําหรับปลายทางจำนวนมาก |
ข้อบ่งชี้ปลายทาง | ||
0x07 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x05 |
bDescriptorType | ข้อบ่งชี้ปลายทาง |
0b00000011 |
bEndpointAddress | ปลายทาง 3 (OUT) |
0b00000010 |
bmAttributes | เป็นกลุ่ม |
0x0040 |
wMaxPacketSize | แพ็กเก็ต 64 ไบต์ |
0x00 |
bInterval | ไม่มีสําหรับปลายทางจำนวนมาก |
ข้อบ่งชี้การกำหนดค่าประกอบด้วยข้อบ่งชี้หลายข้อที่ต่อกัน
แต่ละรายการจะขึ้นต้นด้วย bLength
และ bDescriptorType
สามารถระบุได้ อินเทอร์เฟซแรกคืออินเทอร์เฟซ HID ที่เชื่อมโยงกับ
ใช้ข้อบ่งชี้ HID และปลายทางเดี่ยวเพื่อส่งเหตุการณ์อินพุตไปยัง
ระบบปฏิบัติการ อินเทอร์เฟซที่ 2 เป็นอินเทอร์เฟซเฉพาะผู้ให้บริการ โดยมี
ปลายทางที่สามารถใช้เพื่อส่งคำสั่งไปยังอุปกรณ์และรับการตอบสนอง
เป็นการตอบแทน
ตัวบอก WebUSB
แม้ว่า WebUSB จะทำงานกับอุปกรณ์จำนวนมากได้โดยไม่ต้องแก้ไขเฟิร์มแวร์ ใช้ฟังก์ชันเพิ่มเติมได้ด้วยการทำเครื่องหมายอุปกรณ์ด้วย ซึ่งบ่งชี้ถึงการรองรับ WebUSB เช่น คุณสามารถระบุ URL ของหน้า Landing Page ที่เบราว์เซอร์ สามารถนำผู้ใช้ไปได้เมื่ออุปกรณ์ของคุณคือ เสียบปลั๊กอยู่
The Branch Device Object Store (BOS) เป็นแนวคิดที่เปิดตัวใน USB 3.0 แต่มี ยังได้รับการพอร์ตไปยังอุปกรณ์ USB 2.0 เนื่องจากเป็นส่วนหนึ่งของเวอร์ชัน 2.1 การประกาศ การสนับสนุนสำหรับ WebUSB เริ่มต้นด้วยความสามารถของแพลตฟอร์มดังต่อไปนี้ ตัวบอกลักษณะในข้อบ่งชี้ BOS
ค่า | ช่อง | คำอธิบาย |
---|---|---|
ข้อบ่งชี้ Object Store ของอุปกรณ์ไบนารี | ||
0x05 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x0F |
bDescriptorType | ข้อบ่งชี้ Object Store ของอุปกรณ์ไบนารี |
0x001D |
wTotalLength | ความยาวรวมของข้อบ่งชี้ชุดนี้ |
0x01 |
bNumDeviceCaps | จำนวนข้อบ่งชี้ความสามารถของอุปกรณ์ใน BOS |
ข้อบ่งชี้ความสามารถของแพลตฟอร์ม WebUSB | ||
0x18 |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x10 |
bDescriptorType | ข้อบ่งชี้ความสามารถของอุปกรณ์ |
0x05 |
bDevCapabilityType | ข้อบ่งชี้ความสามารถของแพลตฟอร์ม |
0x00 |
bReserved | |
{0x38, 0xB6, 0x08, 0x34, 0xA9, 0x09, 0xA0, 0x47, 0x8B, 0xFD, 0xA0, 0x76, 0x88, 0x15, 0xB6, 0x65} |
PlatformCapablityUUID | GUID ความสามารถของแพลตฟอร์ม WebUSB ในรูปแบบ Little-endian |
0x0100 |
bcdVersion | WebUSB Descriptor เวอร์ชัน 1.0 |
0x01 |
bVendorCode | ค่า bRequest สำหรับ WebUSB |
0x01 |
iLandingPage | URL สำหรับหน้า Landing Page |
UUID ความสามารถของแพลตฟอร์มระบุว่าเป็นความสามารถของแพลตฟอร์ม WebUSB
ข้อบ่งชี้ ซึ่งให้ข้อมูลพื้นฐานเกี่ยวกับอุปกรณ์ สำหรับเบราว์เซอร์
เพื่อดึงข้อมูลเพิ่มเติมเกี่ยวกับอุปกรณ์ที่ใช้ค่า bVendorCode
เพื่อ
ส่งคำขอเพิ่มเติมไปยังอุปกรณ์ คำขอเดียวที่ระบุในปัจจุบันคือ
GET_URL
ซึ่งแสดงผลข้อบ่งชี้ URL ข้อความเหล่านี้คล้ายกับสตริง
แต่ได้รับการออกแบบมาเพื่อเข้ารหัส URL โดยใช้จำนวนไบต์น้อยที่สุด URL
ตัวบ่งชี้สำหรับ "https://google.com"
จะมีลักษณะดังนี้
ค่า | ช่อง | คำอธิบาย |
---|---|---|
ข้อบ่งชี้ URL | ||
0x0D |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x03 |
bDescriptorType | ข้อบ่งชี้ URL |
0x01 |
bScheme | https:// |
"google.com" |
URL | เนื้อหา URL ที่เข้ารหัสแบบ UTF-8 |
เมื่ออุปกรณ์เสียบเบราว์เซอร์เป็นครั้งแรก ให้อ่านข้อบ่งชี้ BOS ตาม
ออกการโอนการควบคุม GET_DESCRIPTOR
แบบมาตรฐานนี้
bmRequestType | bRequest | wValue | wIndex | wLength | ข้อมูล (คำตอบ) |
---|---|---|---|---|---|
0b10000000 |
0x06 |
0x0F00 |
0x0000 |
* | ข้อบ่งชี้ BOS |
โดยปกติแล้วคำขอนี้จะเกิดขึ้น 2 ครั้ง ครั้งแรกที่มี wLength
มีขนาดใหญ่พอ
เพื่อให้โฮสต์ทราบค่าในช่อง wTotalLength
โดยไม่มี
กำลังทำการโอนขนาดใหญ่ แล้วดำเนินการอีกครั้งเมื่อความยาวของข้อบ่งชี้แบบเต็มคือ
รู้จัก
หากตัวบ่งชี้ความสามารถของแพลตฟอร์ม WebUSB มีการตั้งค่าช่อง iLandingPage
เป็น
ค่าที่ไม่ใช่ 0 เบราว์เซอร์จะส่งคำขอ GET_URL
สำหรับ WebUSB โดยเฉพาะ GET_URL
ด้วยการโอนการควบคุมโดยตั้งค่า bRequest
เป็นค่า bVendorCode
จากข้อบ่งชี้ความสามารถของแพลตฟอร์มและตั้งค่า wValue
เป็น iLandingPage
รหัสคำขอสำหรับ GET_URL
(0x02
) จะอยู่ใน wIndex
bmRequestType | bRequest | wValue | wIndex | wLength | ข้อมูล (คำตอบ) |
---|---|---|---|---|---|
0b11000000 |
0x01 |
0x0001 |
0x0002 |
* | ข้อบ่งชี้ URL |
ขอย้ำอีกครั้งว่าอาจมีการออกคำขอนี้ 2 ครั้งเพื่อตรวจสอบความยาวครั้งแรก ของข้อบ่งชี้ที่กำลังอ่านอยู่
ข้อควรพิจารณาเฉพาะแพลตฟอร์ม
แม้ว่า WebUSB API จะพยายามทําให้มีอินเทอร์เฟซที่สอดคล้องกันสําหรับการเข้าถึง นักพัฒนาอุปกรณ์ USB ยังควรตระหนักถึงข้อกำหนดที่บังคับใช้ แอปพลิเคชัน เช่น ข้อกำหนดของเว็บเบราว์เซอร์เพื่อเข้าถึงอุปกรณ์
macOS
ไม่จำเป็นต้องมีสิ่งใดเป็นพิเศษสำหรับ macOS เว็บไซต์ที่ใช้ WebUSB สามารถเชื่อมต่อกับ อุปกรณ์และอ้างสิทธิ์อินเทอร์เฟซใดๆ ที่ไม่ได้อ้างสิทธิ์โดยไดรเวอร์เคอร์เนลหรือ แอปพลิเคชันอื่น
Linux
Linux คล้ายกับ macOS แต่โดยค่าเริ่มต้นแล้ว ดิสทริบิวชันส่วนใหญ่ไม่ได้ตั้งค่าผู้ใช้
บัญชีที่มีสิทธิ์เปิดอุปกรณ์ USB Daemon ของระบบที่ชื่อ udev คือ
มีหน้าที่กำหนดผู้ใช้และกลุ่มที่อนุญาตให้เข้าถึงอุปกรณ์ กฎ
เช่น ระบบจะให้สิทธิ์การเป็นเจ้าของอุปกรณ์ที่ตรงกับผู้ให้บริการที่ระบุ
รหัสผลิตภัณฑ์ไปยังกลุ่ม plugdev
ซึ่งเป็นกลุ่มทั่วไปสำหรับผู้ใช้ที่มีสิทธิ์เข้าถึง
ต่ออุปกรณ์ต่อพ่วง:
SUBSYSTEM=="usb", ATTR{idVendor}=="XXXX", ATTR{idProduct}=="XXXX", GROUP="plugdev"
แทนที่ XXXX
ด้วยผู้ให้บริการฐานสิบหกและรหัสผลิตภัณฑ์สำหรับอุปกรณ์ของคุณ
เช่น ATTR{idVendor}=="18d1", ATTR{idProduct}=="4e11"
จะตรงกับ Nexus One
โทรศัพท์ ค่านี้ต้องเขียนโดยไม่มี "0x" ปกติ คำนำหน้าและตัวพิมพ์เล็กทั้งหมด
ได้อย่างถูกต้อง หากต้องการค้นหารหัสของอุปกรณ์ ให้เรียกใช้คำสั่ง
เครื่องมือ lsusb
ควรวางกฎนี้ในไฟล์ในไดเรกทอรี /etc/udev/rules.d
และ
จะมีผลทันทีที่เสียบปลั๊กอุปกรณ์ ไม่จำเป็นต้องรีสตาร์ท
udev
Android
แพลตฟอร์ม Android ใช้ Linux แต่ไม่ต้องแก้ไขอะไรอีก
การกำหนดค่าระบบ โดยค่าเริ่มต้น อุปกรณ์ที่ไม่มีไดรเวอร์
ลงในระบบปฏิบัติการที่มีอยู่ในเบราว์เซอร์ นักพัฒนาแอปควรเป็น
แต่โปรดทราบว่าผู้ใช้จะต้องพบกับขั้นตอนเพิ่มเติมเมื่อทำการเชื่อมต่อกับ
อุปกรณ์ เมื่อผู้ใช้เลือกอุปกรณ์เพื่อรับสาย
requestDevice()
Android จะแสดงข้อความแจ้งที่ถามว่าอนุญาตหรือไม่
Chrome เพื่อเข้าถึงได้ ข้อความแจ้งนี้จะปรากฏขึ้นอีกครั้งหากผู้ใช้กลับไปที่เว็บไซต์
ที่มีสิทธิ์เชื่อมต่อกับอุปกรณ์และการโทรจากเว็บไซต์อยู่แล้ว
open()
นอกจากนี้ อุปกรณ์จะสามารถเข้าถึงบน Android ได้มากกว่าบน Linux บนเดสก์ท็อป เพราะจะรวมคนขับน้อยลงโดยค่าเริ่มต้น การละเว้นที่เห็นได้ชัด เช่น คลาส USB CDC-ACM ที่โดยทั่วไปใช้โดยอะแดปเตอร์แปลง USB เป็นซีเรียล ไม่มี API ใน Android SDK สำหรับสื่อสารกับอุปกรณ์ซีเรียล
ChromeOS
ChromeOS ที่ใช้ระบบปฏิบัติการ Linux เช่นกัน และไม่จำเป็นต้องมีการปรับเปลี่ยนใดๆ กับการกำหนดค่าระบบ บริการ permission_broker ควบคุมการเข้าถึง USB อุปกรณ์ และจะอนุญาตให้เบราว์เซอร์เข้าถึงได้ ตราบใดที่ยังมี อินเทอร์เฟซที่ไม่มีการอ้างสิทธิ์หนึ่งรายการ
Windows
ไดรเวอร์รุ่น Windows มีข้อกำหนดเพิ่มเติม แตกต่างจาก แพลตฟอร์มที่เหนือกว่าความสามารถในการเปิดอุปกรณ์ USB จากแอปพลิเคชันของผู้ใช้ไม่สามารถ เป็นค่าเริ่มต้นแม้ว่าจะไม่มีการโหลดไดรเวอร์ก็ตาม มีป้ายพิเศษ WinUSB ซึ่งจำเป็นต้องโหลดเพื่อให้อินเทอร์เฟซ ที่แอปพลิเคชันต่างๆ ใช้เพื่อเข้าถึงอุปกรณ์ ซึ่งสามารถดำเนินการได้ด้วย ไฟล์ข้อมูลไดรเวอร์ (INF) ที่ติดตั้งในระบบหรือโดยการดัดแปลงอุปกรณ์ เพื่อจัดหาคำอธิบายความเข้ากันได้ของ Microsoft OS ระหว่าง การแจงนับ
ไฟล์ข้อมูลผู้ขับขี่ (INF)
ไฟล์ข้อมูลไดรเวอร์บอก Windows ถึงสิ่งที่ต้องทำเมื่อพบอุปกรณ์
เป็นครั้งแรก เนื่องจากระบบของผู้ใช้มีไดรเวอร์ WinUSB อยู่แล้ว
เพียงแค่ให้ไฟล์ INF เชื่อมโยงกับผู้ให้บริการและรหัสผลิตภัณฑ์
ด้วยกฎการติดตั้งใหม่นี้ ไฟล์ด้านล่างเป็นตัวอย่างพื้นฐาน บันทึกไว้ใน
ไฟล์ที่มีนามสกุล .inf
ให้เปลี่ยนส่วนที่ทำเครื่องหมายด้วย "X" แล้วไปทางขวา
ให้คลิกแอป แล้วเลือก "ติดตั้ง" จากเมนูตามบริบท
[Version]
Signature = "$Windows NT$"
Class = USBDevice
ClassGUID = {88BAE032-5A81-49f0-BC3D-A4FF138216D6}
Provider = %ManufacturerName%
CatalogFile = WinUSBInstallation.cat
DriverVer = 09/04/2012,13.54.20.543
; ========== Manufacturer/Models sections ===========
[Manufacturer]
%ManufacturerName% = Standard,NTx86,NTia64,NTamd64
[Standard.NTx86]
%USB\MyCustomDevice.DeviceDesc% = USB_Install,USB\VID_XXXX&PID_XXXX
[Standard.NTia64]
%USB\MyCustomDevice.DeviceDesc% = USB_Install,USB\VID_XXXX&PID_XXXX
[Standard.NTamd64]
%USB\MyCustomDevice.DeviceDesc% = USB_Install,USB\VID_XXXX&PID_XXXX
; ========== Class definition ===========
[ClassInstall32]
AddReg = ClassInstall_AddReg
[ClassInstall_AddReg]
HKR,,,,%ClassName%
HKR,,NoInstallClass,,1
HKR,,IconPath,%REG_MULTI_SZ%,"%systemroot%\system32\setupapi.dll,-20"
HKR,,LowerLogoVersion,,5.2
; =================== Installation ===================
[USB_Install]
Include = winusb.inf
Needs = WINUSB.NT
[USB_Install.Services]
Include = winusb.inf
Needs = WINUSB.NT.Services
[USB_Install.HW]
AddReg = Dev_AddReg
[Dev_AddReg]
HKR,,DeviceInterfaceGUIDs,0x10000,"{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}"
; =================== Strings ===================
[Strings]
ManufacturerName = "Your Company Name Here"
ClassName = "Your Company Devices"
USB\MyCustomDevice.DeviceDesc = "Your Device Name Here"
ส่วน [Dev_AddReg]
จะกำหนดค่าชุด DeviceInterfaceGUID สำหรับ
อุปกรณ์ อินเทอร์เฟซอุปกรณ์ทุกเครื่องต้องมี GUID เพื่อให้แอปพลิเคชัน
ค้นหาและเชื่อมต่อกับโดเมน
ผ่าน Windows API ใช้ PowerShell ของ New-Guid
cmdlet หรือเครื่องมือออนไลน์เพื่อสร้าง GUID แบบสุ่ม
เพื่อวัตถุประสงค์ในการพัฒนา เครื่องมือ Zadig มีอินเทอร์เฟซที่ใช้งานง่ายสำหรับ เปลี่ยนไดรเวอร์ที่โหลดสำหรับอินเทอร์เฟซ USB ด้วยไดรเวอร์ WinUSB
ข้อบ่งชี้ความเข้ากันได้ของ Microsoft OS
วิธีการไฟล์ INF ข้างต้นค่อนข้างยุ่งยากเพราะต้องมีการกำหนดค่า เครื่องของผู้ใช้ล่วงหน้า Windows 8.1 ขึ้นไปเสนอทางเลือก ผ่านการใช้ข้อบ่งชี้ USB ที่กำหนดเอง ข้อบ่งชี้เหล่านี้จะให้ข้อมูล กับระบบปฏิบัติการ Windows เมื่อเสียบปลั๊กอุปกรณ์เป็นครั้งแรก มักรวมอยู่ในไฟล์ INF
เมื่อตั้งค่าข้อบ่งชี้ WebUSB แล้ว คุณสามารถเพิ่มระบบปฏิบัติการของ Microsoft ได้อย่างง่ายดาย
ตัวบอกความเข้ากันได้ด้วย ก่อนอื่นให้ขยายข้อบ่งชี้ BOS ด้วยสิ่งนี้
ข้อบ่งชี้ความสามารถของแพลตฟอร์มเพิ่มเติม อย่าลืมอัปเดต wTotalLength
และ bNumDeviceCaps
ค่า | ช่อง | คำอธิบาย |
---|---|---|
ข้อบ่งชี้ความสามารถของแพลตฟอร์ม Microsoft OS 2.0 | ||
0x1C |
bLength | ขนาดของข้อบ่งชี้นี้ |
0x10 |
bDescriptorType | ข้อบ่งชี้ความสามารถของอุปกรณ์ |
0x05 |
bDevCapabilityType | ข้อบ่งชี้ความสามารถของแพลตฟอร์ม |
0x00 |
bReserved | |
{0xDF, 0x60, 0xDD, 0xD8, 0x89, 0x45, 0xC7, 0x4C, 0x9C, 0xD2, 0x65, 0x9D, 0x9E, 0x64, 0x8A, 0x9F} |
PlatformCapablityUUID | GUID ของความเข้ากันได้แพลตฟอร์ม Microsoft OS 2.0 ในรูปแบบ Little-endian |
0x06030000 |
dwWindowsVersion | เวอร์ชัน Windows ที่เข้ากันได้ขั้นต่ำ (Windows 8.1) |
0x00B2 |
wMSOSDescriptorSetTotalLength | ความยาวรวมของชุดข้อบ่งชี้ |
0x02 |
bMS_VendorCode | ค่า bRequest สำหรับการเรียกข้อมูลข้อบ่งชี้ของ Microsoft เพิ่มเติม |
0x00 |
bAltEnumCode | อุปกรณ์ไม่รองรับการแจกแจงสำรอง |
คุณต้องเลือกค่า bRequest
ที่จะใช้ในข้อบ่งชี้ WebUSB
ควบคุมการโอนที่เกี่ยวข้องกับข้อบ่งชี้เหล่านี้ ในตัวอย่างนี้ฉันเลือก
0x02
0x07
ที่วางไว้ใน wIndex
เป็นคำสั่งในการเรียก Microsoft OS
2.0 การตั้งค่าข้อบ่งชี้จากอุปกรณ์
bmRequestType | bRequest | wValue | wIndex | wLength | ข้อมูล (คำตอบ) |
---|---|---|---|---|---|
0b11000000 |
0x02 |
0x0000 |
0x0007 |
* | ชุดข้อบ่งชี้ MS OS 2.0 |
อุปกรณ์ USB สามารถมีหลายฟังก์ชัน ดังนั้นส่วนแรกของข้อบ่งชี้
set จะอธิบายว่าพร็อพเพอร์ตี้ต่อไปนี้เชื่อมโยงกับฟังก์ชันใด
ตัวอย่างด้านล่างกำหนดค่าอินเทอร์เฟซ 1 ของอุปกรณ์ผสม คำอธิบายจะให้
ข้อมูลสำคัญสองประการของระบบปฏิบัติการเกี่ยวกับอินเทอร์เฟซนี้ ฟิลด์
ตัวบอกรหัสบอก Windows ว่าอุปกรณ์นี้ใช้งานได้กับ WinUSB
คนขับ ข้อบ่งชี้พร็อพเพอร์ตี้รีจิสทรีจะทำงานคล้ายกับ
[Dev_AddReg]
ของตัวอย่าง INF ด้านบน การตั้งค่าพร็อพเพอร์ตี้รีจิสทรีเป็น
กำหนด GUID ของอินเทอร์เฟซอุปกรณ์ให้กับฟังก์ชันนี้
ค่า | ช่อง | คำอธิบาย |
---|---|---|
ส่วนหัวชุดข้อบ่งชี้ Microsoft OS 2.0 | ||
0x000A |
wLength | ขนาดของข้อบ่งชี้นี้ |
0x0000 |
wDescriptorType | ตัวบอกส่วนหัวของชุดตัวบอก |
0x06030000 |
dwWindowsVersion | เวอร์ชัน Windows ที่เข้ากันได้ขั้นต่ำ (Windows 8.1) |
0x00B2 |
wTotalLength | ความยาวรวมของชุดข้อบ่งชี้ |
ส่วนหัวย่อยการกำหนดค่า Microsoft OS 2.0 | ||
0x0008 |
wLength | ขนาดของข้อบ่งชี้นี้ |
0x0001 |
wDescriptorType | คำอธิบายส่วนหัวของชุดย่อยการกำหนดค่า |
0x00 |
bConfigurationValue | ใช้กับการกำหนดค่า 1 (จัดทำดัชนีจาก 0 แม้จะมีการกำหนดค่า ปกติได้รับการจัดทำดัชนีจาก 1) |
0x00 |
bReserved | ต้องตั้งค่าเป็น 0 |
0x00A8 |
wTotalLength | ความยาวรวมของเซตย่อยซึ่งรวมส่วนหัวนี้ |
ส่วนหัวย่อยของฟังก์ชัน Microsoft OS 2.0 | ||
0x0008 |
wLength | ขนาดของข้อบ่งชี้นี้ |
0x0002 |
wDescriptorType | ตัวบอกส่วนหัวของชุดย่อยของฟังก์ชัน |
0x01 |
bFirstInterface | อินเทอร์เฟซแรกของฟังก์ชัน |
0x00 |
bReserved | ต้องตั้งค่าเป็น 0 |
0x00A0 |
wSubsetLength | ความยาวรวมของเซตย่อยซึ่งรวมส่วนหัวนี้ |
ข้อบ่งชี้รหัสที่เข้ากันได้กับ Microsoft OS 2.0 | ||
0x0014 |
wLength | ขนาดของข้อบ่งชี้นี้ |
0x0003 |
wDescriptorType | ข้อบ่งชี้รหัสที่เข้ากันได้ |
"WINUSB\0\0" |
CompatibileID | เพิ่มสตริง ASCII เป็น 8 ไบต์ |
"\0\0\0\0\0\0\0\0" |
SubCompatibleID | เพิ่มสตริง ASCII เป็น 8 ไบต์ |
ข้อบ่งชี้พร็อพเพอร์ตี้รีจิสทรี Microsoft OS 2.0 | ||
0x0084 |
wLength | ขนาดของข้อบ่งชี้นี้ |
0x0004 |
wDescriptorType | ข้อบ่งชี้พร็อพเพอร์ตี้รีจิสทรี |
0x0007 |
wPropertyDataType | REG_MULTI_SZ |
0x002A |
wPropertyNameLength | ความยาวของชื่อพร็อพเพอร์ตี้ |
"DeviceInterfaceGUIDs\0" |
PropertyName | ชื่อพร็อพเพอร์ตี้ที่มีตัวระบุค่า Null ที่เข้ารหัสเป็น UTF-16LE |
0x0050 |
wPropertyDataLength | ความยาวของค่าพร็อพเพอร์ตี้ |
"{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}\0\0" |
PropertyData | GUID บวกเครื่องหมายสิ้นสุดที่เป็นค่าว่าง 2 ตัวที่เข้ารหัสเป็น UTF-16LE |
Windows จะค้นหาข้อมูลจากอุปกรณ์ดังกล่าวเพียงครั้งเดียว หากอุปกรณ์รองรับ ไม่ตอบกลับด้วยข้อบ่งชี้ที่ถูกต้อง ระบบจะไม่ถามซ้ำในคราวต่อไป เชื่อมต่ออุปกรณ์แล้ว Microsoft ได้จัดเตรียมรายการรีจิสทรีอุปกรณ์ USB แล้ว รายการที่อธิบายรายการรีจิสทรีที่สร้างขึ้นเมื่อแจกแจงอุปกรณ์ วันและเวลา การทดสอบลบรายการที่สร้างขึ้นสำหรับอุปกรณ์เพื่อบังคับให้ Windows พยายามอ่าน คำอธิบายอีกครั้ง
สำหรับข้อมูลเพิ่มเติม โปรดดูบล็อกโพสต์ของ Microsoft เกี่ยวกับวิธีใช้ ข้อบ่งชี้
ตัวอย่าง
โค้ดตัวอย่างการใช้อุปกรณ์ WebUSB-Aware ที่มีทั้ง WebUSB คุณจะพบข้อบ่งชี้และข้อบ่งชี้ Microsoft OS ในโปรเจ็กต์ต่อไปนี้