成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

C#生成隨機的中文漢字的原理

開發 后端
本文介紹C#生成隨機的中文漢字,騰訊為了防止目前網絡上橫行的QQ號碼自動注冊機而采取中文驗證碼的手段。下面就來介紹一下使用C#生成隨機的中文漢字的原理。

C#生成隨機的中文漢字的原理

騰訊為了防止目前網絡上橫行的QQ號碼自動注冊機而采取中文驗證碼的手段。下面就來介紹一下使用C#生成隨機的中文漢字的原理。

1、漢字編碼原理

到底怎么辦到隨機生成漢字的呢?漢字從哪里來的呢?是不是有個后臺數據表,其中存放了所需要的所有漢字,使用程序隨機取出幾個漢字組合就行了呢?使用后臺數據庫先將所有漢字存起來使用時隨機取出,這也是一種辦法,但是中文漢字有這么多,怎么來制作呢?其實可以不使用任何后臺數據庫,使用程序就能做到這一切。要知道如何生成漢字,就得先了解中文漢字的編碼原理。

1980年,為了使每一個漢字有一個全國統一的代碼,我國頒布了***個漢字編碼的國家標準: GB2312-80《信息交換用漢字編碼字符集》基本集,簡稱GB2312,這個字符集是我國中文信息處理技術的發展基礎,也是國內所有漢字系統的統一標準。到了后來又公布了國家標準GB18030-2000《信息交換用漢字編碼字符集基本集的擴充》,簡稱GB18030,編程時如果涉及到編碼和本地化的朋友應該對GB18030很熟悉。這是是我國繼GB2312-1980和GB13000-1993之后最重要的漢字編碼標準,同時也是未來我國計算機系統必須遵循的基礎性標準之一。

目前在中文WINDOWS操作系統中,.NET編程中默認的的代碼頁就是GB18030簡體中文。但是事實上如果生成中文漢字驗證碼只須要使用GB2312字符集就已經足夠了。字符集中除了我們平時大家都認識的漢字外,也包含了很多我們不認識平時也很少見到的漢字。如果生成中文漢字驗證碼中有很多我們不認識的漢字讓我們輸入,對于使用拼音輸入法的朋友來說可不是好事,五筆使用者還能勉強根據漢字的長相打出來,呵呵!所以對于GB2312字符集中的漢字我們也不是全都要用。

其實這兩個表是同一回事,只不過一個使用十六進制分區表示,一個使用區位所在的數字位置表示。 例如“好”字的十六進制區位碼是ba c3,前兩位是區域,后兩位代表位置,ba處在第26區,“好”處在此區漢字的第35位也就是c3位置,所以數字代碼就是2635。這就是GB2312漢字區位原理。根據《漢字區位碼表》我們可以發現第15區也就是AF區以前都沒有漢字,只有少量符號,漢字都從第16區B0開始,這就是為什么GB2312字符集都是從16區開始的。

2、.Net程序處理漢字編碼原理分析

在.Net中可以使用System.Text來處理所有語言的編碼。在System.Text命名空間中包含眾多編碼的類,可供進行操作及轉換。其中的Encoding類就是重點處理漢字編碼的類。通過在.NET文檔中查詢Encoding類的方法我們可以發現所有和文字編碼有關的都是字節數組,其中有兩個很好用的方法:

Encoding.GetBytes ()方法將指定的 String 或字符數組的全部或部分內容編碼為字節數組
Encoding.GetString ()方法將指定字節數組解碼為字符串。


沒錯我們可以通過這兩個方法將漢字字符編碼為字節數組,同樣知道了漢字GB2312的字節數組編碼也就可以將字節數組解碼為漢字字符。通過對“好”字進行編碼為字節數組后

Encoding gb=System.Text.Encoding.GetEncoding("gb2312");
object[] bytes=gb.Encoding.GetBytes ("好");


發現得到了一個長度為2的字節數組bytes,使用

