go 语言实现http请求转发

本文介绍了一个使用Go语言实现的简单代理服务器程序。该程序通过监听指定端口接收客户端请求,并将其转发到目标服务器,同时处理HTTP请求头部信息。文章提供了完整的源代码,展示了如何建立socket连接、处理数据转发及日志记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package main

import (
	"bytes"
	"fmt"
	"log"
	"net"
	"os"
	"strconv"
	"strings"
	"time"

	"../../RequestCenter"
)

func main() {
	var srcHost, agencyHost string
	flag.StringVar(&srcHost, "srcHost", "", "srcHost")
	flag.StringVar(&agencyHost, "agencyHost", "", "agencyHost")
	flag.Parse()
	if srcHost == "" || agencyHost == "" {
		fmt.Fprintf(os.Stderr, "Fatal error: %s", "参数为空")
		os.Exit(1)
	}
	Log("已成功将" + srcHost + "代理到" + agencyHost)
	//建立socket,监听端口
	netListen, err := net.Listen("tcp", srcHost)
	CheckError(err)
	Log("Waiting for clients")

	defer netListen.Close()
	for {
		conn, err := netListen.Accept()
		//如果没有请求就一直等待
		if err == nil {
			Log(conn.RemoteAddr().String(), " tcp connect success ", conn.LocalAddr())
			chanmsg := make(chan int)
			go handleConnection(conn, agencyHost, chanmsg)
			if <-chanmsg == 1 {
				conn.Close()
				//Log("链接被关闭!")
			}
		}
	}
}

//处理连接
func handleConnection(conn net.Conn, agencyHost string, chanmsg chan int) {
	var baseReq = RequestCenter.CreateRequestWithConn(conn)
	buffer := baseReq.ReceiveData(5000)
	if len(buffer) > 1 {
		arr := strings.Split(string(buffer), "\r\n")
		if len(arr) > 1 {
			arr[1] = "Host: " + agencyHost
			newstr := strings.Join(arr, "\r\n")
			Log(newstr)
			SendAgencyHost([]byte(newstr), baseReq, agencyHost)
		}
	}
	chanmsg <- 1
}
func SendAgencyHost(data []byte, baseconn *RequestCenter.QRequest, agencyHost string) {
	var agencyReq = RequestCenter.CreateRequest("tcp", agencyHost)
	agencyReq.SendData(nil, data)
	var buf bytes.Buffer

	bufferHead := agencyReq.ReceiveData(5000)
	if len(bufferHead) > 0 {
		buf.Write(bufferHead)
	}
	time.Sleep(10 * time.Millisecond)
	bufferBody := agencyReq.ReceiveData(5000)
	if len(bufferBody) > 0 {
		buf.Write(bufferBody)
	}
	Log(strconv.Itoa(buf.Len()))
	Log(string(buf.Bytes()))
	baseconn.SendData(nil, buf.Bytes())
	agencyReq.Close()
}

//打印信息统一方法
func Log(v ...interface{}) {
	log.Println(v...)
}

//执行错误处理方法
func CheckError(err error) {
	if err != nil {
		fmt.Fprintf(os.Stderr, "Fatal error: %s", err.Error())
		os.Exit(1)
	}
}

 

转载于:https://my.oschina.net/u/252343/blog/828034

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值