[解決済み] Pythonでパスワードのソルトとハッシュ化
2022-09-15 19:19:40
質問
このコードは、ソルトでパスワードをハッシュ化することになっています。 ソルトとハッシュ化されたパスワードは、データベースに保存されます。 パスワード自体は保存されません。
この操作の機密性を考えると、私はすべてが順調であることを確認したいと思いました。
import hashlib
import base64
import uuid
password = 'test_password'
salt = base64.urlsafe_b64encode(uuid.uuid4().bytes)
t_sha = hashlib.sha512()
t_sha.update(password+salt)
hashed_password = base64.urlsafe_b64encode(t_sha.digest())
どのように解決するのですか?
EDITです。 この回答は間違いです。SHA512の1回の繰り返しは 速い であり、パスワードハッシュ関数として使用するには不適切です。代わりに、ここにある他の回答の1つを使用してください。
私には問題ないように見えます。しかし、私はあなたが実際にbase64を必要としないことを確信しています。あなたはこれを行うことができます。
import hashlib, uuid
salt = uuid.uuid4().hex
hashed_password = hashlib.sha512(password + salt).hexdigest()
問題が生じないのであれば、ソルトとハッシュ化されたパスワードを16進文字列ではなく生のバイトとして保存することで、データベースへの保存効率をわずかに向上させることができます。これを行うには
hex
を
bytes
と
hexdigest
と
digest
.
関連
-
[解決済み] staticmethodとclassmethodの違いについて
-
[解決済み] Pythonには文字列の'contains'サブストリングメソッドがありますか?
-
[解決済み] Pythonで現在時刻を取得する方法
-
[解決済み] Pythonで2つのリストを連結する方法は?
-
[解決済み] Pythonで例外を手動で発生(スロー)させる
-
[解決済み】ネストされたディレクトリを安全に作成するには?
-
[解決済み】PHPパスワードのハッシュとソルトの安全性について
-
[解決済み】Pythonに三項条件演算子はありますか?
-
[解決済み] Javaでパスワードをハッシュ化するには?
-
[解決済み] PyMongoで.sortを使用する
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] PythonでのAWS Lambdaのインポートモジュールエラー
-
[解決済み] 2つの線分が交差しているかどうかを確認するにはどうすればよいですか?
-
[解決済み] pandasのDataFrameから空のセルを含む行を削除する
-
[解決済み] なぜ(0-6)は-6=偽なのか?重複
-
[解決済み] 古いバージョンのPythonにおける辞書のキーの並び順
-
[解決済み] pandasのタイムゾーンに対応したDateTimeIndexを、特定のタイムゾーンに対応したナイーブなタイムスタンプに変換する。
-
[解決済み] Cythonのコードを含むPythonパッケージはどのように構成すればよいのでしょうか?
-
[解決済み] Flaskで非同期タスクを作る
-
[解決済み] 新しいpip backtrackingの実行時問題の解決
-
[解決済み] Alembicアップグレードスクリプトでインサートやアップデートを実行するにはどうすればよいですか?