请教一个 H5 和 PC 上的程序通讯的问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a Javascript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
Javascript 权威指南第 5 版
Closure: The Definitive Guide
WindProtect
V2EX    Javascript

请教一个 H5 和 PC 上的程序通讯的问题

  •  
  •   WindProtect 2022-03-05 09:36:02 +08:00 3068 次点击
    这是一个创建于 1326 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需求是这样的,我们做了个 h5 程序跑手机浏览器上,然后需要在内网中的某台电脑运行一个打印程序来打印内容。

    本来用的 http + websocket 直连 ip 来通讯,也运行良好。但是现在需要在这个 h5 程序加个扫码功能,这样那 h5 程序只能跑在 https 上,这样 websocket 也只能通过 ssl 来连接,使用 wss 的话又无法通过 ip 来直接请求。

    各位有什么能让使用了 ssl 的 H5 程序直接和指定 PC 通讯的方案么?能双向通讯最好,实在不行单向也行。

    13 条回复    2022-03-05 11:51:50 +08:00
    pigspy
        1
    pigspy  
       2022-03-05 09:44:10 +08:00
    那就看能不能使用第三方的服务器来帮助 PC 和网页端建立连接了
    zhouxiajie86
        2
    zhouxiajie86  
       2022-03-05 09:48:31 +08:00
    用 nginx 做下转发
    WindProtect
        3
    WindProtect  
    OP
       2022-03-05 09:59:39 +08:00
    @pigspy 有想过,一个是双方都和服务器建连接,但这又得自己做转发感觉很麻烦。二是用 MQTT ,不过第一次用不熟悉得学习下。就想着问问看有没什么简单的方法可以手机直接请求到 PC 的方案我又想不到的。。

    @zhouxiajie86 nginx 不现实。打印程序不知道跑哪个网络哪个 ip 的,不可能每安装次打印程序就配置一次吧。
    op351
        4
    op351  
       2022-03-05 09:59:51 +08:00
    h5 扫码只能用 https ?这么神奇吗?
    ciddechan
        5
    ciddechan  
       2022-03-05 10:06:23 +08:00
    反正扫码这种需求也不太需要 ws 吧?直接 h5 简单轮询不行?
    asLw0P981N0M0TCC
        6
    asLw0P981N0M0TCC  
       2022-03-05 10:07:04 +08:00
    nginx !
    Rache1
        7
    Rache1  
       2022-03-05 10:14:47 +08:00   1
    最简单办法,给你这个 H5 再添加一个 https 的域名,扫码的时候单独跳到那个域名,扫码完成后再把扫码结果附在 URL 或者用页面表单带回来 http 的页面,然后再拿给 ws 处理。
    WindProtect
        8
    WindProtect  
    OP
       2022-03-05 10:18:44 +08:00
    @op351 对的,要使用摄像头只能开启 ssl 。

    @ciddechan 用 ws 主要是双向通讯用,和扫码没什么关系,扫码处理 js 就能做了,现在问题是因为要加扫码,导致只能开启 https ,然后不管 ws 还是 http 请求,都要开启 ssl 才能访问。然后我弄域名又不能简单指向到哪台内网的主机。
    WindProtect
        9
    WindProtect  
    OP
       2022-03-05 10:20:46 +08:00
    @Rache1 这个可以,我研究下。
    markgor
        10
    markgor  
       2022-03-05 11:09:42 +08:00
    1 、自签证书---缺点是每个客户端要安装证书
    2 、几十块买个域名配个免费证书--缺点涉及费用
    KingPL
        11
    KingPL  
       2022-03-05 11:24:20 +08:00
    开发个安卓 webView 忽略掉 ssl 自签证书,这样跑 https 的 h5 就行
    WindProtect
        12
    WindProtect  
    OP
       2022-03-05 11:50:17 +08:00
    搞定了,弄个 http 的静态页面,就跑 websocket ,传完数据就关,虽然牺牲了双向通讯的功能,不过这功能在这个 h5 暂时没应用,先这么弄了,下班回家。

    再次感谢 @Rache1
    WindProtect
        13
    WindProtect  
    OP
       2022-03-05 11:51:50 +08:00
    @KingPL 能搞 android 我就不这么头痛了。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5362 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 26ms UTC 07:38 PVG 15:38 LAX 00:38 JFK 03:38
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86