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

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

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

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

Unity3D

Unity3Dは、ゲームや対話式の3Dアプリケーション、トレーニングシュミレーション、そして医学的・建築学的な技術を可視化する、商業用の開発プラットフォームです。

Q&A

解決済

1回答

741閲覧

Unityスクリプトの復号化で、CryptographicException: Invalid input block size.

valval

総合スコア43

C#

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

Unity3D

Unity3Dは、ゲームや対話式の3Dアプリケーション、トレーニングシュミレーション、そして医学的・建築学的な技術を可視化する、商業用の開発プラットフォームです。

0グッド

0クリップ

投稿2018/01/07 09:53

編集2018/01/07 09:55

チート対策のため、PlayerPrefsに格納するstringを暗号化し、再開時に復号化することを考えています。
暗号化は

C#

1 2 byte[] byteMessage = Encoding.UTF8.GetBytes(text);//平文をバイト列化 3 4 5 RijndaelManaged rijndael = new RijndaelManaged(); 6 rijndael.KeySize = 128; 7 rijndael.BlockSize = 128; 8 9 // パスワードから共有キーと初期化ベクターを作成 10 string pw = getkey(); 11 string salt =getSalt(); 12 13 byte[] bSalt = Encoding.UTF8.GetBytes(salt); 14 Rfc2898DeriveBytes deriveBytes = new Rfc2898DeriveBytes(pw, bSalt); 15 deriveBytes.IterationCount = 1000; // 反復回数 16 17 rijndael.Key = deriveBytes.GetBytes(rijndael.KeySize / 8); 18 rijndael.IV = deriveBytes.GetBytes(rijndael.BlockSize / 8); 19 20 // 暗号化 21 ICryptoTransform encryptor = rijndael.CreateEncryptor(); 22 byte[] encrypted = encryptor.TransformFinalBlock(byteMessage, 0, byteMessage.Length); 23 24 encryptor.Dispose(); 25 26 string encryptedstr = Encoding.UTF8.GetString(encrypted); 27 28 PlayerPrefs.SetString("data1", encryptedstr); 29 30 PlayerPrefs.Save();

とし、復号化は

C#

1 2     string saveddata = PlayerPrefs.GetString("data1", ""); 3 byte[] byteMessage = Encoding.UTF8.GetBytes(saveddata); 4 5 RijndaelManaged rijndael = new RijndaelManaged(); 6 rijndael.KeySize = 128; 7 rijndael.BlockSize = 128; 8 9 // パスワードから共有キーと初期化ベクターを作成 10 string pw =getkey(); 11 string salt =getSalt(); 12 13 byte[] bSalt = Encoding.UTF8.GetBytes(salt); 14 Rfc2898DeriveBytes deriveBytes = new Rfc2898DeriveBytes(pw, bSalt); 15 deriveBytes.IterationCount = 1000; // 反復回数 16 17 rijndael.Key = deriveBytes.GetBytes(rijndael.KeySize / 8); 18 rijndael.IV = deriveBytes.GetBytes(rijndael.BlockSize / 8); 19 20 // 復号化 21 ICryptoTransform decryptor = rijndael.CreateDecryptor(); 22 byte[] plain = decryptor.TransformFinalBlock(byteMessage, 0, byteMessage.Length); 23 24 decryptor.Dispose(); 25 26 27 string strMessage = Encoding.UTF8.GetString(plain);//平文がstrMessageに入るはず

としました。
暗号化は通ったものの、復号化の
byte[] plain = decryptor.TransformFinalBlock(byteMessage, 0, byteMessage.Length);
で、
CryptographicException: Invalid input block size.
Mono.Security.Cryptography.SymmetricTransform.FinalDecrypt (System.Byte[] inputBuffer, Int32 inputOffset, Int32 inputCount) (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/Mono.Security.Cryptography/SymmetricTransform.cs:462)
Mono.Security.Cryptography.SymmetricTransform.TransformFinalBlock (System.Byte[] inputBuffer, Int32 inputOffset, Int32 inputCount) (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/Mono.Security.Cryptography/SymmetricTransform.cs:554)
System.Security.Cryptography.RijndaelManagedTransform.TransformFinalBlock (System.Byte[] inputBuffer, Int32 inputOffset, Int32 inputCount) (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/System.Security.Cryptography/RijndaelManagedTransform.cs:94)
CameraPos.Start () (at Assets/CameraPos.cs:215)

というエラーががでました。

どうすれば、復号化できますか。

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

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

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

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

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

guest

回答1

0

ベストアンサー

バイト列のシリアライズにUTF8変換を使うのは悪手です。
なぜなら、文字データではないから、、。
Base64変換を使ってみてはいかがですか?
参考までに、MSDNのページなどを、、。

https://msdn.microsoft.com/ja-jp/library/dhx0d524(v=vs.110).aspx

投稿2018/01/07 10:29

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

valval

2018/01/07 11:00

ありがとうございます。 セーブ前に、 string encryptedstr = System.Convert.ToBase64String(encrypted); を行って暗号文をBase64化し、セーブデータを復号化する前に、 byte[] byteMessage = System.Convert.FromBase64String(saveddata); としたところ、無事、通りました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問