?? 根據(jù)用戶名生成注冊(cè)碼的算法.txt
字號(hào):
現(xiàn)在網(wǎng)上下載的軟件大部分都需要注冊(cè)后才能使用其全部的功能,也就是說(shuō)當(dāng)前大部分軟件都是建立了注冊(cè)機(jī)制的,對(duì)于一個(gè)剛進(jìn)入軟件行業(yè)的程序員來(lái)說(shuō)一定非常想了解其中的注冊(cè)機(jī)制是怎樣實(shí)現(xiàn)的。其實(shí)用VC開發(fā)軟件,是可以很方便地加入注冊(cè)機(jī)制的。
要實(shí)現(xiàn)軟件注冊(cè)功能,首先需要知道實(shí)現(xiàn)注冊(cè)機(jī)制要涉及到的幾個(gè)問(wèn)題:1、如何加入注冊(cè)檢測(cè),判斷軟件是否注冊(cè);2、如何生成注冊(cè)碼,如何保證一個(gè)用戶名只生成與之唯一對(duì)應(yīng)的注冊(cè)碼;3、在軟件不注冊(cè)情況下,如何限制軟件功能的局限性;4、對(duì)已經(jīng)負(fù)費(fèi)使用用戶而言,不應(yīng)造成使用不便。
首先,應(yīng)該有一個(gè)生成注冊(cè)碼的算法,以下是我簡(jiǎn)單的一個(gè)生成15為注冊(cè)碼的算法:
//該函數(shù)返回一個(gè)CSTRING類型的15位注冊(cè)碼,入口參數(shù)為用戶名
CString GetRegPasswd(CString &DirName)
{
//將用戶名換算成15位注冊(cè)碼
long Num1,Num2,Num3;
char sn[16]={0};
CString p;
int i,len;
Num1=0;
Num2=0;
Num3=0;
len=int(strlen(DirName));
if(len!=0)
{
for( i=1;i<=len;i++)
{
//第一步算法
Num1=(long(Num1+(int(DirName[i-1])*i*i)*(i*sqrt(DirName[i-1])+1)))%100000;
//第二步算法
Num2=(Num2*i+(long(pow((int)DirName[i-1],2)*i)))%100000;
//第三步算法
Num3=(Num2+(long)sqrt(Num1))%100000;
}
//以下把三個(gè)算法結(jié)果分別生成5個(gè)字符,共有15個(gè)
for(i=0;i<5;i++)
sn[i]=(int)(Num1+31+i*i*i)%128;
for(i=5;i<10;i++)
sn[i]=(int)(Num2+31+i*i*i)%128;
for(i=10;i<15;i++)
sn[i]=(int)(Num3+31+i*i*i)%128;
sn[15]=0;
//以下循環(huán)把所有生成的字符轉(zhuǎn)換為0---9,A---Z,a----z
for(i=0;i<15;i++)
{
while((sn[i]<''0'' || sn[i]>''9'') && (sn[i]<''A'' || sn[i]>''Z'') &&(sn[i]<''a'' || sn[i]>''z'') )
{
sn[i]=(sn[i]+31+7*i)%128;
}
}
//賦值給一個(gè)CSTRING變量,用做函數(shù)返回值
p.Format("%s",sn);
}
return p;
}
//檢查軟件是否注冊(cè)的函數(shù)
BOOL GetRegFlag(void)
{
HKEY hKey = NULL;
BYTE i;
CString str;
str.LoadString(IDS_REG_KEY);// IDS_REG_KEY為在注冊(cè)表中的子目錄字符串
if (RegCreateKey(HKEY_CURRENT_USER, str, &hKey) != ERROR_SUCCESS) return false;
DWORD cbA;
cbA=sizeof(int);
if( RegQueryValueEx(hKey, "SzMima",NULL,NULL, &i,&cbA) != ERROR_SUCCESS)
return false;
BYTE j=i;
if(j==0)//0代表軟件已經(jīng)注冊(cè),可以正常使用
{
RegCloseKey(hKey);
return true;
}
else
{
RegCloseKey(hKey);
return false;
}
return false;
};
//設(shè)置軟件已經(jīng)注冊(cè)標(biāo)志的函數(shù)
BOOL SetRegFlag(void)
{
HKEY hKey = NULL;
BYTE i;
CString str;
str.LoadString(IDS_REG_KEY);// IDS_REG_KEY為在注冊(cè)表中的子目錄字符串
if (RegCreateKey(HKEY_CURRENT_USER, str, &hKey) != ERROR_SUCCESS) return false;
BYTE j=0;//0代表已經(jīng)注冊(cè)
if(RegSetValueEx(hKey, "SzMima", 0, REG_BINARY, &j,4) != ERROR_SUCCESS)
{
AfxMessageBox("設(shè)置注冊(cè)表數(shù)據(jù)失敗!");
return FALSE;
}
return false;
};
以上三個(gè)函數(shù)即可實(shí)現(xiàn)軟件注冊(cè)機(jī)制,只需要在程序初始化的時(shí)候加入以下幾句代碼即可
BOOL bReg= GetRegFlag ();
if(!bReg)
{
//在此加入限制功能或者拒絕是使用的代碼
}
如果用戶注冊(cè)只需要加入以下代碼即可
//這是我的程序中的一個(gè)注冊(cè)界面,輸入用戶名和注冊(cè)碼提交后檢驗(yàn)注冊(cè)碼是否正確的代碼
void CRegEdit::OnBnClickedOk()
{
if(!UpdateData()) return;//取得編輯框的內(nèi)容,并賦值到類變量中
m_RegUser.TrimLeft();//m_RegUser是用戶名
m_RegUser.TrimRight();
if(m_RegUser.IsEmpty())
{
AfxMessageBox("用戶名不能為空,請(qǐng)重新輸入。");
GetDlgItem(IDC_REGUSER)->SetFocus();
return;
}
m_RegPasswd.TrimLeft();m_RegPasswd是注冊(cè)碼
m_RegPasswd.TrimRight();
if(m_RegPasswd.IsEmpty())
{
AfxMessageBox("注冊(cè)碼不能為空,請(qǐng)重新輸入。");
GetDlgItem(IDC_REGPASSWD)->SetFocus();
return;
}
CString Passwd;
Passwd=GetRegPasswd(m_RegUser);//調(diào)用算法取得該用戶名的注冊(cè)碼
if(Passwd==m_RegPasswd)//與用戶輸入的注冊(cè)進(jìn)行比較
{
SetRegFlag();//設(shè)置注冊(cè)標(biāo)志
OnOK();
}
else
AfxMessageBox("注冊(cè)碼錯(cuò)誤,請(qǐng)重新輸入。");
UpdateData(false);
}
以上就是在VC中實(shí)現(xiàn)注冊(cè)機(jī)制的主要的代碼,把他們加入您的程序即可。程序代碼已在VC6.0/WIN98/WIN 2000環(huán)境中運(yùn)行通過(guò),并在實(shí)際運(yùn)用中得到驗(yàn)證。對(duì)已經(jīng)注冊(cè)的用戶將不會(huì)有任何的障礙,只需錄入注冊(cè)碼一次就可以,不增加其日常使用的負(fù)擔(dān);而對(duì)非法用戶的使用而言,取決于軟件的作者賦予他們的權(quán)利。
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -