質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
ハッシュ

ハッシュは、高速にデータ検索を行うアルゴリズムのことです。

Q&A

3回答

10787閲覧

ハッシュ関数の作り方について

takayuki2020

総合スコア12

ハッシュ

ハッシュは、高速にデータ検索を行うアルゴリズムのことです。

0グッド

0クリップ

投稿2017/04/26 01:06

お世話になります。
takayuki2020です。

今回は、ソースコードがありません。
ハッシュ関数の作り方について質問です。

カスタマーなどがログインパスワードを作るとき、
ハッシュ×パスワードを組み合わせて作ると知りました。

具体的な作り方や、参考になる書籍などございましたら、ぜひ教えてください。
よろしくお願い申し上げます。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

パスワードの保護などに使うハッシュ関数は、決して自分で作ってはいけません。SHA-2、SHA-3など、よく知られていて、かつ強度が十分なものを使いましょう。

自分で作ると、

  • もとの値が違うのに、ハッシュ値が同じになってしまう(衝突)
  • ハッシュ値からもとの値に関する情報が得られてしまう

など、暗号学的に不適当なものとなってしまう危険性が、極めて大きいです。

投稿2017/04/26 01:18

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

Password Hashing Algorithmsを使ってください。
Argon2bcryptでキーワード検索するとHITするかと。

英語のサイトですが、個人的にかなり参考になりました。
How to Safely Store Your Users' Passwords in 2016

投稿2017/04/26 01:39

umyu

総合スコア5846

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

殆どのプログラム言語に標準で機能が付いていると思いますが、その使い方は言語によって異なります。
最も単純な使い方は、ハッシュ化する前の文字列を直接与えて

$hashed = hash('password');

と言うように関数を呼び出すとか。
気の利いたモノだと

$hashed = hash('password', 'sha1', 's32oi3fha2os5af8qy');

と言うように、ハッシュ化するアルゴリズムを指定出来たり、ランダム文字列を与えてよりセキュリティを強化する方法などもあると思います。

いずれにせよ言語によって関数の名前や引数、事前に必要な準備等は異なるので、言語がわからないと何とも言えません。

PHPでしたらコチラ等見てみてください

投稿2017/04/26 01:12

kunai

総合スコア5405

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問