> 백엔드 개발 > Golang > Go에서 비밀번호 관리자 구축하기

Go에서 비밀번호 관리자 구축하기

DDD
풀어 주다: 2024-09-18 20:17:30
원래의
911명이 탐색했습니다.

소프트웨어 개발자로서 저는 항상 보안과 유용성의 교차점에 매료되어 왔습니다. 최근에 저는 Go를 사용하여 명령줄 비밀번호 관리자를 만드는 흥미로운 프로젝트에 착수하기로 결정했습니다. 첫 번째 커밋부터 시작하여 이 여정의 시작을 여러분과 공유하고 싶습니다.

창세기

2023년 11월 27일에 저는 "dost"(힌디어로 친구, 비밀번호 관리에 도움이 되는 동반자 역할을 반영함)라는 이름을 붙인 프로젝트에 대한 초기 커밋을 했습니다. 이 첫 번째 단계는 작지만 강력하고 사용자 친화적인 도구가 되기를 바라는 기반을 마련합니다.

영감과 비전

Building a Password Manager in Go

이 프로젝트를 시작하면서 저는 인기 있는 명령줄 비밀번호 관리자 패스에서 영감을 얻었습니다. Pass의 단순성과 효율성이 내 관심을 끌었고 Go에서 나만의 비밀번호 관리자를 구축하기 위한 청사진으로 Pass의 API를 사용하기로 결정했습니다.

패스의 소스 코드를 살펴보는 것은 놀라운 경험이었습니다. 나는 널리 사용되는 이 도구의 전체 기능이 하나의 포괄적인 Bash 스크립트에 캡슐화되어 있다는 사실에 흥미를 느꼈습니다. 비록 Go의 장점을 활용하기는 하지만 이 우아한 단순함은 제가 존경하고 내 프로젝트에서 본받고 싶은 것입니다.

통과 과정을 통해 저는 명령줄 비밀번호 관리자의 필수 기능과 그것이 제공해야 하는 사용자 경험에 대한 귀중한 통찰력을 얻었습니다. 저는 "dost"를 계속 개발하면서 이러한 교훈을 염두에 두고 Go의 성능 및 크로스 플랫폼 호환성 이점과 패스의 단순성을 결합한 도구를 만드는 것을 목표로 삼을 것입니다.

이 탐구는 구현할 기능에 대한 로드맵을 제공했을 뿐만 아니라 잘 제작되고 집중된 도구의 힘에 대한 나의 믿음을 강화했습니다. 이 영감이 향후 개발 단계에서 "dost"의 진화를 어떻게 형성할지 기대됩니다.

첫 번째 기능

초기 커밋은 두 가지 핵심 기능에 중점을 두었습니다.

  1. 비밀번호 생성: 사용자가 원하는 비밀번호 길이를 지정할 수 있는 기본 비밀번호 생성기를 구현했습니다. 이 기능은 다양한 보안 요구 사항에 맞춰 강력하고 무작위 비밀번호를 생성하는 것을 목표로 합니다.

  2. 클립보드 통합: 사용자 경험을 향상시키기 위해 생성된 비밀번호가 자동으로 클립보드에 복사되도록 했습니다. 작지만 중요한 이 기능은 시간을 절약하고 전사 오류의 위험을 줄여줍니다.

기술적 통찰력

첫 번째 버전의 몇 가지 기술적 측면을 살펴보겠습니다.

  • Go 버전: 프로젝트는 언어의 단순성과 효율성을 활용하는 Go 1.21.0을 사용하여 구축되었습니다.
  • 외부 종속성: 다양한 운영 체제에서 클립보드 작업을 원활하게 처리하기 위해 github.com/atotto/clipboard 패키지를 사용하고 있습니다.
  • 무작위 생성: 비밀번호 생성에서는 예측할 수 없고 강력한 비밀번호를 생성하는 데 중요한 보안 난수 생성을 위해 Go의 crypto/rand 패키지를 활용합니다.
  • 문자 세트: 비밀번호 생성기에는 대문자와 소문자, 숫자, 다양한 특수 문자가 포함되어 복잡성을 보장합니다.

코드 조각

구현의 몇 가지 주요 부분을 살펴보겠습니다.

  1. 비밀번호 생성 기능:
