>  기사  >  백엔드 개발  >  골랭 쿠키 요청

골랭 쿠키 요청

王林
王林원래의
2023-05-21 18:42:08725검색

Golang에서 HTTP 요청을 할 때는 일반적으로 쿠키와 같은 인증 정보를 사용해야 하며, 쿠키도 얻어야 합니다. 이 기사에서는 Golang을 사용하여 쿠키로 HTTP 요청을 시작하고 이후 사용을 위해 쿠키를 변수에 저장하는 방법을 소개합니다.

HTTP 및 쿠키 소개

HTTP(Hypertext Transfer Protocol)는 클라이언트와 서버 간의 데이터 전송을 가능하게 하는 프로토콜입니다. 클라이언트는 요청을 보내고 서버는 응답을 반환하고 요청된 리소스를 제공합니다. HTTP 요청에는 주로 다음 부분이 포함됩니다.

  • HTTP 메서드(GET, POST, PUT, DELETE 등)
  • URL
  • 요청 헤더(사용자 에이전트, 언어, 콘텐츠 유형 등을 포함한 요청 헤더 정보)
  • 요청 본문(선택 사항, POST 또는 PUT 방법에 적용 가능)

응답에는 일반적으로 다음 부분이 포함됩니다.

  • 상태 코드(예: 200 OK, 404 Not Found)
  • 응답 헤더(서버를 포함한 응답 헤더 정보) 유형, 시간, 콘텐츠 유형 등)
  • 응답 본문(응답 내용)

HTTP 헤더에는 쿠키가 포함될 수 있으며 쿠키는 일반적으로 인증, 사용자 정보 기억 등에 사용됩니다. 쿠키는 클라이언트의 브라우저에 저장되며 방문한 사이트에 대한 데이터를 포함합니다. HTTP 요청 시 본인 확인이 필요한 경우, 일반적으로 쿠키를 통해 인증 정보를 전달해야 합니다.

Golang이 쿠키 요청을 시작합니다

Golang에서는 표준 라이브러리의 net/http 패키지를 사용하여 HTTP 요청을 시작할 수 있습니다. 요청 시 HTTP 헤더의 Cookie 필드를 설정하여 쿠키를 전달하거나 쿠키 패키지를 이용하여 쿠키를 편리하게 관리할 수 있습니다.

다음은 net/http 패키지를 사용하여 요청을 시작하고 쿠키를 가져오는 간단한 샘플 코드입니다.

package main

import (
    "fmt"
    "net/http"
)

func main() {
    // 创建请求客户端
    client := &http.Client{}

    // 创建请求
    req, err := http.NewRequest("GET", "https://example.com", nil)
    if err != nil {
        fmt.Println(err)
        return
    }

    // 发送请求并获取响应
    resp, err := client.Do(req)
    if err != nil {
        fmt.Println(err)
        return
    }
    defer resp.Body.Close()

    // 获取 Cookie
    cookies := resp.Cookies()
    for _, cookie := range cookies {
        fmt.Printf("%s: %s
", cookie.Name, cookie.Value)
    }
}

위 코드는 요청 클라이언트를 생성하고 NewRequest 메서드를 사용하여 GET 요청을 생성한 후 요청을 보냅니다. 응답을 얻으려면. 응답에는 쿠키 콘텐츠가 포함되어 있습니다. resp.Cookies() 메서드를 사용하여 쿠키 정보를 얻고 인쇄물을 반복합니다.

일반적으로 쿠키 정보를 전달하려면 요청 헤더에 Cookie 필드를 설정해야 합니다. 다음은 Cookie 필드를 설정하여 요청을 시작하는 예입니다.

package main

import (
    "fmt"
    "net/http"
)

func main() {
    // 创建请求
    req, err := http.NewRequest("GET", "https://example.com", nil)
    if err != nil {
        fmt.Println(err)
        return
    }

    // 设置 Cookie
    cookie := &http.Cookie{Name: "name", Value: "value"}
    req.AddCookie(cookie)

    // 发起请求并获取响应
    client := &http.Client{}
    resp, err := client.Do(req)
    if err != nil {
        fmt.Println(err)
        return
    }
    defer resp.Body.Close()

    // 获取响应内容
    fmt.Println(resp.Status)
}

위 코드는 GET 요청을 생성하고 req.AddCookie를 전달합니다. (쿠키) 이 메서드는 쿠키를 설정한 다음 net/http 패키지의 client.Do(req) 메서드를 사용하여 요청을 시작하고 응답을 얻고 응답 상태 코드를 출력합니다.

Cookies 패키지

Cookie 필드 및 resp.Cookies() 메서드 설정 외에도 쿠키 패키지를 사용하여 쿠키를 편리하게 관리하고 처리할 수 있습니다. 패키지는 다음 두 가지 구조를 제공합니다.

  • Cookie: HTTP 쿠키를 나타냅니다.
  • Jar: 쿠키 컬렉션을 나타냅니다.

다음은 쿠키 패키지를 사용하여 쿠키를 관리하는 예입니다.

package main

import (
    "fmt"
    "net/http"
    "net/http/cookiejar"
)

func main() {
    // 创建 Cookie 集合
    jar, err := cookiejar.New(nil)
    if err != nil {
        fmt.Println(err)
        return
    }

    // 创建请求客户端
    client := &http.Client{
        Jar: jar,
    }

    // 创建请求
    req, err := http.NewRequest("GET", "https://example.com", nil)
    if err != nil {
        fmt.Println(err)
        return
    }

    // 发送请求并获取响应
    resp, err := client.Do(req)
    if err != nil {
        fmt.Println(err)
        return
    }
    defer resp.Body.Close()

    // 打印 Cookie
    cookies := jar.Cookies(req.URL)
    for _, cookie := range cookies {
        fmt.Printf("%s: %s
", cookie.Name, cookie.Value)
    }
}

위 코드는 cookiejar 패키지를 사용하여 CookieJar를 생성하고 이를 요청 클라이언트에 전달한 다음 URL을 통해 쿠키를 가져와 출력을 인쇄합니다.

결론

이 글에서는 Golang을 사용하여 쿠키로 HTTP 요청을 시작하는 방법을 소개합니다. 위의 방법 외에도 GoRequest, gin 프레임워크 등과 같은 타사 라이브러리를 사용할 수도 있지만 여기서는 소개하지 않습니다. 실제 사용에서는 특정 상황에 따라 가장 적합한 방법을 선택해야 합니다.

위 내용은 골랭 쿠키 요청의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.