麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

簡(jiǎn)述.Net下的應(yīng)用程序授權(quán)實(shí)戰(zhàn)步驟

2019-11-17 04:27:40
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

  看了“看了下面那篇“Crack別人應(yīng)用程序”的文章有感,簡(jiǎn)述.Net下的應(yīng)用程序授權(quán)。”,自己實(shí)際操作了把得出的心得  。這里原理啊背景啊什么都不介紹了,笑望人生已經(jīng)在他的BLOG上都寫(xiě)的相當(dāng)清楚了,有什么不細(xì)節(jié)不明白的可以去看原文。推薦先大概看下原文,現(xiàn)看我下面的步驟,然后再回頭去研究原文的細(xì)節(jié)。由于我自己寫(xiě)的實(shí)例是用在公司一項(xiàng)目中,源代碼就不方便放出來(lái)了,嘿嘿。
  第一步:生成一組公鑰和私鑰,公鑰用于你發(fā)布程序,私鑰屬于注冊(cè)碼生成。view plaincopy to clipboardPRint?
using(RSACryptoServiceProvider rsa = new  RSACryptoServiceProvider())   
{   
 // 公鑰   
 string pubkey = rsa.ToxmlString(false);   
   
 // 私鑰   
string prikey = rsa.ToXmlString(true);   
 
//如果是webForm就Response.Write(pubkey + ”<br/>” + prikey); 下  
//如果是winForm就MessageBox.Show("公鑰:" + pubkey + "/r/n私鑰:" + prikey); 下  

using(RSACryptoServiceProvider rsa = new  RSACryptoServiceProvider())
{
 // 公鑰
 string pubkey = rsa.ToXmlString(false);
 
 // 私鑰
string prikey = rsa.ToXmlString(true);

//如果是webForm就Response.Write(pubkey + ”<br/>” + prikey); 下
//如果是winForm就MessageBox.Show("公鑰:" + pubkey + "/r/n私鑰:" + prikey); 下
}  第二步:取得機(jī)器硬件編碼。我選用CUP的編號(hào)。view plaincopy to clipboardprint?
/// <summary>  
/// 獲取CPU編號(hào)  
/// </summary>  
/// <returns></returns>  
public string GetCpuId()  
{  
 
ManagementClass mc = new ManagementClass("Win32_Processor");  
ManagementObjectCollection moc = mc.GetInstances();  
 
String strCpuID = null;  
foreach (ManagementObject mo in moc)  
{  
strCpuID = mo.Properties["ProcessorId"].Value.ToString();  
break;  
}  
return strCpuID;  
 

 /// <summary>
 /// 獲取CPU編號(hào)
 /// </summary>
 /// <returns></returns>
 public string GetCpuId()
 {

 ManagementClass mc = new ManagementClass("Win32_Processor");
 ManagementObjectCollection moc = mc.GetInstances();

 String strCpuID = null;
 foreach (ManagementObject mo in moc)
 {
 strCpuID = mo.Properties["ProcessorId"].Value.ToString();
 break;
 }
 return strCpuID;

 }  第三步:編寫(xiě)注冊(cè)碼生成WinForm程序,使用CUP的編號(hào)來(lái)生成注冊(cè)碼,當(dāng)然你也可以用 WebForm來(lái)寫(xiě)。view plaincopy to clipboardprint?
using(RSACryptoServiceProvider rsa = new RSACryptoServiceProvider())   
{   
 rsa.FromXmlString(“私鑰”);   
 // 加密對(duì)象   
 RSAPKCS1SignatureFormatter f = new RSAPKCS1SignatureFormatter(rsa);   
 f.SetHashAlgorithm("SHA1");   
 byte[] source = System.Text.ASCIIEncoding.ASCII.GetBytes(“CUP的編號(hào)”);   
 SHA1Managed sha = new SHA1Managed();   
 byte[] result = sha.ComputeHash(source);   
   
 byte[] b = f.CreateSignature(result);   
   
msg.Text = Convert.ToBase64String(b); //這里就得到了string形式的注冊(cè)碼  
 
//再接下來(lái)你可以把生成的注冊(cè)碼保存成license.lic文件,license.lic文件也沒(méi)什么特別的格式就是相當(dāng)于把注冊(cè)嗎保存到一個(gè)txt文件中,無(wú)非這個(gè)txt文件的后綴改成了lic,你要高興也可保存成其它多種格式。  
//也可以保存在注冊(cè)表中或是web.config中,總之能讓你的發(fā)布的應(yīng)用程序能讀的到就行。  

using(RSACryptoServiceProvider rsa = new RSACryptoServiceProvider())
{
 rsa.FromXmlString(“私鑰”);
 // 加密對(duì)象
 RSAPKCS1SignatureFormatter f = new RSAPKCS1SignatureFormatter(rsa);
 f.SetHashAlgorithm("SHA1");
 byte[] source = System.Text.ASCIIEncoding.ASCII.GetBytes(“CUP的編號(hào)”);
 SHA1Managed sha = new SHA1Managed();
 byte[] result = sha.ComputeHash(source);
 
 byte[] b = f.CreateSignature(result);
 
msg.Text = Convert.ToBase64String(b); //這里就得到了string形式的注冊(cè)碼

//再接下來(lái)你可以把生成的注冊(cè)碼保存成license.lic文件,license.lic文件也沒(méi)什么特別的格式就是相當(dāng)于把注冊(cè)嗎保存到一個(gè)txt文件中,無(wú)非這個(gè)txt文件的后綴改成了lic,你要高興也可保存成其它多種格式。
//也可以保存在注冊(cè)表中或是web.config中,總之能讓你的發(fā)布的應(yīng)用程序能讀的到就行。
}  第四步:在發(fā)布的程序相關(guān)地方添加對(duì)注冊(cè)碼有效性的驗(yàn)證。如添加在程序啟動(dòng)的時(shí)候,程序執(zhí)行特定操作的時(shí)候等等,總之看你的需要做有效性的驗(yàn)證。view plaincopy to clipboardprint?
//相關(guān)注冊(cè)碼獲取代碼……  
//以下代碼是發(fā)布程序使用公鑰對(duì)注冊(cè)碼進(jìn)行驗(yàn)證  
using(RSACryptoServiceProvider rsa = new RSACryptoServiceProvider())   
{   
 rsa.FromXmlString(“公鑰”);   
 RSAPKCS1SignatureDeformatter f = new RSAPKCS1SignatureDeformatter(rsa);   
   
 f.SetHashAlgorithm("SHA1");   
   
 byte[] key = Convert.FromBase64String(“注冊(cè)碼”);   
   
 SHA1Managed sha = new SHA1Managed();   
 byte[] name = sha.ComputeHash(ASCIIEncoding.ASCII.GetBytes(“注冊(cè)碼”));   
 if(f.VerifySignature(name,key))   
 msg.Text = "驗(yàn)證成功"; //可以return true;等方式返回相應(yīng)的狀態(tài)  
 else   
 msg.Text = "不成功";   
}


發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 成人福利视频在线 | 综合精品视频 | 最新在线黄色网址 | 蜜桃视频最新网址 | 最新一级毛片 | 欧美日韩在线中文字幕 | 午夜视频大全 | 亚洲生活片 | 久久久久久免费 | 国产精品6区| 亚洲午夜免费 | ⅴideo裸体秀hd | av手机在线免费播放 | 国产精品热 | 久久久精品视 | 视频一区 日韩 | 一级成人在线 | 黄色片网站免费观看 | 黄wwww| 久久久久久久久成人 | 97zyz成人免费视频 | 黄色网址免费在线 | 亚洲黑人在线观看 | 99视频在线观看视频 | 亚洲第一成人在线观看 | 亚洲网站在线 | 国产99精品视频 | 欧美中文字幕一区二区三区亚洲 | 黄色成人短视频 | 成人午夜亚洲 | 久青草免费视频 | 哪里可以看免费的av | 久草资源在线观看 | 久久经典 | 黄色7777 | 日本视频免费观看 | www视频免费观看 | 国产精品美女久久久久久不卡 | 免费高清一级欧美片在线观看 | 久草在线观看首页 | 精品亚洲福利一区二区 |