백엔드 개발 Golang Gin 프레임워크에서의 세션 관리 및 적용

Gin 프레임워크에서의 세션 관리 및 적용

Jun 22, 2023 pm 12:38 PM
애플리케이션 세션 관리 진프레임워크

Gin 프레임워크는 Go 언어를 사용하여 개발된 경량 웹 프레임워크로 효율성, 사용 용이성, 유연성 및 기타 장점이 있습니다. 웹 애플리케이션 개발에서 세션 관리는 사용자 정보 저장, 사용자 신원 확인, CSRF 공격 방지 등에 사용될 수 있는 매우 중요한 주제입니다. 이 기사에서는 세션 관리 메커니즘과 Gin 프레임워크에서의 적용을 소개합니다.

1. 세션 관리 메커니즘

Gin 프레임워크에서 세션 관리는 미들웨어를 통해 구현됩니다. Gin 프레임워크는 세션 관리에 필요한 작업을 캡슐화하는 세션 패키지를 제공합니다. 세션 패키지를 사용하기 전에 먼저 터미널에 다음 명령을 입력해야 합니다.

go get github.com/gin-contrib/sessions
로그인 후 복사

세션 패키지는 쿠키, 메모리 저장소, 파일 저장소, Redis 저장소의 네 가지 세션 관리 방법을 제공합니다. 그 중 메모리 저장소와 파일 저장소가 기본이며, Redis 저장소에는 redis-go-driver 패키지를 설치하고 코드로 가져와야 합니다. 다음은 Cookie 메소드를 예로 들어 세션 관리 구현을 소개합니다.

  1. 세션 미들웨어 생성
package main

import (
    "github.com/gin-contrib/sessions"
    "github.com/gin-contrib/sessions/cookie"
    "github.com/gin-gonic/gin"
)

func main() {
    router := gin.Default()

    // 设置会话中间件
    store := cookie.NewStore([]byte("secret"))
    router.Use(sessions.Sessions("mysession", store))

    router.GET("/set", setHandler)
    router.GET("/get", getHandler)

    router.Run(":8080")
}

func setHandler(c *gin.Context) {
    session := sessions.Default(c)
    session.Set("user", "John")
    session.Save()
    c.String(200, "Session saved.")
}

func getHandler(c *gin.Context) {
    session := sessions.Default(c)
    user := session.Get("user")
    c.String(200, "User is %v.", user)
}
로그인 후 복사

위 코드에서는 쿠키 저장소에 세션 미들웨어를 생성하고 이를 Gin 엔진에 바인딩합니다. 그 중 첫 번째 매개변수 "mysession"은 세션 이름을 나타내고, 두 번째 매개변수 []byte("secret")는 쿠키의 값을 암호화하는 데 사용되는 키입니다. setHandler에서는 session.Set() 메서드를 사용하여 키-값 쌍을 설정한 다음 session.Save() 메서드를 호출하여 세션을 저장합니다. getHandler에서는 session.Get() 메서드를 사용하여 사용자 정보를 얻고 이를 응답으로 출력합니다.

  1. 테스트 세션 관리

서비스를 시작하려면 터미널에 다음 명령어를 입력하세요.

go run main.go
로그인 후 복사

브라우저에 다음 주소를 입력하세요.

http://localhost:8080/set
로그인 후 복사

그런 다음 다시 입력하세요.

http://localhost:8080/get
로그인 후 복사

응답 정보를 확인할 수 있습니다.

User is John.
로그인 후 복사

설명 세션을 성공적으로 생성하고 사용자 정보를 저장했습니다.

2. 세션 관리 적용

웹 응용 프로그램에서 세션 관리는 일반적으로 다음 시나리오에서 사용됩니다.

  1. 사용자 인증

사용자 인증은 웹 응용 프로그램에서 가장 일반적인 시나리오 중 하나입니다. 사용자 로그인 여부, 사용자가 특정 리소스에 액세스할 수 있는지 여부. Gin 프레임워크에서는 세션에 사용자 정보를 저장하고 인증이 필요할 때마다 이를 확인할 수 있습니다. 간단한 사용자 인증 예시는 다음과 같습니다.

func authHandler(c *gin.Context) {
    session := sessions.Default(c)
    user := session.Get("user")
    if user == nil {
        c.Redirect(http.StatusFound, "/login")
        return
    }
    // 验证用户身份
    if user != "admin" {
        c.AbortWithStatus(http.StatusUnauthorized)
        return
    }
    c.String(200, "Hello, admin.")
}
로그인 후 복사

위 코드에서는 먼저 session.Get() 메서드를 사용하여 사용자 정보를 가져오고, 사용자가 로그인되어 있지 않은 경우 로그인 페이지로 리디렉션합니다. 사용자가 로그인한 경우 관리자인지 확인하십시오. 관리자라면 "Hello, admin."이 출력되고, 그렇지 않으면 401 Unauthorized가 반환됩니다.

  1. CSRF 공격 방지

