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

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

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

解決済

2回答

7420閲覧

アプリでパスワードを保存させる一般的な暗号化の方法

FacePanel

総合スコア48

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

2クリップ

投稿2018/09/17 10:37

いろいろ、方法はあると思いますが、絶対にばれては困るという程の重要性がない場合に、それでも簡単な暗号化をさせようとする場合、どんな方法が良いのでしょうか?
クレジットカードの番号やウェブサイトのパスワードほどではない場合の、例えば、ある部署内部で使うパスワード程度と思ってください。
勝手に、変更されては困るけれども、わざわざパスワードを見つけ出したいと思う程の重要性のないものです。

なお、バイナリなどを使う場合に、どうしたらバイナリに変換したり、戻したりできるのかという問題についても教えていただけますと、助かります。

どうぞよろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

素直に AES 暗号を使えばいいのではないでしょうか。
バイナリをテキストに変換したり戻したりするには以下のように Base64 を使ってください。

C#

1using System; 2using System.IO; 3using System.Linq; 4using System.Security.Cryptography; 5using System.Text; 6 7namespace ConsoleApp1 8{ 9 class Program 10 { 11 static void Main(string[] args) 12 { 13 string password = "暗号化用パスワード"; 14 string text = "平文"; 15 using (var cryptor = new Cryptor(password)) 16 { 17 var encoded = Convert.ToBase64String(cryptor.Encode(text)); 18 var decoded = cryptor.Decode(Convert.FromBase64String(encoded)); 19 Console.WriteLine(encoded); 20 Console.WriteLine(decoded); 21 } 22 Console.ReadKey(); 23 } 24 } 25 26 class Cryptor : IDisposable 27 { 28 public Cryptor(string password) 29 { 30 using (var hash = new SHA512Managed()) 31 { 32 var data = hash.ComputeHash(Encoding.UTF8.GetBytes(password)); 33 Algorithm.KeySize = 256; 34 Algorithm.Key = data.Take(32).ToArray(); 35 Algorithm.IV = data.Skip(32).Take(16).ToArray(); 36 } 37 } 38 39 protected SymmetricAlgorithm Algorithm { get; private set; } = new AesManaged(); 40 41 public byte[] Encode(string text) 42 { 43 using (var memoryStream = new MemoryStream()) 44 { 45 using (var cryptoStream = new CryptoStream(memoryStream, Algorithm.CreateEncryptor(), CryptoStreamMode.Write)) 46 { 47 var buffer = Encoding.UTF8.GetBytes(text); 48 cryptoStream.Write(buffer, 0, buffer.Length); 49 } 50 return memoryStream.ToArray(); 51 } 52 } 53 54 public string Decode(byte[] encoded) 55 { 56 using (var memoryStream = new MemoryStream(encoded)) 57 using (var cryptoStream = new CryptoStream(memoryStream, Algorithm.CreateDecryptor(), CryptoStreamMode.Read)) 58 using (var reader = new StreamReader(cryptoStream, Encoding.UTF8)) 59 { 60 return reader.ReadToEnd(); 61 } 62 } 63 64 public void Dispose() 65 { 66 Algorithm?.Dispose(); 67 Algorithm = null; 68 } 69 } 70} 71

投稿2018/09/17 18:23

Zuishin

総合スコア28660

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

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

guest

0

  • もっとも簡単な方法

パスワードのXORを取ってビット反転させて保存する。
簡単ですが見る人が見たらすぐ見破られます。

  • もうちょっと複雑な方法

パスワードに適当なソルトを付与してSHA256あたりのハッシュ関数で何回かハッシュ計算し(ストレッチング)、その結果を保存する。
ユーザーからパスワードを入力されるたびに同じ方法で計算し保存したデータと一致するか検査する。
この方法は「戻し方」を考慮する必要はないです(そもそも戻せない)
「ソルト」「ストレッチング」がわからない場合は検索して調べてください。だいたい実装方法も含めてたくさん情報が見つかります。

投稿2018/09/17 10:52

hope_mucci

総合スコア4447

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問