欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Go语言利用ssh连接服务器的方法步骤

程序员文章站 2022-03-17 23:09:30
学习了go语言后,打算利用最近比较空一点,写一个前端部署工具,不需要每次都复制粘贴的麻烦,需要完成部署的第一步就需要连接远程服务器打开 ssh server首先我们想要利用ssh连接服务器的前提是服务...

学习了go语言后,打算利用最近比较空一点,写一个前端部署工具,不需要每次都复制粘贴的麻烦,需要完成部署的第一步就需要连接远程服务器

打开 ssh server

首先我们想要利用ssh连接服务器的前提是服务器打开了ssh server,ssh 分为client和server端 ,如果打开了client可以连接远程服务器,打开了server就可以被连接.

因为linux网上教程很多,windows比较少,所以这里只写windows版本的,

首先我们一般用open ssh这个工具打开服务,windows系统是自带 open ssh client 这个服务的, 如果我们需要打开open server,

  • 直接 win + i打开 windows设置
  • 打开应用
  • 应用和功能里面有一项管理可选功能,打开

Go语言利用ssh连接服务器的方法步骤

发现客户端(client)已经安装了,这时候我们开打添加功能,安装openssh 服务端

安装完成, 打开openssh设置自动启动

Go语言利用ssh连接服务器的方法步骤

最后一步,测试一下是否openssh server已经打开, 打开命令行 输入 用户名(电脑的用户名)@ip(本机的ip地址),再输入密码就可以看到连接成功了

尝试通过ssh连接本机

Go语言利用ssh连接服务器的方法步骤

连接成功

Go语言利用ssh连接服务器的方法步骤

go语言连接ssh

连接ssh的主要用的就是 golang.org/x/crypto/ssh这个包, 利用github.com/pkg/sftp来进行文件传输和远程文件操作,下面的代码都有详细注释直接看注释就好了

ps: ssh这个包 直接用go get可能会下不下来,需要手动下载

package connect

import (
	"fmt"
	"github.com/pkg/sftp"
	"golang.org/x/crypto/ssh"
	"net"
	"time"
)

func connect(user, password, host string, port int) (*sftp.client, error) {
	var (
		auth   []ssh.authmethod
		addr   string
		clientconfig *ssh.clientconfig
		sshclient *ssh.client
		sftpclient *sftp.client
		err   error
	)
	// 将密码穿到验证方法切片里
	auth = make([]ssh.authmethod, 0)
	auth = append(auth, ssh.password(password))
	//配置项
	clientconfig = &ssh.clientconfig{
		user: user,
		auth: auth,
		timeout: 30 * time.second,
         //这各参数是验证服务端的,返回nil可以不做验证,如果不设置会报错
		hostkeycallback: func(hostname string, remote net.addr, key ssh.publickey) error {
			return nil
		},
	}
	//连接ip和端口
	addr = fmt.sprintf("%s:%d", host, port) 
	//通过tcp协议,连接ssh
	if sshclient, err = ssh.dial("tcp", addr, clientconfig); err != nil {
		return nil, err
	}

	//创建sftp服务对象
	if sftpclient, err = sftp.newclient(sshclient); err != nil {
		return nil, err
	}
	//返回sftp服务对象
	return sftpclient, nil
}

连接ssh的方法已经封装好了,需要使用直接调用就行了

到此这篇关于go语言利用ssh连接服务器的方法步骤的文章就介绍到这了,更多相关go ssh连接服务器内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!