V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
tool2d
V2EX  ›  问与答

有人知道,为什么 electron 没办法载入任天堂的网站吗?

  •  
  •   tool2d · 2023-01-31 15:41:40 +08:00 · 1120 次点击
    这是一个创建于 451 天前的主题,其中的信息可能已经有所发展或是发生改变。
    按照官方例子,main.js 就改了一句 mainWindow.loadURL("https://accounts.nintendo.com"); 页面无法打开,也没有响应。

    换成 baidu 都可以,就是这个不行,百思不得其解。

    我在官网下了很多老版本测试,也不行,真的很奇怪。
    12 条回复    2023-02-01 10:02:21 +08:00
    gzlock
        1
    gzlock  
       2023-01-31 16:03:50 +08:00   ❤️ 1
    盲猜 ua 的问题?
    tool2d
        2
    tool2d  
    OP
       2023-01-31 16:10:08 +08:00
    @gzlock 感觉不像 ua 问题,electron 连页面的成功载入消息都没给我推。

    而且开发者控制台输入 window.open("https://accounts.nintendo.com"); 也会堵住后面所有输入。
    hahastudio
        3
    hahastudio  
       2023-01-31 17:36:06 +08:00   ❤️ 1
    你的网络能正常打开你说的页面吗,我怀疑是 DNS 的问题
    我用 Electron Fiddle 试了一下,用了 Electron v22.1.0 ,没有问题
    tool2d
        4
    tool2d  
    OP
       2023-01-31 17:59:18 +08:00
    @hahastudio 你可以打开啊?

    我差一点就去官方提交 issues 了,那我换台电脑再查查原因。
    tool2d
        5
    tool2d  
    OP
       2023-01-31 18:46:06 +08:00
    hahastudio
        6
    hahastudio  
       2023-01-31 19:36:30 +08:00
    Request URL: https://accounts.nintendo.com/
    Request Method: GET
    Status Code: 302 Moved Temporarily
    Referrer Policy: strict-origin-when-cross-origin

    Cache-Control: private, no-cache, must-revalidate, no-store
    Connection: keep-alive
    Content-Length: 0
    Date: Tue, 31 Jan 2023 11:32:19 GMT
    Expires: Tue, 31 Jan 2023 11:32:19 GMT
    Location: https://accounts.nintendo.com/login?post_login_redirect_uri=https%3A%2F%2Faccounts.nintendo.com%2F
    Pragma: no-cache
    Server: nginx
    Strict-Transport-Security: max-age=2592000; includeSubDomains
    X-Content-Type-Options: nosniff
    X-Frame-Options: SAMEORIGIN
    Set-Cookie: ...

    我觉得区别在 status code ,一个是 302 ,你给 /a 的话是 404 。
    我猜是你那边有处理跳转的 code ,可能没写好
    tool2d
        7
    tool2d  
    OP
       2023-01-31 20:27:55 +08:00
    @hahastudio 你试一下 curl https://accounts.nintendo.com/login?post_login_redirect_uri=https%3A%2F%2Faccounts.nintendo.com%2F 或者 wget 呢?

    离开浏览器,我就取不下数据了。和 electron 一样,直接卡住。
    hahastudio
        8
    hahastudio  
       2023-01-31 20:46:42 +08:00
    @tool2d 那大概率是因为你的 Chrome 设置代理了
    tool2d
        9
    tool2d  
    OP
       2023-01-31 23:16:06 +08:00
    @hahastudio 我把 chrome 浏览器的访问日志全部导出,一个个对比参数,终于找到原因了。

    任天堂的服务器比较特殊,需要把 curl 里默认的 Connection: close 改成 Connection: keep-alive ,就能正常访问了。

    chrome 内核默认 connection:keep-alive, 而 electron 内核默认 connection:close 。
    tool2d
        10
    tool2d  
    OP
       2023-02-01 00:08:13 +08:00
    上面说的有点问题,通过 Chrome DevTool Protocol 调试发现,electron 内核默认也是 keep-alive 。

    终极答案在一楼,就是 UA 被识别到了。

    任天堂服务器看到 UA 里有 Electron/22.0.3 ,就拒绝返回!去掉就好了。
    tool2d
        11
    tool2d  
    OP
       2023-02-01 00:09:18 +08:00
    @gzlock 花了我 8 小时,才验证你的猜想。NB
    hahastudio
        12
    hahastudio  
       2023-02-01 10:02:21 +08:00
    我这边 Electron 发送的 UA 是
    User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) scrawny-contract-implement-ypfyw/1.0.0 Chrome/108.0.5359.179 Electron/22.1.0 Safari/537.36
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2595 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 15:41 · PVG 23:41 · LAX 08:41 · JFK 11:41
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.