>백엔드 개발 >Golang >Httprouter를 사용하여 Negroni에서 경로별 인증을 구현하는 방법은 무엇입니까?

Httprouter를 사용하여 Negroni에서 경로별 인증을 구현하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-24 08:39:42460검색

How to Implement Route-Specific Authentication in Negroni with Httprouter?

Httprouter를 사용하는 Negroni의 경로별 인증

웹 애플리케이션에서 사용자 인증을 구현할 때 인증 요구에서 특정 경로를 면제해야 하는 경우가 많습니다. 이 기사에서는 Httprouter와 함께 Negroni를 사용하여 경로별 인증을 달성하는 방법을 살펴봅니다.

문제 설명

웹 서버는 Httprouter 및 Negroni를 활용하며 사용자 인증은 OAuth에서 처리됩니다. 토큰은 암호화된 세션에 저장되며 미들웨어를 사용하여 토큰의 존재를 확인합니다. 그러나 로그인 페이지와 같은 일부 경로는 이 인증 미들웨어를 우회해야 합니다. 문제는 확장성을 저하시키지 않으면서 미들웨어에서 특정 경로를 제외하는 것입니다.

솔루션

경로별 미들웨어를 생성하려면 각 경로에 대해 별도의 Negroni 인스턴스를 생성하는 것이 핵심입니다. 노선. 이를 통해 각 엔드포인트에 적용되는 미들웨어를 세부적으로 제어할 수 있습니다.

예를 들어 다음 코드 조각을 고려하세요.

router := httprouter.New()
router.Handler("GET", "/login",
               negroni.New(negroni.HandlerFunc(loginHandler)))
router.Handler("GET", "/",
               negroni.New(authenticator.Get(),
               negroni.HandlerFunc(indexHandler)))

server := negroni.Classic()
server.UseHandler(router)
server.Use(sessions.Sessions("example-web-dev",
           cookiestore.New([]byte("some secret"))))
server.Run(":3000")

이 예에서 /login은 인증 미들웨어인 반면 /는 세션과 인증 미들웨어를 모두 적용합니다. 여러 Negroni 인스턴스를 활용하면 경로별 인증을 효과적이고 확장 가능하게 달성할 수 있습니다.

위 내용은 Httprouter를 사용하여 Negroni에서 경로별 인증을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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