PHP-Editor Xinyi nimmt Sie mit auf die Erkundung der hartnäckigen versteckten Dienste in Golang. Golang ist eine effiziente Programmiersprache, die für ihre hervorragende Leistung und Parallelität bekannt ist. In diesem schnelllebigen Zeitalter des Internets sind versteckte Dienste zu einem wichtigen Bestandteil vieler Anwendungen geworden. Sie bieten eine sichere und zuverlässige Möglichkeit, Anwendungen über einen längeren Zeitraum laufen zu lassen und gleichzeitig ihre internen Details zu verbergen. In diesem Artikel wird die Implementierung persistenter versteckter Dienste in Golang vorgestellt und die Anwendungsszenarien und Vorteile in praktischen Anwendungen untersucht. Egal, ob Sie Einsteiger oder erfahrener Entwickler sind, Sie erwerben nützliches Wissen und praktische Erfahrungen. Lassen Sie uns gemeinsam dieses interessante Thema erkunden!
Ich versuche, über github.com/cretz/bine/tor einen versteckten Dienst in Golang zu hosten. Aber jedes Mal, wenn ich das Programm starte, wird anstelle des vorherigen versteckten Dienstes ein neuer versteckter Dienst (mit einer neuen .onion-Adresse) gestartet.
Dies ist der Code, den ich verwende
package main import ( "context" "fmt" "github.com/cretz/bine/tor" "log" "net/http" "time" ) func main() { // Start tor with default config fmt.Println("Starting and registering onion service, please wait a couple of minutes...") t, err := tor.Start(nil, nil) if err != nil { log.Panicf("Unable to start Tor: %v", err) } defer t.Close() // Wait at most a few minutes to publish the service listenCtx, listenCancel := context.WithTimeout(context.Background(), 3*time.Minute) defer listenCancel() // Create a v3 onion service onion, err := t.Listen(listenCtx, &tor.ListenConf{Version3: true, RemotePorts: []int{80}}) if err != nil { log.Panicf("Unable to create onion service: %v", err) } defer onion.Close() fmt.Printf("Open Tor browser and navigate to http://%v.onion\n", onion.ID) fmt.Println("Press enter to exit") // Serve the current folder from HTTP errCh := make(chan error, 1) go func() { errCh <- http.Serve(onion, http.FileServer(http.Dir("."))) }() // End when enter is pressed go func() { fmt.Scanln() errCh <- nil }() if err = <-errCh; err != nil { log.Panicf("Failed serving: %v", err) } }
Ich habe versucht, das Programm zu zwingen, dasselbe DataDir zu verwenden
t, err := tor.Start(nil, &tor.StartConf{DataDir: "data-dir"})
Aber das funktioniert nicht.
Sie müssen einen Schlüssel erstellen und speichern und ihn dann an ListenConf übergeben:
Siehe: https://github.com/cretz/bine/blob/master/tor/listen.go#L56
Hinweis:
Die von Ihnen verwendete Bibliothek bietet hierfür Funktionen.
Mach das einmal und spare privateKeyString
:
keyPair, _ := ed25519.GenerateKey() privateKeyString := hex.EncodeToString(keyPair.PrivateKey())
Dann in Ihrem Servercode:
privateKeyBytes, _ := hex.DecodeString(privateKeyString) privateKey := ed25519.PrivateKey(privateKeyBytes) lc := &tor.ListenConf{ Key: privateKey, Version3: true, RemotePorts: []int{80} }
Das obige ist der detaillierte Inhalt vonAnhaltender versteckter Dienst in Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!