교차 사이트 요청 위조(CSRF)는 공격 목적을 달성하기 위해 브라우저의 쿠키 메커니즘을 사용하여 요청을 위조합니다. Gin 프레임워크에서는 세션을 사용하여 CSRF 공격을 방지할 수 있습니다. 특히, 각 양식 제출 시 양식에 csrf_token 필드를 추가한 다음 해당 필드를 세션에 저장합니다. 후속 요청마다 토큰이 세션에 저장된 내용과 일치하는지 확인할 수 있습니다. 다음은 간단한 CSRF 방어 예시입니다.

func csrfHandler(c *gin.Context) {
    session := sessions.Default(c)
    token := session.Get("csrf_token")
    if token == nil || token != c.PostForm("csrf_token") {
        c.AbortWithStatus(http.StatusBadRequest)
        return
    }
    // 处理表单提交
    c.String(200, "Form submitted.")
}

func formHandler(c *gin.Context) {
    session := sessions.Default(c)
    token := uuid.New().String()
    session.Set("csrf_token", token)
    session.Save()
    c.HTML(http.StatusOK, "form.html", gin.H{
        "csrf_token": token,
    })
}
로그인 후 복사

위 코드에서는 먼저 양식의 csrf_token 값과 세션에 저장된 토큰 값을 비교합니다. 일치하지 않는 경우 400 잘못된 요청 상태 코드가 반환됩니다. 일치하면 양식 제출이 처리되고 "양식 제출"이 출력됩니다. 양식이 로드되면 uuid 패키지를 사용하여 고유한 토큰 값을 생성한 다음 해당 값을 세션에 저장하고 마지막으로 양식 페이지를 사용자에게 반환합니다.

3. 요약

이 글에서는 Gin 프레임워크에서의 세션 관리 메커니즘과 그 적용을 소개했습니다. 세션 관리는 웹 애플리케이션 개발에서 중요한 주제이며, 사용자 정보 저장, 사용자 신원 확인, CSRF 공격 방지 등에 사용될 수 있습니다. Gin 프레임워크에서는 미들웨어를 사용하여 세션 관리를 구현할 수 있으며 세션 패키지는 편리한 작업 인터페이스를 제공합니다. 실제 응용 프로그램에서는 인증, 권한 부여, 암호화, 로깅 등과 같은 다른 기능 모듈을 결합하여 보다 완전한 웹 응용 프로그램 시스템을 구축할 수도 있습니다.

위 내용은 Gin 프레임워크에서의 세션 관리 및 적용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

iPhone 홈 화면에서 삭제를 취소하는 방법 iPhone 홈 화면에서 삭제를 취소하는 방법 Apr 17, 2024 pm 07:37 PM

홈 화면에서 중요한 항목을 삭제하고 다시 복구하려고 하시나요? 다양한 방법으로 앱 아이콘을 화면에 다시 표시할 수 있습니다. 우리는 당신이 따라갈 수 있는 모든 방법과 홈 화면에 앱 아이콘을 다시 넣을 수 있는 방법에 대해 논의했습니다. 방법 1 - 앱 라이브러리에서 앱 아이콘 바꾸기 앱 라이브러리에서 직접 홈 화면에 앱 아이콘을 배치할 수 있습니다. 1단계 – 옆으로 스와이프하여 앱 라이브러리의 모든 앱을 찾습니다. 2단계 – 이전에 삭제한 앱 아이콘을 찾습니다. 3단계 – 메인 라이브러리의 앱 아이콘을 홈 화면의 올바른 위치로 드래그하기만 하면 됩니다. 이것은 응용 다이어그램입니다

PHP에서 화살표 기호의 역할과 실제 적용 PHP에서 화살표 기호의 역할과 실제 적용 Mar 22, 2024 am 11:30 AM

PHP에서 화살표 기호의 역할과 실제 적용 PHP에서 화살표 기호(->)는 일반적으로 객체의 속성과 메서드에 액세스하는 데 사용됩니다. 객체는 PHP의 객체지향 프로그래밍(OOP)의 기본 개념 중 하나입니다. 실제 개발에서는 객체를 조작할 때 화살표 기호가 중요한 역할을 합니다. 이 기사에서는 화살표 기호의 역할과 실제 적용을 소개하고 독자의 이해를 돕기 위해 구체적인 코드 예제를 제공합니다. 1. 객체의 속성에 접근하기 위한 화살표 기호의 역할 화살표 기호를 사용하여 객체의 속성에 접근할 수 있습니다. 쌍을 인스턴스화할 때

초보자부터 숙련자까지: Linux tee 명령의 다양한 응용 시나리오 탐색 초보자부터 숙련자까지: Linux tee 명령의 다양한 응용 시나리오 탐색 Mar 20, 2024 am 10:00 AM

