MD5をc#で簡単に使用できることはわかっています。使用するコードは次のとおりです。
using System.Security.Cryptography;
public static string MD5(string input)
{
MD5CryptoServiceProvider x = new MD5CryptoServiceProvider();
byte[] bs = System.Text.Encoding.UTF8.GetBytes(input);
bs = x.ComputeHash(bs);
System.Text.StringBuilder s = new System.Text.StringBuilder();
foreach (byte b in bs)
{
s.Append(b.ToString("x2").ToLower());
}
return s.ToString();
}
通常、MD5文字列の長さは32文字で、0〜9およびafです。0-9AZazと_を使用するかどうか疑問に思いました。-など、約64文字が設定され、MD5文字列は大幅に短くなります。MD5文字列を使用して何かを識別し、データベースに保存します。短い文字列でも同じことができ、スペースも少なくて済み、インデックス作成にかかる時間も短くなります。
だからここに、私の質問は、誰もが0-9a-f文字列を0-9A-Za-z._文字列に変更するための高速な方法を持っているということです
ps基本的な考え方は、MD5文字列をint(非常に大きくなります)に変更してから、任意の文字セットを使用して文字列に転送することです。私はそれが遅くなることを想像することができます。
どんなアイデアでも役に立ちます。ありがとう。
[編集]
皆さん、ありがとうございました。最終的には自分の文字列を展開します。URLの一部としても必要なので、文字列が必要です。固定長の文字列が必要なため、Base64は使用しません。
MD5は16文字で長さは32ですが、64文字に変更すると長さが20になります。
これが私が使っているアップデート機能です。
public static string MD520(string input)
{
char[] chars = new char[] { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '_', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '-', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };
MD5CryptoServiceProvider x = new MD5CryptoServiceProvider();
byte[] bs = System.Text.Encoding.UTF8.GetBytes(input);
bs = x.ComputeHash(bs);
System.Text.StringBuilder s = new System.Text.StringBuilder();
byte m = 0;
int c = 0;
foreach (byte b in bs)
{
if (m == 2)
{
c = c * b;
for (byte i = 0; i < 4; i++)
{
int n = c % 64;
s.Append(chars[n]);
c = (c - n) / 64;
}
m = 0;
}
else
{
c = ((m > 0) ? c : 1) * b;
m++;
}
}
return s.ToString();
}