string lowCode = System.Convert.ToString(bytes[0], 16); //取出元素1編碼內容(兩位16進制)
string hightCode = System.Convert.ToString(bytes[1], 16);//取出元素2編碼內容(兩位16進制)


之后發現字節數組bytes16進制變碼后內容竟然是{ba,c3},剛好是“好”字的十六進制區位碼(見區位碼表)。

因此我們就可以隨機生成一個長度為2的十六進制字節數組,使用GetString ()方法對其進行解碼就可以得到漢字字符了。不過對于生成中文漢字驗證碼來說,因為第15區也就是AF區以前都沒有漢字,只有少量符號,漢字都從第16區 B0開始,并且從區位D7開始以后的漢字都是和很難見到的繁雜漢字,所以這些都要排出掉。所以隨機生成的漢字十六進制區位碼第1位范圍在B、C、D之間,如果第1位是D的話,第2位區位碼就不能是7以后的十六進制數。在來看看區位碼表發現每區的***個位置和***一個位置都是空的,沒有漢字,因此隨機生成的區位碼第3位如果是A的話,第4位就不能是0;第3位如果是F的話,第4位就不能是F。

好了,知道了原理,隨機生成中文漢字的程序也就出來了,以下就是生成4個隨機漢字的C#控制臺代碼:

  1. usingSystem;  
  2. usingSystem.Text;  
  3.  
  4. namespaceConsoleApplication  
  5. {  
  6. classChineseCode  
  7. {  
  8. publicstaticvoidMain()  
  9. {  
  10. //獲取GB2312編碼頁(表)  
  11. EncodingEncodinggb=Encoding.GetEncoding("gb2312");  
  12.  
  13. //調用函數產生4個隨機中文漢字編碼  
  14. object[]bytes=CreateRegionCode(4);  
  15.  
  16. //根據漢字編碼的字節數組解碼出中文漢字  
  17. stringstr1=gb.GetString((byte[])Convert.ChangeType(bytes[0],typeof(byte[])));  
  18. stringstr2=gb.GetString((byte[])Convert.ChangeType(bytes[1],typeof(byte[])));  
  19. stringstr3=gb.GetString((byte[])Convert.ChangeType(bytes[2],typeof(byte[])));  
  20. stringstr4=gb.GetString((byte[])Convert.ChangeType(bytes[3],typeof(byte[])));  
  21.  
  22. //輸出的控制臺  
  23. Console.WriteLine(str1+str2+str3+str4);  
  24. }  
  25.  
  26. publicstaticobject[]CreateRegionCode(intstrlength)  
  27. {  
  28. //定義一個字符串數組儲存漢字編碼的組成元素  
  29. string[]rBase=newString[16]{"0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"};  
  30.  
  31. Randomrnd=newRandom();  
  32.  
  33. //定義一個object數組用來  
  34. object[]bytes=newobject[strlength];  
  35.  
  36. for(inti=0;i<strlength;i++)  
  37. {  
  38. //區位碼第1位  
  39. intr1=rnd.Next(11,14);  
  40. stringstr_r1=rBase[r1].Trim();  
  41.  
  42. //區位碼第2位  
  43. rnd=newRandom(r1*unchecked((int)DateTime.Now.Ticks)+i);//更換隨機數發生器的  
  44.  
  45. 種子避免產生重復值  
  46. intr2;  
  47. if(r1==13)  
  48. {  
  49. r2=rnd.Next(0,7);  
  50. }  
  51. else  
  52. {  
  53. r2=rnd.Next(0,16);  
  54. }  
  55. stringstr_r2=rBase[r2].Trim();  
  56.  
  57. //區位碼第3位  
  58. rnd=newRandom(r2*unchecked((int)DateTime.Now.Ticks)+i);  
  59. intr3=rnd.Next(10,16);  
  60. stringstr_r3=rBase[r3].Trim();  
  61.  
  62. //區位碼第4位  
  63. rnd=newRandom(r3*unchecked((int)DateTime.Now.Ticks)+i);  
  64. intr4;  
  65. if(r3==10)  
  66. {  
  67. r4=rnd.Next(1,16);  
  68. }  
  69. elseif(r3==15)  
  70. {  
  71. r4=rnd.Next(0,15);  
  72. }  
  73. else  
  74. {  
  75. r4=rnd.Next(0,16);  
  76. }  
  77. stringstr_r4=rBase[r4].Trim();  
  78.  
  79. //定義兩個字節變量存儲產生的隨機漢字區位碼  
  80. bytebyte1=Convert.ToByte(str_r1+str_r2,16);  
  81. bytebyte2=Convert.ToByte(str_r3+str_r4,16);  
  82. //將兩個字節變量存儲在字節數組中  
  83. byte[]str_r=newbyte[]{byte1,byte2};  
  84.  
  85. //將產生的一個漢字的字節數組放入object數組中  
  86. bytes.SetValue(str_r,i);  
  87.  
  88. }  
  89.  
  90. returnbytes;  
  91.  
  92. }  
  93. }  
  94.  

以上介紹C#生成隨機的中文漢字的原理

【編輯推薦】

  1. 分析C#不安全代碼
  2. 淺析C#調用ImageAnimator
  3. C#連接Access、SQL Server數據庫
  4. 淺談C#固定的和活動的變量
  5. 介紹C#中的值類型
責任編輯:佚名 來源: IT168
相關推薦

2009-08-25 17:46:50

C#生成漢字編碼原理

2009-09-04 15:57:49

C#實現漢字之間互換

2020-10-16 08:30:00

foreach編程語言C#

2009-09-03 17:40:25

C#發送短信

2010-06-03 10:26:29

開發MySQL中文亂碼

2011-08-05 09:33:30

Func局部變量作用域

2009-09-10 16:41:13

C# get post

2024-03-06 08:52:59

C#Emit代碼

2023-09-04 11:46:09

C#動態代碼

2009-08-25 17:15:50

C#隱藏C#重寫C#重載

2010-06-02 16:36:38

連接MySQL中文亂碼

2010-06-12 11:19:59

MySQL中文亂碼

2009-09-10 09:42:53

C# TextBox

2009-09-07 14:29:47

C# Socket編程C# Socket

2009-08-07 17:04:41

C#數據庫

2009-08-04 13:31:35

C#自定義事件

2009-09-14 13:57:20

C# Lambda表達Lambda表達式

2024-04-01 13:08:24

唯一IDC#后端

2024-04-02 09:26:07

C#中文數字編程語言

2009-08-21 17:02:31

C#編寫數字轉換中文算
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品久久久久久久久久久久久久 | 国产一区二 | 国产一区二区精华 | 成人福利影院 | 一区二区高清 | 蜜桃臀av一区二区三区 | 久久久久1 | 成人在线视频免费观看 | 国产日韩精品一区二区三区 | 亚洲视频欧美视频 | 欧洲免费毛片 | 久久这里只有精品首页 | 国产视频久久久 | 久久久精品天堂 | 欧美黄色性生活视频 | 91精品国产91久久久久久吃药 | 精品久久久久久亚洲综合网 | 国产精品久久久久久婷婷天堂 | 国产视频精品在线观看 | 色综合久久天天综合网 | 精品一区二区三区四区 | 日韩插插| 韩国av一区二区 | 97国产超碰| 精品欧美一区二区久久久伦 | 天天拍天天射 | www.蜜桃av | 麻豆一区二区三区精品视频 | 中文字幕精品一区久久久久 | 日韩中文字幕av | 日韩一级免费大片 | 久久久资源 | 一区二区三区四区电影 | 亚洲综合大片69999 | 亚洲美乳中文字幕 | 久久99一区二区 | 日本精品裸体写真集在线观看 | 在线视频99 | 一区二区三区四区视频 | 91成人精品 | 网址黄 |