0

0

解决 Golang WebSocket 连接失败:Chrome 报错 400

DDD

DDD

发布时间:2025-10-06 12:50:28

|

939人浏览过

|

来源于php中文网

原创

解决 golang websocket 连接失败:chrome 报错 400

本文旨在帮助开发者解决在使用 Golang 构建 WebSocket 服务时,Chrome 浏览器出现 "WebSocket connection failed: Unexpected response code: 400" 错误的问题。通过提供修改后的服务端和客户端代码,阐述了跨域请求导致该错误的原因,并提供了将 HTML 文件托管在 Golang 服务器上的解决方案。

问题分析

当 Chrome 浏览器报告 "WebSocket connection failed: Unexpected response code: 400" 错误时,通常是因为浏览器检测到跨域请求,并认为客户端没有足够的权限访问 WebSocket 服务。 默认情况下,浏览器会阻止从一个域加载的网页去请求另一个域的资源,这被称为同源策略。

解决方案

解决此问题的关键是将 HTML 页面也托管在 Golang 服务器上,确保 WebSocket 连接与提供 HTML 页面的源同源。

1. 修改 Golang 服务端代码

立即学习go语言免费学习笔记(深入)”;

修改 main.go 文件,使其能够同时提供静态文件服务和 WebSocket 服务。以下是修改后的代码:

package main

import (
    "fmt"
    "log"
    "net/http"

    "golang.org/x/net/websocket"
)

func Echo(ws *websocket.Conn) {
    var err error

    for {
        var reply string

        if err = websocket.Message.Receive(ws, &reply); err != nil {
            fmt.Println("Can't receive")
            break
        }

        fmt.Println("Received back from client: " + reply)

        msg := "Received:  " + reply
        fmt.Println("Sending to client: " + msg)

        if err = websocket.Message.Send(ws, msg); err != nil {
            fmt.Println("Can't send")
            break
        }
    }
}

func main() {
    http.Handle("/", http.FileServer(http.Dir("."))) // 提供静态文件服务
    http.Handle("/socket", websocket.Handler(Echo))   // WebSocket 服务
    log.Println("serving")
    if err := http.ListenAndServe(":1234", nil); err != nil {
        log.Fatal("ListenAndServe:", err)
    }
}

关键修改在于添加了 http.Handle("/", http.FileServer(http.Dir("."))) 这一行代码。它将根路径 / 映射到当前目录 (.),允许服务器提供当前目录下的静态文件,包括 HTML 文件。同时,将WebSocket服务的路径修改为 /socket。

2. 修改 HTML 客户端代码

Removal.AI
Removal.AI

AI移出图片背景工具

下载

修改 HTML 文件,使其连接到正确的 WebSocket 服务路径。以下是修改后的 index.html 文件:







  
  

WebSocket Echo Test

Message:

关键修改在于将 wsuri 的值修改为 "ws://127.0.0.1:1234/socket",与服务端代码中 WebSocket 服务的路径相匹配。

3. 目录结构

确保 index.html 文件与 main.go 文件位于同一目录下。例如:

.
├── index.html
└── main.go

4. 运行程序

  1. 保存 main.go 和 index.html 文件。
  2. 在终端中,进入包含这两个文件的目录。
  3. 运行 go run main.go 命令启动服务器。
  4. 在 Chrome 浏览器中打开 http://127.0.0.1:1234/,即可访问 HTML 页面并建立 WebSocket 连接。

注意事项

  • 确保安装了 golang.org/x/net/websocket 包。如果没有安装,可以使用 go get golang.org/x/net/websocket 命令安装。
  • 如果仍然遇到问题,请检查浏览器的开发者工具,查看是否有其他错误信息。
  • 在生产环境中,建议使用更健壮的静态文件服务器,例如 Nginx 或 Apache。

总结

通过将 HTML 页面托管在 Golang 服务器上,可以有效解决 Chrome 浏览器中 WebSocket 连接失败的 400 错误。 这种方法避免了跨域请求问题,确保客户端能够成功连接到 WebSocket 服务。 同时,需要注意WebSocket服务的路径配置,确保客户端和服务器端的配置一致。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

178

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

337

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

195

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

190

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

192

2025.06.17

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.2万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号