Ssh login go
Jump to navigation
Jump to search
package main
import (
"bytes"
"fmt"
"log"
"golang.org/x/crypto/ssh"
)
func main() {
config := &ssh.ClientConfig{
User: "username",
Auth: []ssh.AuthMethod{
ssh.Password("password"),
},
HostKeyCallback: ssh.InsecureIgnoreHostKey(),
}
client, err := ssh.Dial("tcp", "myserver:22", config)
if err != nil {
log.Fatal("Failed to dial: ", err)
}
// Each ClientConn can support multiple interactive sessions,
// represented by a Session.
session, err := client.NewSession()
if err != nil {
log.Fatal("Failed to create session: ", err)
}
defer session.Close()
// Once a Session is created, you can execute a single command on
// the remote side using the Run method.
var b bytes.Buffer
session.Stdout = &b
if err := session.Run("/bin/hostname"); err != nil {
log.Fatal("Failed to run: " + err.Error())
}
fmt.Println(b.String())
}
package main
import (
"fmt"
"golang.org/x/crypto/ssh"
"golang.org/x/crypto/ssh/knownhosts"
)
func main() {
host := "<hostname>:<port>"
user := "<username>"
pwd := "<password>"
pKey := []byte("<privateKey>")
var err error
var signer ssh.Signer
signer, err = ssh.ParsePrivateKey(pKey)
if err != nil {
fmt.Println(err.Error())
}
var hostkeyCallback ssh.HostKeyCallback
hostkeyCallback, err = knownhosts.New("~/.ssh/known_hosts")
if err != nil {
fmt.Println(err.Error())
}
conf := &ssh.ClientConfig{
User: user,
HostKeyCallback: hostkeyCallback,
Auth: []ssh.AuthMethod{
ssh.Password(pwd),
ssh.PublicKeys(signer),
},
}
}