Go语言中获取tls中的KeyLogFile,用于dubug
创始人
2024-11-13 17:37:46
0

文章目录

    • 获取KeyLogFile
    • 示例代码:
      • 1. client
      • 2. client
      • 3. 效果

获取KeyLogFile

tls.config自带了接口,所以配置的时候只需要打开就行,以客户端为例
keylogfile 是一个 io.Writer 开了这个就自动使用了

keyLogFile, _ := os.OpenFile(keyLogFilePath, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0600)  // 2. 配置tls 打开了KeyLogWriter tlsConfig := &tls.Config{     InsecureSkipVerify: true,     KeyLogWriter:       keyLogFile, } 

示例代码:

1. client

package main  import ( 	"crypto/tls" 	"fmt" 	"log" 	"net" 	"os" )  const ( 	HOST           = "localhost" 	PORT           = "8443" 	KEYLOGFILEPATH = "E:\\Martin_Code\\Go\\src\\lesson-03-tls\\02-myTls\\keylogfile-clent.txt" )  func main() {  	if err := tlsWithKeyLog(HOST, KEYLOGFILEPATH); err != nil { 		log.Fatalf("tlsWithKeyLog error: %s \n", err) 		os.Exit(1) 	}  }  func tlsWithKeyLog(url, keyLogFilePath string) error { 	// 1. 创建一个文件 已有则覆盖了 	keyLogFile, _ := os.OpenFile(keyLogFilePath, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0600) 	fmt.Fprintf(keyLogFile, "# SSL/TLS secrets log file, generated by go\n")  	// 2. 配置tls 打开了KeyLogWriter 	tlsConfig := &tls.Config{ 		InsecureSkipVerify: true, 		KeyLogWriter:       keyLogFile, 	}  	// 建立tls连接 	conn, err := tls.Dial("tcp", net.JoinHostPort(HOST, PORT), tlsConfig) 	if err != nil { 		log.Fatalf("客户端Dial()失败:%s", err) 	} 	defer conn.Close()  	conn.Write([]byte("Hello world"))  	return nil }  

2. client

package main  import ( 	"crypto/tls" 	"fmt" 	"io" 	"log" 	"net" 	"os" )  const ( 	CERTFILEPATH   = "E:\\Martin_Code\\Go\\src\\lesson-03-tls\\02-myTls\\server.crt" 	KEYFILEPATH    = "E:\\Martin_Code\\Go\\src\\lesson-03-tls\\02-myTls\\server.key" 	KEYLOGFILEPATH = "E:\\Martin_Code\\Go\\src\\lesson-03-tls\\02-myTls\\keylogfile-server.txt" )  func handleConn(conn net.Conn) { 	log.Printf("服务器收到连接:%s", conn.RemoteAddr()) 	defer conn.Close()  	conn.Write([]byte("Hello, 这里是配置了TLS的服务器!\n"))  	for { 		buf := make([]byte, 1024) 		n, err := conn.Read(buf) 		if err != nil { 			if err == io.EOF { 				log.Println("客户端关闭连接") 			} else { 				log.Printf("服务器读取数据失败:%s", err) 			} 			return 		} 		fmt.Printf("服务器收到数据:%s\n", string(buf[:n])) 	} }  func main() { 	// 1. 服务器 加载证书和私钥 	cert, err := tls.LoadX509KeyPair(CERTFILEPATH, KEYFILEPATH) 	if err != nil { 		log.Fatalf("服务器加载证书失败:%s", err) 	} 	log.Println("服务器加载证书成功!")  	// 1.1 设置keylog文件 	keyLogFile, _ := os.OpenFile(KEYLOGFILEPATH, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0600) 	fmt.Fprintf(keyLogFile, "# SSL/TLS secrets log file, generated by go\n")  	// 2. 创建TLS配置,并指定证书和私钥 	config := &tls.Config{ 		Certificates: []tls.Certificate{cert}, 		KeyLogWriter: keyLogFile, 	} 	log.Println("服务器TLS配置创建成功!")  	// 3. 监听 	listen, err := tls.Listen("tcp", ":8443", config) 	if err != nil { 		log.Fatalf("服务器监听失败: %s", err) 	} 	log.Println("服务器监听成功!") 	defer listen.Close()  	// 4. 开启Accept 	for { 		conn, err := listen.Accept() 		if err != nil { 			log.Printf("服务器Accept()失败:%s", err) 			continue 		} 		// 5. 处理连接 		go handleConn(conn)  	} }  

3. 效果

在这里插入图片描述

相关内容

热门资讯

绝活儿辅助!广西老友玩老是输怎... 绝活儿辅助!广西老友玩老是输怎么办(辅助挂)都是真的有辅助app(讲解有挂)在进入广西老友玩老是输怎...
法门辅助!福建13水插件(辅助... 法门辅助!福建13水插件(辅助挂)一贯是有辅助技巧(有挂技术)1、许多玩家不知道福建13水插件辅助怎...
办法辅助!潮友会app下载官方... 办法辅助!潮友会app下载官方辅助器(辅助挂)真是真的是有辅助app(有挂教程)该软件可以轻松地帮助...
妙招辅助!邯郸胡乐挂辅助(辅助... 妙招辅助!邯郸胡乐挂辅助(辅助挂)好像存在有辅助插件(有挂方略)1、上手简单,内置详细流程视频教学,...
教程书辅助!乐酷辅助(辅助挂)... 教程书辅助!乐酷辅助(辅助挂)其实存在有辅助脚本(有挂细节)乐酷辅助能透视中分为三种模型:乐酷辅助模...
学习辅助!决战卡五星辅助(辅助... 学习辅助!决战卡五星辅助(辅助挂)本来真的是有辅助软件(有人有挂)学习辅助!决战卡五星辅助(辅助挂)...
绝活辅助!边锋嘉兴麻将辅助器(... 绝活辅助!边锋嘉兴麻将辅助器(辅助挂)真是真的有辅助神器(新版有挂)1、边锋嘉兴麻将辅助器公共底牌简...
举措辅助!枫叶辅助器(辅助挂)... 举措辅助!枫叶辅助器(辅助挂)本来存在有辅助技巧(竟然有挂)1、下载好枫叶辅助器正确养号方法之后点击...
讲义辅助!点我达辅助(辅助挂)... 讲义辅助!点我达辅助(辅助挂)一直存在有辅助技巧(有人有挂)1、点我达辅助辅助器安装包、点我达辅助辅...
模块辅助!威信茶馆有挂的吗(辅... 模块辅助!威信茶馆有挂的吗(辅助挂)一直真的是有辅助脚本(揭秘有挂)1、玩家可以在威信茶馆有挂的吗线...