>백엔드 개발 >Golang >golang 오류 노출 경로

golang 오류 노출 경로

WBOY
WBOY원래의
2023-05-10 09:28:061051검색

Golang은 효율적이고 간결하며 안전한 프로그래밍 언어이지만 오류 처리 시 시스템 경로가 노출되기 쉽다는 단점도 있습니다. 이 문서에서는 이 문제를 설명하고 해결 방법을 제공합니다.

1. 문제 배경

Golang의 오류 처리 메커니즘은 매우 개발자 친화적입니다. 함수에서 오류를 반환해야 하는 경우 오류 유형의 변수를 직접 반환할 수 있습니다. 예:

func Divide(a, b int) (float64, error) {
    if b == 0 {
        return 0, fmt.Errorf("cannot divide by zero")
    }
    return float64(a) / float64(b), nil
}

이 함수를 사용할 때 오류 발생 여부를 확인하려면 오류 변수가 nil인지 여부만 확인하면 됩니다. 예:

result, err := Divide(10, 2)
if err != nil {
    fmt.Println(err)
    return
}
fmt.Println(result)

이 오류 처리 방법은 매우 간결하고 효율적이며 누구나 쉽게 사용할 수 있습니다. 그러나 오류 스택 정보에는 경로 정보가 포함되어 있어 프로그램 오류 발생 시 공격자는 오류 정보에서 시스템 경로 등 민감한 정보를 얻어 더욱 정밀한 공격을 수행할 수 있다.

2. 문제 분석

위의 예를 살펴보겠습니다.Divide(10, 0) 실행 시 오류 메시지는 다음과 같습니다.

cannot divide by zero
main.Divide
    /Users/xxx/Documents/go/src/error.go:3
main.main
    /Users/xxx/Documents/go/src/main.go:10
runtime.main
    /usr/local/go/src/runtime/proc.go:204
runtime.goexit
    /usr/local/go/src/runtime/asm_amd64.s:1371

보시다시피 오류 메시지와 파일 및 줄 번호만 볼 수는 없습니다. 오류 함수가 있는 위치뿐만 아니라 오류 함수의 구체적인 구현 코드도 볼 수 있습니다. 이러한 종류의 잘못된 정보 공개는 너무 자세하고 공격자의 성공 확률을 크게 높입니다.

3. Solution

문제가 발견되었으니 이제 해결책을 찾아야 합니다. 다음으로 가능한 두 가지 해결 방법은 다음과 같습니다.

  1. 사용자 정의 오류 유형

Golang에서는 오류 유형을 사용자 정의할 수 있습니다. 정의는 매우 간단합니다. 오류 인터페이스의 Error() 메서드만 구현하면 됩니다. 예:

type MyError struct {
    Reason string
}

func (m MyError) Error() string {
    return m.Reason
}

func Divide(a, b int) (float64, error) {
    if b == 0 {
        return 0, MyError{Reason: "cannot divide by zero"}
    }
    return float64(a) / float64(b), nil
}

이런 방식으로 프로그램 오류가 발생하면 오류 스택 정보에는 더 이상 경로와 같은 민감한 정보가 포함되지 않고 맞춤화된 오류 정보만 포함됩니다. 예:

cannot divide by zero
  1. 타사 라이브러리 사용

사용자 정의 오류 유형 외에도 기존 타사 라이브러리를 사용하여 이 문제를 해결할 수도 있습니다. 일반적으로 사용되는 라이브러리에는 오류 정보를 암호화하고 처리할 수 있는 logrus, zerolog 등이 있으며, 시스템 경로와 같은 민감한 정보의 노출을 효과적으로 방지할 수 있습니다.

Logrus를 예로 들면, Logrus를 사용하여 로그를 기록할 때 오류 유형 변수만 매개변수로 전달하면 됩니다. 예:

import (
    log "github.com/sirupsen/logrus"
)

func Divide(a, b int) (float64, error) {
    if b == 0 {
        return 0, fmt.Errorf("cannot divide by zero")
    }
    return float64(a) / float64(b), nil
}

func main() {
    result, err := Divide(10, 0)
    if err != nil {
        log.WithError(err).Error("divide error")
        return
    }
    log.Info(result)
}

이렇게 하면 프로그램 오류가 발생하면 로그에 오류 정보만 수신되며 경로 등 민감한 정보는 노출되지 않습니다.

4. 요약

이 글에서는 Golang의 오류 처리 메커니즘의 보안 문제를 소개하고 두 가지 솔루션을 제공합니다. 오류 유형을 사용자 정의하는 것이 일반적인 솔루션이며 타사 라이브러리를 사용하면 문제를 보다 편리하고 효율적으로 해결할 수 있습니다. Golang 개발자라면 오류 메시지에 민감한 정보가 노출될 수 있는지 주의 깊게 살펴보고 그에 따른 예방 조치를 취하시기 바랍니다. 이런 방법으로만 우리 프로그램을 더욱 안전하고 안정적으로 만들 수 있습니다.

위 내용은 golang 오류 노출 경로의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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