加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

如何在使用golang http包时限制客户端IP地址

发布时间:2020-12-16 09:22:17 所属栏目:大数据 来源:网络整理
导读:我正在使用golang http包.服务器如何限制客户端IP地址? func (s *Worker) Run(c chan error) { apiMux := http.NewServeMux() apiMux.HandleFunc("/test",s.test) apiMux.HandleFunc("/block/create",s.CreateBlock) apiMux.HandleFunc("/block/delete",s.D
我正在使用golang http包.服务器如何限制客户端IP地址?

func (s *Worker) Run(c chan error) {
    apiMux := http.NewServeMux()
    apiMux.HandleFunc("/test",s.test)
    apiMux.HandleFunc("/block/create",s.CreateBlock)
    apiMux.HandleFunc("/block/delete",s.DeleteBlock)

    apiServer := &http.Server{
        Addr:    "0.0.0.0:" + strconv.Itoa(s.ListenPort),Handler: apiMux,}

    go func() {
        log.Println("Worker listening on " + apiServer.Addr)
        c <- apiServer.ListenAndServe()
    }()
}

解决方法

您需要做两件事:一个是使用中间件处理程序包装您的多路复用器,该处理程序预处理您的请求并验证IP.另一个是获取用户的真实IP,如果您位于防火墙或负载均衡器后面(导致地址始终是LB的地址),或者如果您的用户位于代理后面,这一点非常重要.

至于包装你的多路复用器,它很简单:

apiServer := &http.Server{
    Addr:    "0.0.0.0:8080",Handler: http.HandlerFunc( func(w http.ResponseWriter,req *http.Request) {
        // get the real IP of the user,see below
        addr := getRealAddr(req)

       // the actual vaildation - replace with whatever you want
       if (addr != "1.2.3.4") {
            http.Error(w,"Blocked",401)
            return
        }
        // pass the request to the mux
        apiMux.ServeHTTP(w,req)
    }),}

我正在附加getRealAddr函数,该函数来自我做过类似事情的实际项目:

func getRealAddr(r *http.Request)  string {

    remoteIP := ""
    // the default is the originating ip. but we try to find better options because this is almost
    // never the right IP
    if parts := strings.Split(r.RemoteAddr,":"); len(parts) == 2 {
        remoteIP = parts[0]
    }
    // If we have a forwarded-for header,take the address from there
    if xff := strings.Trim(r.Header.Get("X-Forwarded-For"),","); len(xff) > 0 {
        addrs := strings.Split(xff,")
        lastFwd := addrs[len(addrs)-1]
        if ip := net.ParseIP(lastFwd); ip != nil {
            remoteIP = ip.String()
        }
    // parse X-Real-Ip header
    } else if xri := r.Header.Get("X-Real-Ip"); len(xri) > 0 {
        if ip := net.ParseIP(xri); ip != nil {
            remoteIP = ip.String()
        }
    }

    return remoteIP

}

至于过滤,它可以基于一组ips或CIDR范围,当然,这取决于你.

如果您有兴趣,上面的代码来自我编写的一个API构建工具包,名为Vertex,它内置了这个:https://github.com/EverythingMe/vertex

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读