Gorilla Websocket: ошибка при рукопожатии WebSocket: неожиданный код ответа: 404 - PullRequest
0 голосов
/ 04 августа 2020

Я клонировал пример чата gorilla websocket и обновил его, чтобы использовать несколько комнат. Однако всякий раз, когда я пытаюсь установить соединение, я получаю сообщение об ошибке: Error during WebSocket handshake: Unexpected response code: 404 В chrome. Мой исходный код доступен на github . Он очень похож на исходный пример и был немного изменен. Я не знаю, почему он не работает.

РЕДАКТИРОВАТЬ: Проблема возникает в этой строке кода:

for _, name := range []string{"arduino", "java", "go", "scala"} {
    room := newRoom("go")
    http.Handle("/chat/go", room)
    go room.run()
}

Цикл по фрагменту вызывает проблему с функцией httphandle . Если вместо этого я объявляю их индивидуально:

room := newRoom("go")
http.Handle("/chat/go", room)
go room.run()
...

Работает. Как я могу это исправить?

1 Ответ

1 голос
/ 04 августа 2020

Итак, на самом деле из вашего index.html файла вы подключаетесь к неправильному URL-адресу

<!-- index.html -->
<script>
    var serviceLocation = "ws://0.0.0.0:8080/chat/";
.....

    function connectToChatserver() {
        room = $('#chatroom option:selected').val();
        wsocket = new WebSocket(serviceLocation + room);
        // it connect to /chat/<room>, it has slash after chat

Это ваш URL-адрес из main.go

    http.Handle("/chat"+name, room)

URL будет выглядеть следующим образом: http://localhost: 8080 / chat go, а не то, что вы хотите: http://localhost: 8080 / chat / go

Fyi , это приведет к ошибке, потому что вы этого не сделаете правильно обработать channel, поэтому после того, как я отправлю 1 сообщение, оно будет автоматически закрыто. Но это еще один топи c.

2020/08/04 06:42:10 running chat room java
2020/08/04 06:42:10 running chat room go
2020/08/04 06:42:10 running chat room arduino
2020/08/04 06:42:10 running chat room scala
2020/08/04 06:42:15 new client in room arduino
2020/08/04 06:42:15 client leaving room arduino
2020/08/04 06:42:15 client leaving room arduino
panic: close of closed channel

goroutine 6 [running]:
main.(*Room).run(0xc00007ac90)
        /home/fahim/Projects/Golang/go-chat/room.go:70 +0x3b5
created by main.main
        /home/fahim/Projects/Golang/go-chat/main.go:17 +0x2bd
exit status 2
...