我正在设置一项涉及启动网络摄像头视频会话的测试。
到目前为止一切正常,除了授予对网络摄像头的访问权限外,不需要任何用户交互。
当我使用的第三方图书馆拨打电话时:navigator.mediaDevices.getUserMedia({audio: true, video: true})
浏览器打开一个提示,要求用户允许访问。
我正在寻找的是一种在没有用户交互的情况下授予访问权限的方法。
我已经尝试过木偶操作员的page.on('dialog'...
但是没有调用网络摄像头访问提示。
如果您有任何想法,请告诉我?
答案 0 :(得分:9)
Google Chrome有一个启动选项--use-fake-ui-for-media-stream
,允许用户跳过getUserMedia的提示。
你可以像下面的木偶操纵者一样设置它。
const puppeteer = require('puppeteer')
;(async () => {
const browser = await puppeteer.launch({
args: [ '--use-fake-ui-for-media-stream' ]
})
const page = await browser.newPage()
await page.goto('http://localhost/start-video-test.html')
const startVideoButton = await page.$('#startVideoButton')
startVideoButton.click()
// video session starts without prompt
return browser.close()
})()