今天要做邀请码这个功能,但是我又懒得修改数据库表结构,然后在网上看了不少博客,然后在php一个博客上面看到了一种写法,然后便根据我的理解改写成了.net的写法。话不多说直接贴代码。
static void Main(string[] args)
{
int num = 10086;
Console.WriteLine(createCode(num));
Console.WriteLine(decode(createCode(num)));
Console.ReadKey();
}
static string source_string= "2YU9IP6ASDFG8QWERTHJ7KLZX4CV5B3ONM1";//自定义35进制
public static string createCode(int Id)
{
string code = "";
int mod =0;
StringBuilder sb = new StringBuilder();
while (Id > 0)
{
mod = Id % source_string.Length;
Id = (Id - mod) / source_string.Length;
code = source_string.ToCharArray()[mod]+ code;
}
return code.PadRight(6,'0');//不足六位补0
}
public static int decode(string code)
{
code =new string((from s in code where s!='0' select s).ToArray());
int num = 0;
for (int i = 0; i < code.ToCharArray().Length; i++)
{
for (int j = 0; j < source_string.ToCharArray().Length; j++)
{
if (code.ToCharArray()[i]== source_string.ToCharArray()[j])
{
num += j*Convert.ToInt32(Math.Pow(source_string.Length, code.ToCharArray().Length-i-1));
}
}
}
return num;
}
这样写的好处在于他人不知道你进制的顺序所以也很难从邀请码反推出你的用户ID。
我只是一个走在编程路上的菜鸟,欢迎大家批评指正谢谢。