推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
Gaays

web-app 的形式只有 https 地址可以调用手机摄像头?

  •  
  •   Gaays · Mar 15, 2022 · 3522 views
    This topic created in 1544 days ago, the information mentioned may be changed or developed.

    最近项目需求有扫码功能,我是用的是 vue2 组件 vue-qrcode-reader ,部署地址不是 https 的话无法调取系统摄像头进行扫码。

    想知道这个的原理是什么,以及有办法可以绕过这个限制或有其他不需要 https 也可以调用摄像头的组件吗?麻烦大佬们赐教,谢谢。

    14 replies    2022-12-06 17:12:06 +08:00
    Oktfolio
        1
    Oktfolio  
       Mar 15, 2022
    Chrome 的限制呗
    P090mkVm22352Q8t
        2
    P090mkVm22352Q8t  
       Mar 15, 2022
    之前也做过这个摄像头功能,好像通过 nginx 配置 443 能给你前端地址强制转为 https
    yin1999
        3
    yin1999  
       Mar 15, 2022   ❤️ 1
    仅 https 可以调用,不过 localhost 用 http 应该也能调用( debug 用)。MDN Ref: https://developer.mozilla.org/en-US/docs/Web/API/MediaDevices/getUserMedia
    musi
        4
    musi  
       Mar 15, 2022
    浏览器限制,如果想绕过那只能自己开发 app 了,然后在 app 里写好调用摄像头的 api 再开给 js 访问
    libook
        5
    libook  
       Mar 15, 2022
    部属个 Nginx 用 Let's Encrypt 发个证书。

    强制 HTTPS 主要是安全方面考虑,因为 HTTP 可能被中间人注入代码来开启摄像头。
    otakustay
        6
    otakustay  
       Mar 15, 2022
    基本上近几年新的 API 都是仅 HTTPS 可用的
    leisure
        7
    leisure  
       Mar 15, 2022
    找个厂商申请个免费证书就好了,安全限制
    geekvcn
        8
    geekvcn  
       Mar 15, 2022 via Android
    确实是这样的,不然 http 随便一劫持,摄像头不是随便看
    iqoo
        9
    iqoo  
       Mar 15, 2022   ❤️ 2
    这年头不是 https 的网站都懒得打开
    Chism
        10
    Chism  
       Mar 15, 2022 via Android
    还有一种方法是 input 文件,限定为 image ,并且只能调用相机,这样貌似就可以不用 https ,前端读取 input 的文件也可以直接二维码识别
    AV1
        11
    AV1  
       Mar 15, 2022
    摄像头、屏幕分享、传感器这些对隐私安全要求相对高,只能在 HTTPS 下使用。
    murmur
        12
    murmur  
       Mar 15, 2022
    chrome 连 geolocation 都要 https ,就这玩意给我们坑的不轻,cordova 的应用都是本地文件哪里来的 https ,搞得有一段时间安卓某些个版本就没法定位
    ysc3839
        13
    ysc3839  
       Mar 15, 2022   ❤️ 1
    @murmur Cordova 这种调 WebView 的可以直接模拟一个 https 环境出来,甚至可以关闭安全机制,并没有什么问题
    jeesk
        14
    jeesk  
       Dec 6, 2022
    @murmur 你说的是 chrome 还是 webview 呀?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1303 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 53ms · UTC 17:23 · PVG 01:23 · LAX 10:23 · JFK 13:23
    ♥ Do have faith in what you're doing.