doujiebo9849 2016-02-17 07:31
浏览 358

如何提高golang.org/x/crypto/ssh的详细程度

i wanted to use golang.org/x/crypto/ssh to write a little program which is able to read the equivalent to ssh -v output. While i am able to connect via the ssh package to my server i have no idea how to enable verbose output or get to the desired information in it. As i am new to golang i am not even able to decide if it is possible at all.

Here is my code so far

package main

import (
    "fmt"

    "golang.org/x/crypto/ssh"
)

type SSHClient struct {
    Config *ssh.ClientConfig
    Host   string
    Port   int
}

func main() {
    sshConfig := &ssh.ClientConfig{
        User: "your_user_name",
        Auth: []ssh.AuthMethod{
            ssh.Password("your_password"),
        },
    }

    client := &SSHClient{
        Config: sshConfig,
        Host:   "example.com",
        Port:   22,
    }

    client.test()
    _, err := ssh.Dial("tcp", "example.com:22", sshConfig)
    if err != nil {
        fmt.Printf("Failed to dial: %s", err)
    }

}

func (client *SSHClient) test() {
    fmt.Println("test")
}
  • 写回答

1条回答

  • 普通网友 2016-02-17 07:49
    关注

    As a quick hack you can open $GOPATH/golang.org/x/crypto/ssh/mux.go file, change const debugMux = false to const debugMux = true and recompile your program.

    In order to see the debug logging make your program do something first:

    s, err := c.NewSession()
    if err != nil {
        fmt.Printf("Failed to create session: %s", err)
    }
    fmt.Println(s.CombinedOutput("hostname"))
    
    评论

报告相同问题?

悬赏问题

  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥15 如何修改pca中的feature函数
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况