Linuxtee 명령은 기존 출력에 영향을 주지 않고 출력을 파일에 쓰거나 출력을 다른 명령으로 보낼 수 있는 매우 유용한 명령줄 도구입니다. 이 기사에서는 초보자부터 숙련자까지 Linuxtee 명령의 다양한 애플리케이션 시나리오를 심층적으로 살펴보겠습니다. 1. 기본 사용법 먼저 tee 명령어의 기본 사용법을 살펴보겠습니다. tee 명령의 구문은 다음과 같습니다: tee[OPTION]...[FILE]...이 명령은 표준 입력에서 데이터를 읽고 데이터를 다음 위치에 저장합니다.

Go 언어의 장점과 적용 시나리오를 살펴보세요. Go 언어의 장점과 적용 시나리오를 살펴보세요. Mar 27, 2024 pm 03:48 PM

Go 언어는 Google이 개발하여 2007년에 처음 출시된 오픈 소스 프로그래밍 언어입니다. 간단하고 배우기 쉽고 효율적이며 동시성이 높은 언어로 설계되었으며 점점 더 많은 개발자가 선호합니다. 이 기사에서는 Go 언어의 장점을 살펴보고 Go 언어에 적합한 몇 가지 애플리케이션 시나리오를 소개하며 구체적인 코드 예제를 제공합니다. 장점: 강력한 동시성: Go 언어에는 동시 프로그래밍을 쉽게 구현할 수 있는 경량 스레드 고루틴에 대한 지원이 내장되어 있습니다. Goroutin은 go 키워드를 사용하여 시작할 수 있습니다.

PHP는 새로운 세션을 시작하거나 기존 세션을 재개합니다 PHP는 새로운 세션을 시작하거나 기존 세션을 재개합니다 Mar 21, 2024 am 10:26 AM

이 기사에서는 PHP에서 새 세션을 시작하거나 기존 세션을 복원하는 방법에 대해 자세히 설명합니다. 편집자는 이것이 매우 실용적이라고 생각하므로 이 기사를 읽고 뭔가를 얻을 수 있기를 바랍니다. PHP 세션 관리: 새 세션 시작 또는 기존 세션 재개 소개 세션 관리는 PHP에서 매우 중요합니다. 이를 통해 사용자 세션 중에 사용자 데이터를 저장하고 액세스할 수 있습니다. 이 문서에서는 PHP에서 새 세션을 시작하거나 기존 세션을 재개하는 방법을 자세히 설명합니다. 새 세션 시작 session_start() 함수는 세션이 존재하는지 확인하고, 존재하지 않으면 새 세션을 생성합니다. 세션 데이터를 읽고 변환할 수도 있습니다.

클라우드 컴퓨팅 분야에서 Linux의 광범위한 적용 클라우드 컴퓨팅 분야에서 Linux의 광범위한 적용 Mar 20, 2024 pm 04:51 PM

클라우드 컴퓨팅 분야에서 Linux의 광범위한 적용 클라우드 컴퓨팅 기술의 지속적인 개발 및 대중화와 함께 Linux는 오픈 소스 운영 체제로서 클라우드 컴퓨팅 분야에서 중요한 역할을 담당합니다. 안정성, 보안성 및 유연성으로 인해 Linux 시스템은 다양한 클라우드 컴퓨팅 플랫폼 및 서비스에서 널리 사용되며 클라우드 컴퓨팅 기술 개발을 위한 견고한 기반을 제공합니다. 이 기사에서는 클라우드 컴퓨팅 분야에서 Linux의 광범위한 애플리케이션을 소개하고 구체적인 코드 예제를 제공합니다. 1. 클라우드 컴퓨팅 플랫폼에서 리눅스의 애플리케이션 가상화 기술 가상화 기술

MySQL 타임스탬프 이해: 기능, 특징 및 애플리케이션 시나리오 MySQL 타임스탬프 이해: 기능, 특징 및 애플리케이션 시나리오 Mar 15, 2024 pm 04:36 PM

MySQL 타임스탬프는 날짜, 시간 또는 날짜와 시간을 저장할 수 있는 매우 중요한 데이터 유형입니다. 실제 개발 과정에서 타임스탬프를 합리적으로 사용하면 데이터베이스 운영 효율성을 높이고 시간 관련 쿼리 및 계산을 용이하게 할 수 있습니다. 이 기사에서는 MySQL 타임스탬프의 기능, 특징 및 애플리케이션 시나리오를 논의하고 특정 코드 예제를 통해 설명합니다. 1. MySQL 타임스탬프의 기능 및 특징 MySQL에는 두 가지 유형의 타임스탬프가 있는데, 하나는 TIMESTAMP입니다.

Apple이 실행 중인 앱을 종료하는 방법에 대한 튜토리얼 Apple이 실행 중인 앱을 종료하는 방법에 대한 튜토리얼 Mar 22, 2024 pm 10:00 PM

1. 먼저 작은 흰색 점을 클릭합니다. 2. 장치를 클릭하세요. 3. 더보기를 클릭하세요. 4. 애플리케이션 전환기를 클릭합니다. 5. 애플리케이션 배경을 닫으면 됩니다.

See all articles