久久精品99久久|国产剧情网站91|天天色天天干超碰|婷婷五天月一av|亚州特黄一级片|亚欧超清无码在线|欧美乱码一区二区|男女拍拍免费视频|加勒比亚无码人妻|婷婷五月自拍偷拍

信息安全畢業(yè)論文

軟件設計中用戶身份的認證方法

時間:2022-10-05 18:09:04 信息安全畢業(yè)論文 我要投稿
  • 相關推薦

軟件設計中用戶身份的認證方法

  軟件設計中用戶身份的認證方法

  摘要:介紹幾種在計算機軟件系統(tǒng)設計中常用的用戶身份認證方法,著重闡述了采集用戶硬件信息的方法,對程序設計人員設計應用程序有一定借鑒作用。

  關鍵詞:計算機軟件;身份認證;用戶識別;信息采集

  用戶身份的認證和識別,是設計計算機應用程序所必須考慮的因素,因為軟件開發(fā)者需要通過識別用戶來進行軟件注冊、升級及授權等服務。

  一、幾種用戶認證方法

  目前,獲得用戶身份的方法主要有以下幾種。

  1、由用戶自己提交個人信息進行認證。一些軟件通過使用者自己提交相關信息,這些信息包含用戶姓名、E-mail地址等,并以此數(shù)據(jù)作為軟件提供服務的關鍵信息。這種方法的優(yōu)點是簡單、易實現(xiàn)。但這種方法的弱點也很明顯,即不能確保信息的真實性,也不能阻止使用者把獲得的信息與他人共享。

  即一個使用者獲得了注冊信息后,可以將注冊信息與親戚朋友共享,那么這些人都能使用此軟件了。糟糕的情況是使用者將注冊信息發(fā)布到網(wǎng)絡上,后果更是難以預計。

  2、由程序自動采集用戶信息進行認證。為了防止軟件被非法用戶自由使用,開發(fā)者可以使用程序來采集使用者計算機的一些相關信息。這些信息是使用者的計算機所特有的、不會輕易改變的,如硬盤序列號、CPU標識號等,開發(fā)者可以把這些信息與軟件綁定到使用者的機器上執(zhí)行。

  例如Windows XP的注冊就是使用了這種方法。這種方法的優(yōu)點是可以防止軟件隨意傳播,但如果用戶硬件更換,可能會使注冊信息失效。

  3、由特定的硬件提供信息認證用戶。使用加密鎖、身份認證Token、動態(tài)口令生成器等硬件產(chǎn)品來提供信息。利用硬件的不可復制性,把硬件和軟件捆綁在一起,利用硬件里面的唯一性的識別信息來識別用戶身份。這種方法安全性好,但成本相對較高。

  二、用戶信息的采集

  在實際應用中,使用的認證方法往往不是單一的,而是混合實施。對于個人開發(fā)者而言,要設計一個軟件系統(tǒng),為了既提高安全性,又降低成本,主要采用第二種方法。

  每臺計算機的CPU ID、硬盤序列號、顯卡型號、網(wǎng)卡的MAC地址等信息是不同的,把多種信息組合起來后,信息相同的概率就更低了,這些就是開發(fā)者需要采集的信息。

  1、獲取網(wǎng)卡的MAC地址。網(wǎng)卡的MAC地址是網(wǎng)卡的唯一標志,它是固化在網(wǎng)卡串行EEPROM中的物理地址,以太網(wǎng)交換機就是根據(jù)信息包頭中的MAC源地址和目的地址實現(xiàn)包的交換和傳遞的。理論上講,不存在2塊網(wǎng)卡的MAC完全相同,這點非常適合用于用戶的身份認證。

  在Windows操作系統(tǒng)下,在DOS窗口中運行ipconfig/all命令,就可以查看本機的網(wǎng)卡MAC地址,如顯示為:Physical Address:00――14――2A――6F――47――1A。

  在Windows XP系統(tǒng)下,可以使用系統(tǒng)提供的NetApi32.DLL功能,實現(xiàn)網(wǎng)卡信息的采集。方法為:(1)使用NCBENUM命令獲得網(wǎng)卡的數(shù)目和每塊網(wǎng)卡的內部編號;(2)使用NCBASTAT命令獲取每塊網(wǎng)卡的MAC地址。下面是部分程序源碼,詳細信息參見相關資料。

  typedef struct _ASTAT_

  {

  ADAPTER_STATUS adapt;

  NAME_BUFFER NameBuff[30];

  }ASTAT,*PASTAT;

  ASTAT Adapter;

  void main()

  {

  NCB ncb;

  UCHAR uRetCode;

  LANA_ENUM lenum;

  //向網(wǎng)卡發(fā)送NCBENUM命令,以獲取當前機器的網(wǎng)卡信息,如有多少個網(wǎng)卡、每張網(wǎng)卡的編號等。

  memset(&ncb,0,sizeof(ncb));

  ncb.ncb_command=NCBENUM;

  ncb.ncb_buffer=(unsigned char*)&lenum;

  ncb.ncb_length=sizeof(lenum);

  uRetCode=Netbios(&ncb);

  if(uRetCode!=0)return;

  //對每一張網(wǎng)卡,通過其網(wǎng)卡編號,獲取其MAC地址

  //網(wǎng)卡編號,一般從0開始,但在Windows 2000中并不一定是連續(xù)分配的

  For(int i=0;i  {

  //首先對選定的網(wǎng)卡發(fā)送一個NCBRESET命令,以便進行初始化

  Memset(&ncb,0,sizeof(ncb));

  ncb.ncb_command=NCBRESET;

  ncb.ncb_lana_num=lenum.lana[i];//指定網(wǎng)卡號

  uRetCode=Netbios(&ncb);

  //接著,可以發(fā)送NCBASTAT命令以獲取網(wǎng)卡的信息

  Memset(&ncb,0,sizeof(ncb));

  ncb.ncb_command=NCBASTAT;

  ncb.ncb_lana_num=lenum.lana[i];//指定網(wǎng)卡號

  strcpy((char *)ncb.ncb_callname,“*”);

  ncb.ncb_buffer=(unsigned char *)&Adapter;//指定返回的信息存放的變量

  ncb.ncb_length=sizeof(Adapter);

  uRetCode = Netbios(&ncb);

  }

  }

  此時,按F7編譯直至通過,按F5運行即可。這段代碼可以直接嵌入相關的應用系統(tǒng)之中,或封裝成.DLL或COM控件,以便可以在Visual Basic、Visual Foxpro、Power Builder或Delphi等其他程序中調用。

  2、獲取CPU信息。以前的CPU型號有很多是相同的,但在Pentium III后,Intel公司為了安全交易和資產(chǎn)追蹤,為每個處理器增加了一個唯一的序列號,這是我們希望獲取的信息。在CPU指令集中,指令cupid被設計用來獲取CPU有關的信息,關于這一指令的說明,可以參見相關資料,這里不再詳細介紹。下面是用C語言編寫的一段功能實現(xiàn)源碼,用于識別CPU信息,并顯示出來。

  {

  PROCESSOR_SIGNATURE ps;

  FEATURE_FLAGS ff;

  MISC_INFO mi;

  _asm

  {

  mov eax,1

  cupid

  mov ps,eax

  mov mi,ebx

  mov ff,edx

  }

  printf(“Processor Type:%d\n”,ps.ProcessorType);

  printf(“Model Number:%d\n”,ps.ModelNumber);

  printf(“Family Code:%d\n”,ps.FamilyCode);

  printf(“Extended Model:%d\n”,ps.ExtendedModel);

  printf(“Extended Family:%d\n”,ps.ExtendedFamily);

  printf(“Stepping ID:%d\n”,ps.SteppingID);

  printf(“Brand ID:%d\n”,mi.BrandID);

  if(ff.MMX) printf(“Support MMX\n”);

  if(ff.SSE)printf(“Support SSE\n”);

  if(ff.SSE2)printf(“Support SSE2\n”);

  if(ff.PSN)printf(“Support processor serial number\n”);

  }

  以上功能可以獲取CPU的緩存信息,顯示緩存的聯(lián)合多路工作狀態(tài)、緩存入口和標準標簽的數(shù)目等,都可以作為識別CPU的標志,而CPU的序列號(processor serial number)是每個CPU的不變標識。

  3、獲取硬盤序列號。大多數(shù)計算機中都配有硬盤,但由于其有損壞而被更換的可能性,所以其信息的可靠性要低于CPU信息。在網(wǎng)上能夠找到很多獲得硬盤序列號的程序,但大多數(shù)不是我們所需要的。

  如果在DOS窗口下輸入Dir/p命令,我們就能看到”Volume Serial Number is xxxx-xxxx”這樣的信息,很多程序取得的就是這個信息,而這是格式化程序產(chǎn)生并保存在硬盤上的一個信息,即”邏輯硬盤序列號”,不是我們所要的,我們要獲得硬盤廠商提供的信息,由于程序比較復雜,限于篇幅,就不再詳細介紹了,有興趣的朋友可以進一步研究。

【軟件設計中用戶身份的認證方法】相關文章:

最新電話用戶真實身份信息登記規(guī)定05-27

智能終端中的應用軟件設計中的光傳感器10-26

科學家們認證的學習方法10-06

淺析電子商務中的身份鑒別技術論文10-08

通信工程研究生認證方法論文10-08

論語中的學習方法10-06

Maven在Eclipse中配置方法10-05

《高級英語》中族裔文化身份與文化認同研究論文10-12

軟件設計辭職報告03-16

用戶報告模板04-26