summaryrefslogtreecommitdiff
path: root/main.go
blob: c4073516884605c156a51f4b74b9a13b61c17c7b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
package main

import (
	"fmt"
	"net"

	"github.com/gliderlabs/ssh"
	"github.com/magiconair/properties"
	gossh "golang.org/x/crypto/ssh"
)

func main() {

	// 解析 server.properties
	conf := properties.MustLoadFile("server.properties", properties.UTF8)
	SSH_SERVER := struct {
		Host string
		Port string
		User string
		Pass string
	}{
		Host: conf.MustGetString("server-ip"),
		Port: conf.MustGetString("server-port"),
		User: conf.MustGetString("term-user"),
		Pass: conf.MustGetString("term-pass"),
	}

	// 创建 ssh 服务器密钥
	privateKeySigner, err := gossh.ParsePrivateKey(privatePEM)
	if err != nil {
		panic(fmt.Errorf("不能解析私钥: %v", err))
	}

	// 在指定端口开启服务
	address := net.JoinHostPort(SSH_SERVER.Host, SSH_SERVER.Port)

	s := &ssh.Server{
		Addr:    address,
		Handler: shell,
		PasswordHandler: func(ctx ssh.Context, password string) bool {
			return ctx.User() == SSH_SERVER.User && password == SSH_SERVER.Pass
		},
	}
	s.AddHostKey(privateKeySigner)

	fmt.Println("Server Address:", address)
	if err := s.ListenAndServe(); err != nil {
		panic(fmt.Errorf("不能启动服务器: %v", err))
	}
}