問題があります。C#でメールアドレスのマスキング/非表示部分を適用する必要があります。例
[email protected]==> jh**[email protected]
[email protected]==> bi****[email protected]
[email protected]==>br*******[email protected]
私はこのコードを持っていますが、いくつかの電子メールには例外があります。 "インデックスが配列の範囲外だった。"
for (int i = 0; i < eml.Length; i++)
{
int j = i == (eml.Length - 1) ? 0 : 1;
cc = eml[i].ToString();
if (i <= 1)
{
dispeml += cc;
}
else
if (eml[i + (j + k)].ToString() == "@")
{
dispeml += cc;
k = 0;
fl = 1;
}
else
if (eml[i + j].ToString() == "@")
{
dispeml += cc;
fl = 1;
}
else
if (fl == 1)
{
dispeml += cc;
}
else
{
dispeml += "*";
}
}
これが正規表現でこれを解決するためのアプローチです
string input = "[email protected]";
string pattern = @"(?<=[\w]{1})[\w-\._\+%]*(?=[\w]{1}@)";
string result = Regex.Replace(input, pattern, m => new string('*', m.Length));
//j**[email protected]
説明:
(?<=[\w]{1})
名前は1ワード文字で始まる必要があります
[\w-\._\+%]*
置換パーツには、-_.+%
を含む0〜n個のWord文字を含めることができます。
(?=[\w]{1}@)
名前は1つのWord文字で終わり、その後に@
が続く必要があります
変更しない文字数に応じて、最初または最後に{1}
を{2}
またはその他に変更できます。
@の前の最初の文字と最後の文字の間の何かを、固定数のマスクされた文字で常にマスクしたい場合は、以下を使用できます。
var email="[email protected]";
var maskedEmail = string.Format("{0}****{1}", email[0],
email.Substring(email.IndexOf('@')-1));
要件に応じて上記の行を変更できます。
上記の行は、結果「a ****[email protected]」を示します。
電子メールを常に固定文字数でマスクすると、電子メールを推測するのが難しくなり、少し安全になることに注意してください。
マスク後:a **** [email protected]
コードスニペットのどこでk変数が初期化されているのかわかりません。インデックスが範囲外の例外を取得している理由について、私がワイルドな刺し傷を負わなければならなかったとしたら、それが私の刺し傷になります。
正規表現を使用して行っているのと非常によく似た何かを達成できると思いますが。私はこのようにしました:
public string ObfuscateEmail(string email)
{
var displayCase = email;
var partToBeObfuscated = Regex.Match(displayCase, @"[^@]*").Value;
if (partToBeObfuscated.Length - 3 > 0) {
var obfuscation = "";
for (var i = 0; i < partToBeObfuscated.Length - 3; i++) obfuscation += "*";
displayCase = String.Format("{0}{1}{2}{3}", displayCase[0], displayCase[1], obfuscation, displayCase.Substring(partToBeObfuscated.Length - 1));
} else if (partToBeObfuscated.Length - 3 == 0) {
displayCase = String.Format("{0}*{1}", displayCase[0], displayCase.Substring(2));
}
return displayCase;
}
これは、あなたが説明していたものにかなり近い合格で提供されたすべてのテストケースのフィドルです https://dotnetfiddle.net/fU2RUo
[編集]私のコードは、@の前のアドレスが3文字未満のメールを難読化しようとはしていません。これが要件である場合は、コードを修正する必要がありますが、これは非常に現実的なケースではないと思いました。ケースを作成します。
特定のマスキング要件に合わせてカスタマイズする方が簡単だったので、このメソッドを作成しました。
これが誰かに役立つことを願っています。もしそうなら、答えを役に立ったとマークしてください。
public static string MaskEmail(this string email)
{
var emailsplit = email.Split('@');
var newsplit = emailsplit[1].Split('.');
char[] array1 = emailsplit[0].ToCharArray();
char[] array2 = newsplit[0].ToCharArray();
var output = "";
for (int i = 0; i < array1.Length; i++)
{
if (array1.Length > 4)
{
if (i == 0 || i == array1.Length - 1 || i == array1.Length - 2)
{
output += array1[i];
}
else
{
output += "*";
}
}
else
{
if (i == 0)
{
output += array1[i];
}
else
{
output += "*";
}
}
}
output += "@";
for (int i = 0; i < array2.Length; i++) output += "*";
for (int i = 1; i < newsplit.Length; i++) output += "." + newsplit[i];
return output;
}
このA **** B @ C **** D.comのようなメールをマスクしたかったのです。これは、複数のドットがあるか、ドメイン拡張子がない電子メールでも機能します。
public string MaskEmail(string email)
{
if (string.IsNullOrEmpty(email) || !email.Contains("@"))
return email;
string[] emailArr = email.Split('@');
string domainExt = Path.GetExtension(email);
string maskedEmail = string.Format("{0}****{1}@{2}****{3}{4}",
emailArr[0][0],
emailArr[0].Substring(emailArr[0].Length - 1),
emailArr[1][0],
emailArr[1].Substring(emailArr[1].Length - domainExt.Length - 1, 1),
domainExt
);
return maskedEmail;
}
結果
[email protected] >> i****o@s****w.com
[email protected] >> m****e@g****e.nl
[email protected] >> w****r@s****w.org
test@noextension >> t****t@n****n
[email protected] >> x****x@y****y.net
public static string EmailStarString(string email)
{
string[] parts = email.Split('@');
string star = string.Empty;
string firstCharEmailName = parts[0].First().ToString();
string lastCharEmailName = parts[0].Last().ToString();
for (int i = 0; i < parts[0].Length - 2; i++)
{
star += "*";
}
return firstCharEmailName + star + lastCharEmailName + "@" + parts[1];
}