ソフトウェア開発者として、私は常にセキュリティとユーザビリティの交差点に魅了されてきました。最近、私は Go を使用してコマンドライン パスワード マネージャーを作成するというエキサイティングなプロジェクトに着手することにしました。最初のコミットから、この旅の始まりを皆さんと共有したいと思います。
創世記
2023 年 11 月 27 日に、私はプロジェクトの最初のコミットを行いました。このプロジェクトに「dost」(ヒンディー語で友人を意味し、パスワード管理の役立つ仲間としての役割を反映) と名付けました。この最初のステップは小さいですが、堅牢でユーザーフレンドリーなツールになることを期待するものの基礎を築きます。
インスピレーションとビジョン
このプロジェクトに着手する際、私は人気のあるコマンドライン パスワード マネージャー パスからインスピレーションを得ました。 pass のシンプルさと有効性に私の注意を引き、Go で独自のパスワード マネージャーを構築するための青写真としてその API を使用することにしました。
パスのソースコードに飛び込むのは、目を見張るような経験でした。私は、この広く使用されているツールの機能全体が 1 つの包括的な Bash スクリプトにカプセル化されていることを発見して興味をそそられました。このエレガントなシンプルさは私が賞賛しており、Go の長所を利用しながらも、自分のプロジェクトで模倣したいと考えています。
パスを勉強することで、コマンドライン パスワード マネージャーの重要な機能と、それが提供すべきユーザー エクスペリエンスについて貴重な洞察を得ることができました。 「dost」の開発を続ける際には、これらの教訓を念頭に置き、パスのシンプルさと Go のパフォーマンスおよびクロスプラットフォーム互換性の利点を組み合わせたツールの作成を目指します。
この調査は、実装する機能のロードマップを提供しただけでなく、よく作られた焦点を絞ったツールの力に対する私の信念を強化しました。このインスピレーションが今後の開発段階で「dost」の進化をどのように形作るのか楽しみです。
最初の機能
最初のコミットは 2 つのコア機能に焦点を当てました:
パスワード生成: ユーザーが希望するパスワードの長さを指定できるようにする基本的なパスワード ジェネレーターを実装しました。この機能は、さまざまなセキュリティ要件に合わせて調整された強力なランダム化されたパスワードを作成することを目的としています。
クリップボードの統合: ユーザー エクスペリエンスを向上させるために、生成されたパスワードがクリップボードに自動的にコピーされるようにしました。この小さいながらも重要な機能により、時間が節約され、転記エラーのリスクが軽減されます。
技術的な洞察
この最初のイテレーションの技術的側面のいくつかを詳しく見てみましょう:
- Go バージョン: プロジェクトは Go 1.21.0 を使用して構築され、言語のシンプルさと効率性を活用しています。
- 外部依存関係: 異なるオペレーティング システム間でクリップボード操作をシームレスに処理するために、github.com/atotto/clipboard パッケージを使用しています。
- ランダム生成: パスワード生成では、Go の crypto/rand パッケージを利用して安全な乱数を生成します。これは、予測不可能で強力なパスワードを作成するために重要です。
- 文字セット: パスワード ジェネレーターには、複雑さを確保するために大文字、小文字、数字、およびさまざまな特殊文字が含まれています。
コードのスニペット
実装の重要な部分をいくつか見てみましょう:
- パスワード生成機能:
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 <p>この関数は、事前定義されたセットから文字をランダムに選択して、大文字、小文字、数字、特殊文字を確実に組み合わせてパスワードを作成します。</p> <ol> <li>クリップボードの統合: </li> </ol> <pre class="brush:php;toolbar:false">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") }
main 関数はすべてを結び付けます。 Go のフラグ パッケージを使用して、ユーザーがパスワードの長さを指定し、パスワードを生成してクリップボードにコピーできるようにします。
コマンドラインインターフェース
メイン関数でわかるように、Go の flag パッケージを使用して簡単な 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.
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
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
以上がGo でパスワード マネージャーを構築するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

この記事では、コードのランタイム操作に使用されるGoの反射パッケージについて説明します。シリアル化、一般的なプログラミングなどに有益です。実行やメモリの使用量の増加、賢明な使用と最高のアドバイスなどのパフォーマンスコストについて警告します

この記事では、GOでテーブル駆動型のテストを使用して説明します。これは、テストのテーブルを使用して複数の入力と結果を持つ関数をテストする方法です。読みやすさの向上、重複の減少、スケーラビリティ、一貫性、および

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

Dreamweaver Mac版
ビジュアル Web 開発ツール

ホットトピック



