为什么我收到了一个超大记录的TLS错误?

8
我想使用go-xmpp连接到DuckDuckGo的XMPP服务
以下是我的测试用例:
package main

import (
    "crypto/tls"
    "log"

    "github.com/mattn/go-xmpp"
)

const (
    svr = "dukgo.com"
    usr = "testtesttest"
    pwd = "test123"
)

func main() {
    xmpp.DefaultConfig = tls.Config{
        ServerName:         svr,
        InsecureSkipVerify: false,
    }

    options := xmpp.Options{
        Host:     svr,
        User:     usr,
        Password: pwd,
    }

    _, err := options.NewClient()
    if err != nil {
        log.Fatal(err)
    }
}

log.Fatal块正在执行并返回以下错误消息:

2016/08/24 16:32:27 tls: oversized record received with length 28012
exit status 1

通过谷歌搜索错误,我发现Docker中也有相同的错误,这并没有什么帮助。这个错误是什么意思?我该怎么解决它?


你可能没有连接到TLS服务器。你的服务器是如何配置的?你需要使用StartTLS吗?TLS是否在不同的端口上?你是否使用TLS? - JimB
1个回答

5

就像你使用的go-xmpp包的示例一样,它也需要端口用于tls。

所以如果没有它,它将尝试连接到HTTP端点并给出此错误。当端点仅支持具有未知CA证书的HTTP或HTTPS时,您会看到类似这样的错误。

请注意,您使用的包还支持无TLS,请仔细检查DuckGo xmpp要求并更改您的代码以匹配它们。

其他类似的帖子

示例

https://github.com/mattn/go-xmpp/blob/master/_example/example.go

// Server has the port
var server = flag.String("server", "talk.google.com:443", "server")
var username = flag.String("username", "", "username")
var password = flag.String("password", "", "password")
var status = flag.String("status", "xa", "status")
var statusMessage = flag.String("status-msg", "I for one welcome our new codebot overlords.", "status message")
var notls = flag.Bool("notls", false, "No TLS")
var debug = flag.Bool("debug", false, "debug output")
var session = flag.Bool("session", false, "use server session")

// Omitted code

var talk *xmpp.Client
var err error
options := xmpp.Options{Host: *server,
    User:          *username,
    Password:      *password,
    NoTLS:         *notls,
    Debug:         *debug,
    Session:       *session,
    Status:        *status,
    StatusMessage: *statusMessage,
}

talk, err = options.NewClient()

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接