1 Star 0 Fork 0

Arohat/google-cloud-go

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
debug.go 1.62 KB
一键复制 编辑 原始数据 按行查看 历史
// Copyright 2018 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package proxy
import (
"bytes"
"fmt"
"log"
"net/http"
)
// Useful things for when we need to figure out what's actually going on under the hood.
type debugTransport struct {
prefix string
t *http.Transport
}
func (d debugTransport) RoundTrip(req *http.Request) (*http.Response, error) {
log.Printf("proxy %s: %s %s", d.prefix, req.Method, req.URL)
logHeaders(req.Header)
res, err := d.t.RoundTrip(req)
if err != nil {
log.Printf("proxy %s: error %v", d.prefix, err)
} else {
log.Printf("proxy %s: %s", d.prefix, res.Status)
log.Printf("Uncompressed = %v", res.Uncompressed)
log.Printf("ContentLength = %d", res.ContentLength)
logHeaders(res.Header)
log.Printf("Trailers:")
logHeaders(res.Trailer)
}
return res, err
}
func logHeaders(hs http.Header) {
for k, v := range hs {
log.Printf(" %s: %s", k, v)
}
}
func (r *requestBody) String() string {
buf := &bytes.Buffer{}
fmt.Fprintf(buf, "media type: %q\n", r.mediaType)
for i, p := range r.parts {
fmt.Fprintf(buf, "part #%d: %q\n", i, string(p))
}
return buf.String()
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/arohat/google-cloud-go.git
git@gitee.com:arohat/google-cloud-go.git
arohat
google-cloud-go
google-cloud-go
v0.34.0

搜索帮助