国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C# 字符串處理小工具

2020-01-24 00:44:15
字體:
來源:轉載
供稿:網友

之前剛上大學時沉迷于安全方面,當時一直想寫一個處理字符串的小程序。

無奈當時沒有太多時間,一直拖延到這寒假。

寒假閑來無事,所以就寫寫小程序來練手,順便復習一下窗體和基礎。

實現的功能有以下:

轉換為大寫

轉換為小寫

反轉字符串

匹配某字符串出現次數

正則匹配

base64加密

base64解密

ROT13加密解密

MD5 32位加密

程序還是非常簡陋的,沒有健壯性,也沒有輸入的校驗。

用心創造BUG(比心

還有請不要吐槽我的變量命名以及方法命名,如果你不是從小學開始學拼音肯定看不懂:)

因為一開始做這個是在瞎測試的項目里做起來的。

實在是懶得去翻譯了

轉換為大寫和小寫是有自帶的方法的

Console.WriteLine(s.ToUpper());//轉換成大寫Console.WriteLine(s.ToLower());//轉換成小寫

輸出反向字符串

public static void fanxiang(string s)  {   char[] arrey = s.ToCharArray();   StringBuilder s1 = new StringBuilder("");   for (int i = arrey.Length - 1; i >= 0; i--)   {    s1.Append(Convert.ToString(arrey[i]));   }   Console.WriteLine("反向字符串為{0}",s1);  }

查看某一短字符串在其中的數量

public static void pipei(string s)  {   int count = 0;   int i;   Console.WriteLine("請輸入短字符串");   string s2 = Console.ReadLine();   while ((i=s.IndexOf(s2)) >= 0)   {    count++;    s = s.Substring(i + s2.Length);   }   Console.WriteLine("字符串中出現了{0}次{1}", count, s2);  }

正則匹配

沒有學過正則類的知識,網上看了很多大部分都是講正則而不是正則類的。當時寫這個大概卡了一天,現在這個依然有BUG。

沒有匹配結果時,或者匹配到空?會造成多行換行。我也忘了當時是怎么測試出來的那個BUG。

哪位園友有想法可以說一下。

public static void zzpipei(string s)  {   Console.WriteLine("請輸入正則表達式");   string zz = Console.ReadLine();   Regex re = new Regex(zz);   string s2 = "";   if (re.IsMatch(s))   {    Console.WriteLine("匹配成功");    MatchCollection mc = re.Matches(s);    foreach (Match ma in mc)    {     s2 += ma.Value;     s2 += ("/r/n");    }    Console.WriteLine("一行為一個匹配結果");    Console.WriteLine(s2);   }   else   { Console.WriteLine("無匹配結果"); }  }

base64加密

使用的方法也是自帶的,對于漢字的加密和部分網站的加密不一樣。

 public static void basejiami(string s)  {   byte[] bytes = Encoding.Default.GetBytes(s);    Console.WriteLine("字符串base64加密為{0}", Convert.ToBase64String(bytes));  }

base64解密

 public static void basejiemi(string s)  {   byte[] bytes = Convert.FromBase64String(s);    Console.WriteLine("字符串base64解密為{0}", Encoding.Default.GetString(bytes));  }

ROT13加密解密

ROT13是一種簡易的置換暗碼。ROT13 也是過去在古羅馬開發的凱撒加密的一種變體。

ROT13是向后替換13位,即A轉為N,B轉為O以此類推。

凱撒密碼是向后替換3位。這個方法再改一下還可以實現凱撒密碼的爆破,而且該方法是區分大小寫的。

ROT13是它自己本身的逆反;也就是說,要還原ROT13,套用加密同樣的算法即可得,故同樣的操作可用再加密與解密。

該算法并沒有提供真正的密碼學上的保全,故它不應該套用在需要保全的用途上。它常常被當作弱加密示例的典型。

public static void rotjm(string s)  {   string jmzf = "";//解密加密后的字符串   char[] arrey = s.ToCharArray();   Console.WriteLine("字符串長度為{0}", arrey.Length);   for (int i = 0; i < arrey.Length; i++)   {    int zfcode = (int)arrey[i];    if (zfcode >= 97 && zfcode <= 109)     zfcode = zfcode + 13;    else if (zfcode >= 110 && zfcode <= 122)     zfcode = zfcode - 13;    else if (zfcode >= 65 && zfcode <= 77)     zfcode = zfcode + 13;    else if (zfcode >= 78 && zfcode <= 90)     zfcode = zfcode - 13;    jmzf = jmzf + (char)zfcode;   }   Console.WriteLine("結果為{0}", jmzf);  }

替換字符串

public static void thzf(string s)  {   Console.WriteLine("請輸入想要被替換的字符串");   string str1 = Console.ReadLine();   Console.WriteLine("請輸入想要替換成的字符串");   string str2 = Console.ReadLine();   Console.WriteLine(s.Replace(str1, str2));  }

32位MD5加密

public static void md5jm(string s)  {   MD5 md5 = new MD5CryptoServiceProvider();   //將字符編碼為字節序列   byte[] data = System.Text.Encoding.Default.GetBytes(s);   byte[] md5data = md5.ComputeHash(data);   md5.Clear();   //遍歷加密數組,加密字節,該方法為32位加密   string str = "";   for (int i = 0; i < md5data.Length; i++)   {    str += md5data[i].ToString("x").PadLeft(2, '0');   }   Console.WriteLine("加密結果為{0}",str);  }

我的程序,使用.NET framework 4.0。

下載

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 北川| 襄樊市| 唐河县| 承德县| 阳西县| 乌鲁木齐市| 曲阳县| 通化县| 鸡西市| 夏邑县| 丹寨县| 霍州市| 福建省| 阿坝县| 三原县| 安多县| 甘洛县| 偃师市| 襄城县| 抚松县| 中江县| 青阳县| 邵武市| 且末县| 黄骅市| 汕头市| 沾化县| 聂拉木县| 湘潭县| 三河市| 武清区| 旅游| 沽源县| 泸西县| 定结县| 巩义市| 新兴县| 河津市| 贺州市| 扶余县| 双城市|