소프트웨어 개발자로서 저는 항상 보안과 유용성의 교차점에 매료되어 왔습니다. 최근에 저는 Go를 사용하여 명령줄 비밀번호 관리자를 만드는 흥미로운 프로젝트에 착수하기로 결정했습니다. 첫 번째 커밋부터 시작하여 이 여정의 시작을 여러분과 공유하고 싶습니다.
2023년 11월 27일에 저는 "dost"(힌디어로 친구, 비밀번호 관리에 도움이 되는 동반자 역할을 반영함)라는 이름을 붙인 프로젝트에 대한 초기 커밋을 했습니다. 이 첫 번째 단계는 작지만 강력하고 사용자 친화적인 도구가 되기를 바라는 기반을 마련합니다.
이 프로젝트를 시작하면서 저는 인기 있는 명령줄 비밀번호 관리자 패스에서 영감을 얻었습니다. Pass의 단순성과 효율성이 내 관심을 끌었고 Go에서 나만의 비밀번호 관리자를 구축하기 위한 청사진으로 Pass의 API를 사용하기로 결정했습니다.
패스의 소스 코드를 살펴보는 것은 놀라운 경험이었습니다. 나는 널리 사용되는 이 도구의 전체 기능이 하나의 포괄적인 Bash 스크립트에 캡슐화되어 있다는 사실에 흥미를 느꼈습니다. 비록 Go의 장점을 활용하기는 하지만 이 우아한 단순함은 제가 존경하고 내 프로젝트에서 본받고 싶은 것입니다.
통과 과정을 통해 저는 명령줄 비밀번호 관리자의 필수 기능과 그것이 제공해야 하는 사용자 경험에 대한 귀중한 통찰력을 얻었습니다. 저는 "dost"를 계속 개발하면서 이러한 교훈을 염두에 두고 Go의 성능 및 크로스 플랫폼 호환성 이점과 패스의 단순성을 결합한 도구를 만드는 것을 목표로 삼을 것입니다.
이 탐구는 구현할 기능에 대한 로드맵을 제공했을 뿐만 아니라 잘 제작되고 집중된 도구의 힘에 대한 나의 믿음을 강화했습니다. 이 영감이 향후 개발 단계에서 "dost"의 진화를 어떻게 형성할지 기대됩니다.
초기 커밋은 두 가지 핵심 기능에 중점을 두었습니다.
비밀번호 생성: 사용자가 원하는 비밀번호 길이를 지정할 수 있는 기본 비밀번호 생성기를 구현했습니다. 이 기능은 다양한 보안 요구 사항에 맞춰 강력하고 무작위 비밀번호를 생성하는 것을 목표로 합니다.
클립보드 통합: 사용자 경험을 향상시키기 위해 생성된 비밀번호가 자동으로 클립보드에 복사되도록 했습니다. 작지만 중요한 이 기능은 시간을 절약하고 전사 오류의 위험을 줄여줍니다.
첫 번째 버전의 몇 가지 기술적 측면을 살펴보겠습니다.
구현의 몇 가지 주요 부분을 살펴보겠습니다.
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 }
이 기능은 사전 정의된 문자 집합에서 무작위로 문자를 선택하여 대문자, 소문자, 숫자, 특수 문자를 혼합하여 비밀번호를 생성하는 기능입니다.
func writeToClipboard(text string) error { return clipboard.WriteAll(text) }
이 간단한 기능은 클립보드 패키지를 활용하여 생성된 비밀번호를 시스템 클립보드에 기록하는 것입니다.
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자입니다.
이 첫 번째 커밋은 시작에 불과합니다. 이 비밀번호 관리자를 계속 개발하면서 다음과 같은 기능을 추가할 계획입니다.
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.
dost is a CLI password manager written in Go.
Inspired by (Pass)[https://www.passwordstore.org/]
> go build -o dost main.go
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
MIT
위 내용은 Go에서 비밀번호 관리자 구축하기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!