func generatePassword(length int) (string, error) {
    const (
        uppercaseLetters = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
        lowercaseLetters = "abcdefghijklmnopqrstuvwxyz"
        digits           = "0123456789"
        specialChars     = "!@#$%^&*()-_=+[]{}|;:'\",.<>/?"
    )

    allChars := uppercaseLetters + lowercaseLetters + digits + specialChars

    var password string
    for i := 0; i < length; i++ {
        randomIndex, err := rand.Int(rand.Reader, big.NewInt(int64(len(allChars))))
        if err != nil {
            return "", err
        }
        password += string(allChars[randomIndex.Int64()])
    }

    return password, nil
}
로그인 후 복사

이 기능은 사전 정의된 문자 집합에서 무작위로 문자를 선택하여 대문자, 소문자, 숫자, 특수 문자를 혼합하여 비밀번호를 생성하는 기능입니다.

  1. 클립보드 통합:
func writeToClipboard(text string) error {
    return clipboard.WriteAll(text)
}
로그인 후 복사

이 간단한 기능은 클립보드 패키지를 활용하여 생성된 비밀번호를 시스템 클립보드에 기록하는 것입니다.

  1. 주요 기능:
func main() {
    passwordLength := flag.Int("length", 12, "length of your password")
    flag.Parse()

    password, err1 := generatePassword(*passwordLength)
    if err1 != nil {
        fmt.Println("Error generating password:", err1)
        return
    }

    fmt.Println("Generated Password:", password)

    err2 := writeToClipboard(password)
    if err2 != nil {
        fmt.Println("Error writing to clipboard:", err2)
        os.Exit(1)
    }

    fmt.Println("Copied to clipboard! ✅\n")
}
로그인 후 복사

주요 기능은 모든 것을 하나로 묶습니다. Go의 플래그 패키지를 사용하여 사용자가 비밀번호 길이를 지정하고 비밀번호를 생성한 후 클립보드에 복사할 수 있도록 합니다.

명령줄 인터페이스

메인 함수에서 볼 수 있듯이 Go의 플래그 패키지를 이용하여 간단한 CLI를 구현해봤습니다. 사용자는 -length 플래그를 사용하여 원하는 비밀번호 길이를 지정할 수 있으며, 지정하지 않은 경우 기본값은 12자입니다.

미래를 내다보며

이 첫 번째 커밋은 시작에 불과합니다. 이 비밀번호 관리자를 계속 개발하면서 다음과 같은 기능을 추가할 계획입니다.

  • Secure storage of passwords
  • Encryption of stored data
  • Search and retrieval functionalities
  • Password strength analysis

I'm excited about the journey ahead and the challenges it will bring. Building a password manager is not just about coding; it's about understanding security principles, user needs, and creating a tool that people can trust with their sensitive information.

Stay tuned for more updates as this project evolves. I'll be sharing my progress, challenges, and learnings along the way. If you're interested in following along or contributing, feel free to check out the project on GitHub.

Building a Password Manager in Go svemaraju / dost

dost command line password manager written in Go

dost

dost is a CLI password manager written in Go.

Inspired by (Pass)[https://www.passwordstore.org/]

Features

  • Generate random passwords of configurable length
  • Copy generated passwords to clipboard automatically
  • Skip using symbols

Usage

> go build -o dost main.go
로그인 후 복사
Enter fullscreen mode Exit fullscreen mode

Generating password:

> ./dost generate email/vema@example.com
Generated Password: );XE,7-Dv?)Aa+&<{V-|pKuq5
로그인 후 복사

Generating password with specified length (default is 25):

> ./dost generate email/vema@example.com 12
Generated Password: si<yJ=5/lEb3
로그인 후 복사

Copy generated password to clipboard without printing:

> ./dost generate -c email/vema@example.com 
Copied to clipboard! ✅
로그인 후 복사

Avoid symbols for generating passwords:

> ./dost generate -n email/vema@example.com 
Generated Password: E2UST}^{Ac[Fb&D|cD%;Eij>H
로그인 후 복사

Under development

  • Insert a new password manually
  • Show an existing password
  • List all entries
  • Password storage
  • GPG Key based encryption

License

MIT




View on GitHub


위 내용은 Go에서 비밀번호 관리자 구축하기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