웹 애플리케이션에서 사용자 인증을 구현할 때 인증 요구에서 특정 경로를 면제해야 하는 경우가 많습니다. 이 기사에서는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!