本文整理匯總了Golang中net/http.Request.Method方法的典型用法代碼示例。如果您正苦於以下問題:Golang Request.Method方法的具體用法?Golang Request.Method怎麽用?Golang Request.Method使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類net/http.Request
的用法示例。
在下文中一共展示了Request.Method方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: wouldMatch
func wouldMatch(router *mux.Router, rq *http.Request, method string) bool {
savedMethod := rq.Method
rq.Method = method
defer func() { rq.Method = savedMethod }()
var matchInfo mux.RouteMatch
return router.Match(rq, &matchInfo)
}
示例2: DownloadPlay
func (this *GoChromeCastHttpServer) DownloadPlay(c web.C, w http.ResponseWriter, r *http.Request) {
if params, err := utils.GetParams(r, "id", "file_path"); err != nil {
w.Header().Set("Content-Type", "application/json")
r := responses.JsonResponse{}
r.Method = "DownloadPlay"
r.Set(nil, err)
io.WriteString(w, utils.RenderResponse(r))
} else {
if sc, display_path, err := this.ds.DownloadPlay(params["id"], params["file_path"]); err != nil {
w.Header().Set("Content-Type", "application/json")
r := responses.JsonResponse{}
r.Method = "DownloadPlay"
r.Set(nil, err)
io.WriteString(w, utils.RenderResponse(r))
} else {
defer func() {
if err == nil {
sc.Close()
}
}()
w.Header().Set("Content-Disposition", "attachment; filename=\""+params["file_path"]+"\"")
http.ServeContent(w, r, display_path, time.Now(), sc)
}
}
}
示例3: main
func main() {
f, err := os.OpenFile("./file.exe", os.O_RDWR, 0666) //其實這裏的 O_RDWR應該是 O_RDWR|O_CREATE,也就是文件不存在的情況下就建一個空文件,但是因為windows下還有BUG,如果使用這個O_CREATE,就會直接清空文件,所以這裏就不用了這個標誌,你自己事先建立好文件。
if err != nil {
panic(err)
}
stat, err := f.Stat() //獲取文件狀態
if err != nil {
panic(err)
}
f.Seek(stat.Size(), 0) //把文件指針指到文件末,當然你說為何不直接用 O_APPEND 模式打開,沒錯是可以。我這裏隻是試驗。
url := "http://dl.google.com/chrome/install/696.57/chrome_installer.exe"
var req http.Request
req.Method = "GET"
//req.UserAgent = UA
req.Close = true
req.URL, err = http.ParseURL(url)
if err != nil {
panic(err)
}
header := http.Header{}
header.Set("Range", "bytes="+strconv.Itoa64(stat.Size)+"-")
req.Header = header
resp, err := http.DefaultClient.Do(&req)
if err != nil {
panic(err)
}
written, err := io.Copy(f, resp.Body)
if err != nil {
panic(err)
}
println("written: ", written)
}
示例4: authPut
// Put issues a PUT to the specified URL.
// Caller should close r.Body when done reading it.
func authPut(url_, user, pwd, client, clientURL, version, agent, bodyType string,
body io.Reader) (r *http.Response, err error) {
var req http.Request
req.Method = "PUT"
req.Body = body.(io.ReadCloser)
if user != "" && pwd != "" {
req.Header = map[string][]string{
"Content-Type": {bodyType},
"Transfer-Encoding": {"chunked"},
"User-Agent": {agent},
"X-Fluidinfo-Client": {client},
"X-Fluidinfo-Client-URL": {clientURL},
"X-Fluidinfo-Version": {version},
"Authorization": {"Basic " + encodedUsernameAndPassword(user, pwd)},
}
} else {
req.Header = map[string][]string{
"Content-Type": {bodyType},
"Transfer-Encoding": {"chunked"},
"User-Agent": {agent},
"X-Fluidinfo-Client": {client},
"X-Fluidinfo-Client-URL": {clientURL},
"X-Fluidinfo-Version": {version},
}
}
req.URL, err = url.Parse(url_)
if err != nil {
return nil, err
}
return send(&req)
}
示例5: ServeHTTP
// ServeHTTP servers the actual HTTP request by buidling a context and running
// it through all the handlers.
func (handler *HttpHandler) ServeHTTP(responseWriter http.ResponseWriter, request *http.Request) {
// override the method if needed
method := request.Header.Get("X-HTTP-Method-Override")
if method != "" {
request.Method = method
}
// make the context
ctx := webcontext.NewWebContext(responseWriter, request, handler.codecService)
// copy the data
for k, v := range handler.Data {
ctx.Data()[k] = v
}
// run it through the handlers
_, err := handler.Handlers.Handle(ctx)
// do we need to handle an error?
if err != nil {
// set the error
ctx.Data().Set(DataKeyForError, err)
// tell the handler to handle it
handler.ErrorHandler().Handle(ctx)
}
}
示例6: Translate
func Translate(from, to, s string) (t string, err error) {
var url_ = "http://ajax.googleapis.com/ajax/services/language/translate?v=1.0&format=text&q=" + url.QueryEscape(s) + "&langpair=" + url.QueryEscape(from) + "%7C" + url.QueryEscape(to)
var r *http.Response
if proxy := os.Getenv("HTTP_PROXY"); len(proxy) > 0 {
proxy_url, _ := url.Parse(proxy)
tcp, _ := net.Dial("tcp", proxy_url.Host)
conn := httputil.NewClientConn(tcp, nil)
var req http.Request
req.URL, _ = url.Parse(url_)
req.Method = "GET"
r, err = conn.Do(&req)
} else {
r, err = http.Get(url_)
}
if err == nil {
defer r.Body.Close()
if b, err := ioutil.ReadAll(r.Body); err == nil {
var r interface{}
if err = json.NewDecoder(bytes.NewBuffer(b)).Decode(&r); err == nil {
if r.(map[string]interface{})["responseStatus"].(float64) == 200 {
return r.(map[string]interface{})["responseData"].(map[string]interface{})["translatedText"].(string), nil
} else {
err = errors.New(r.(map[string]interface{})["responseDetails"].(string))
}
}
}
}
return "", err
}
示例7: getCodes
func getCodes() {
//並發寫文件必須要有鎖啊,怎麽還是串行程序的思維啊。
fileName := "./data/data.html"
f, err := os.Create(fileName) //其實這裏的 O_RDWR應該是 O_RDWR|O_CREATE,也就是文件不存在的情況下就建一個空文件,但是因為windows下還有BUG,如果使用這個O_CREATE,就會直接清空文件,所以這裏就不用了這個標誌,你自己事先建立好文件。
if err != nil {
panic(err)
}
defer f.Close()
urls := "http://quote.eastmoney.com/stocklist.html"
var req http.Request
req.Method = "GET"
req.Close = true
req.URL, err = url.Parse(urls)
if err != nil {
panic(err)
}
header := http.Header{}
header.Set("User-Agent", UA)
req.Header = header
resp, err := http.DefaultClient.Do(&req)
if err == nil {
if resp.StatusCode == 200 {
io.Copy(f, resp.Body)
} else {
fmt.Println("http get StatusCode")
}
defer resp.Body.Close()
} else {
fmt.Println("http get error")
}
}
示例8: Put
// Put returns *BeegoHttpRequest with PUT method.
func Put(url string) *BeegoHttpRequest {
var req http.Request
var resp http.Response
req.Method = "PUT"
req.Header = http.Header{}
return &BeegoHttpRequest{url, &req, map[string]string{}, map[string]string{}, defaultSetting, &resp, nil}
}
示例9: post
func post(url_ string, oauthHeaders map[string]string) (r *http.Response, err error) {
var req http.Request
req.Method = "POST"
req.ProtoMajor = 1
req.ProtoMinor = 1
req.Close = true
req.Header = map[string][]string{
"Authorization": {"OAuth "},
}
req.TransferEncoding = []string{"chunked"}
first := true
for k, v := range oauthHeaders {
if first {
first = false
} else {
req.Header["Authorization"][0] += ",\n "
}
req.Header["Authorization"][0] += k + "=\"" + v + "\""
}
req.URL, err = url.Parse(url_)
if err != nil {
return nil, err
}
return send(&req)
}
示例10: TestServeFile
func TestServeFile(t *testing.T) {
defer afterTest(t)
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
ServeFile(w, r, "testdata/file")
}))
defer ts.Close()
var err error
file, err := ioutil.ReadFile(testFile)
if err != nil {
t.Fatal("reading file:", err)
}
// set up the Request (re-used for all tests)
var req http.Request
req.Header = make(http.Header)
if req.URL, err = url.Parse(ts.URL); err != nil {
t.Fatal("ParseURL:", err)
}
req.Method = "GET"
// straight GET
_, body := getBody(t, "straight get", req)
if !bytes.Equal(body, file) {
t.Fatalf("body mismatch: got %q, want %q", body, file)
}
}
示例11: download
func download(dictId string, dictNum string, downUrl string) {
fileName := SAVEPATH + dictId + "-" + dictNum + ".scel"
f, err := os.OpenFile(fileName, os.O_RDWR|os.O_CREATE, 0666) //其實這裏的 O_RDWR應該是 O_RDWR|O_CREATE,也就是文件不存在的情況下就建一個空文件,但是因為windows下還有BUG,如果使用這個O_CREATE,就會直接清空文件,所以這裏就不用了這個標誌,你自己事先建立好文件。
if err != nil {
panic(err)
}
defer f.Close()
var req http.Request
req.Method = "GET"
req.Close = true
req.URL, _ = url.Parse(downUrl)
header := http.Header{}
header.Set("User-Agent", UA)
header.Set("Host", HOST)
header.Set("Referer", REFERER+dictId)
req.Header = header
resp, err := http.DefaultClient.Do(&req)
if err == nil {
if resp.StatusCode == 200 {
fmt.Println(dictId + ":sucess")
_, err = io.Copy(f, resp.Body)
if err != nil {
panic(err)
}
} else {
fmt.Println(dictId + ":" + strconv.Itoa(resp.StatusCode))
}
defer resp.Body.Close()
} else {
fmt.Println(dictId + ":error")
}
}
示例12: AllowMethods
func AllowMethods(w http.ResponseWriter, r *http.Request, methods ...string) bool {
r.Method = strings.ToUpper(r.Method)
addHead := false
for _, method := range methods {
if method == r.Method {
return true
}
if method == GET {
if r.Method == HEAD {
return true
}
addHead = true
}
}
allow := strings.Join(methods, ", ")
if addHead {
allow = "HEAD, " + allow
}
w.Header().Set(Allow, allow)
if r.Method == OPTIONS {
w.WriteHeader(http.StatusOK)
return false
}
msg := "requires one of: " + allow
http.Error(w, msg, http.StatusMethodNotAllowed)
return false
}
示例13: Delete
func Delete(url string) *HttpRequestBuilder {
var req http.Request
req.Method = "DELETE"
req.Header = http.Header{}
req.Header.Set("User-Agent", defaultUserAgent)
return &HttpRequestBuilder{url, &req, nil, map[string]string{}}
}
示例14: Head
// Head returns *BeegoHttpRequest with HEAD method.
func Head(url string) *BeegoHttpRequest {
var req http.Request
req.Method = "HEAD"
req.Header = http.Header{}
req.Header.Set("User-Agent", defaultUserAgent)
return &BeegoHttpRequest{url, &req, map[string]string{}, false, 60 * time.Second, 60 * time.Second, nil, nil, nil}
}
示例15: Proxy
func (p *WebsocketProxy) Proxy(w http.ResponseWriter, r *http.Request) {
hj, ok := w.(http.Hijacker)
if !ok {
log.Println("hijack assertion failed", r.Host, r.URL.Path)
p.handler.ServeHTTP(w, r) // last-ditch effort as plain http
return
}
conn, rw, err := hj.Hijack()
if err != nil {
log.Println("hijack failed", r.Host, r.URL.Path, err)
p.handler.ServeHTTP(w, r) // last-ditch effort as plain http
return
}
defer conn.Close()
rw.Flush()
wrapreq := new(http.Request)
wrapreq.Proto = "HTTP/1.1"
wrapreq.ProtoMajor, wrapreq.ProtoMinor = 1, 1
wrapreq.Method = "WEBSOCKET"
wrapreq.Host = r.Host
const dummy = "/"
wrapreq.URL = &url.URL{Path: dummy}
var buf bytes.Buffer
r.Write(&buf)
wrapreq.Body = ioutil.NopCloser(io.MultiReader(&buf, conn))
resp, err := p.transport.RoundTrip(wrapreq)
if err != nil || resp.StatusCode != 200 {
io.WriteString(conn, "HTTP/1.0 503 Gateway Failed\r\n")
io.WriteString(conn, "Connection: close\r\n\r\n")
return
}
defer resp.Body.Close()
io.Copy(conn, resp.Body)
}