登录
首页 >  Golang >  Go问答

在 ECS 上运行的 golang FTP PASS(密码)命令无法正常工作

来源:stackoverflow

时间:2024-03-08 16:12:27 270浏览 收藏

学习Golang要努力,但是不要急!今天的这篇文章《在 ECS 上运行的 golang FTP PASS(密码)命令无法正常工作》将会介绍到等等知识点,如果你想深入学习Golang,可以关注我!我会持续更新相关文章的,希望对大家都能有所帮助!

问题内容

我有一个 go 服务器,它使用 github.com/jlaffaye/ftp 库从远程服务器获取 ftp 文件。 我首先获得连接

conn, err := ftp.dialtimeout(cfg.host+cfg.port, time.second*15)
    if err != nil {
        return nil, fmt.errorf("ftp dial error: %v", err)
    }

之后,我尝试登录

err = conn.login(cfg.username, pwd)
    if err != nil {
        return nil, fmt.errorf("ftp login error: %v", err)
    }

我在本地运行时登录成功。 在查看输出时也证实了这一点

code, msg, err := c.cmd(StatusLoggedIn, "PASS %s", password)
        log.Printf("pass, code %d, msg %s, err %v", code, msg, err)
        if err != nil {
            return err
        }

它来自我的供应商 pkg,位于 \vendor\github.com\jlaffaye\ftp\ftp.go 输出为

2021/06/16 23:12:45 通过,代码 230,msg 用户 xxxx 登录,错误

在运行部署在亚马逊ecs上的相同服务时, \vendor\github.com\jlaffaye\ftp\ftp.go 下供应的 pkg 的输出变为

2021/06/16 20:24:28 通过,代码 0,消息,错误 eof

有人可以建议一下可能导致此问题的原因吗?


正确答案


从亚马逊 ecs 运行时,似乎无法访问 ftp 服务器,因为 ec2 计算机的 ip 地址未在 ftp 服务器中列入白名单。 使用 telnet 进行了一些调试

来自我们 vpn 后面的本地计算机

# telnet ftp.xxxxxxxxx.net 21
trying xx.xxx.xxx.xxx...
connected to xxxxxxxxxxx.net.
escape character is '^]'.
220 proftpd 1.3.5 server (proftpd default installation) [xx.xxx.xxx.xxx]
user xxxx
331 password required for xxxx
pass xxxxxxxxx
230 user xxx logged in

来自不同 vpc 中的 ec2 计算机

Connected to ftp.xxxxxxxxxxxx.net.
Escape character is '^]'.
220 ProFTPD 1.3.5 Server (ProFTPD Default Installation) [xx.xxx.xxx.xxx]
USER xxxx
331 Password required for xxxx
PASS xxxxxxxx
Connection closed by foreign host.

今天关于《在 ECS 上运行的 golang FTP PASS(密码)命令无法正常工作》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>