本文主要介紹C#字符串處理小工具,實(shí)現(xiàn)功能包括:轉(zhuǎn)換為大寫(xiě);轉(zhuǎn)換為小寫(xiě);反轉(zhuǎn)字符串;匹配某字符串出現(xiàn)次數(shù);正則匹配;base64加密;base64解密;ROT13加密解密;MD5 32位加密。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧之前剛上大學(xué)時(shí)沉迷于安全方面,當(dāng)時(shí)一直想寫(xiě)一個(gè)處理字符串的小程序。 無(wú)奈當(dāng)時(shí)沒(méi)有太多時(shí)間,一直拖延到這寒假。 寒假閑來(lái)無(wú)事,所以就寫(xiě)寫(xiě)小程序來(lái)練手,順便復(fù)習(xí)一下窗體和基礎(chǔ)。 實(shí)現(xiàn)的功能有以下: 轉(zhuǎn)換為大寫(xiě) 轉(zhuǎn)換為小寫(xiě) 反轉(zhuǎn)字符串 匹配某字符串出現(xiàn)次數(shù) 正則匹配 base64加密 base64解密 ROT13加密解密 MD5 32位加密 程序還是非常簡(jiǎn)陋的,沒(méi)有健壯性,也沒(méi)有輸入的校驗(yàn)。 用心創(chuàng)造BUG(比心 還有請(qǐng)不要吐槽我的變量命名以及方法命名,如果你不是從小學(xué)開(kāi)始學(xué)拼音肯定看不懂:) 因?yàn)橐婚_(kāi)始做這個(gè)是在瞎測(cè)試的項(xiàng)目里做起來(lái)的。 實(shí)在是懶得去翻譯了 轉(zhuǎn)換為大寫(xiě)和小寫(xiě)是有自帶的方法的 Console.WriteLine(s.ToUpper());//轉(zhuǎn)換成大寫(xiě) Console.WriteLine(s.ToLower());//轉(zhuǎn)換成小寫(xiě) 輸出反向字符串 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); } 查看某一短字符串在其中的數(shù)量 public static void pipei(string s) { int count = 0; int i; Console.WriteLine("請(qǐng)輸入短字符串"); string s2 = Console.ReadLine(); while ((i=s.IndexOf(s2)) >= 0) { count++; s = s.Substring(i + s2.Length); } Console.WriteLine("字符串中出現(xiàn)了{(lán)0}次{1}", count, s2); } 正則匹配 沒(méi)有學(xué)過(guò)正則類(lèi)的知識(shí),網(wǎng)上看了很多大部分都是講正則而不是正則類(lèi)的。當(dāng)時(shí)寫(xiě)這個(gè)大概卡了一天,現(xiàn)在這個(gè)依然有BUG。 沒(méi)有匹配結(jié)果時(shí),或者匹配到空?會(huì)造成多行換行。我也忘了當(dāng)時(shí)是怎么測(cè)試出來(lái)的那個(gè)BUG。 哪位園友有想法可以說(shuō)一下。 public static void zzpipei(string s) { Console.WriteLine("請(qǐng)輸入正則表達(dá)式"); 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("一行為一個(gè)匹配結(jié)果"); Console.WriteLine(s2); } else { Console.WriteLine("無(wú)匹配結(jié)果"); } } base64加密 使用的方法也是自帶的,對(duì)于漢字的加密和部分網(wǎng)站的加密不一樣。 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是一種簡(jiǎn)易的置換暗碼。ROT13 也是過(guò)去在古羅馬開(kāi)發(fā)的凱撒加密的一種變體。 ROT13是向后替換13位,即A轉(zhuǎn)為N,B轉(zhuǎn)為O以此類(lèi)推。 凱撒密碼是向后替換3位。這個(gè)方法再改一下還可以實(shí)現(xiàn)凱撒密碼的爆破,而且該方法是區(qū)分大小寫(xiě)的。 ROT13是它自己本身的逆反;也就是說(shuō),要還原ROT13,套用加密同樣的算法即可得,故同樣的操作可用再加密與解密。 該算法并沒(méi)有提供真正的密碼學(xué)上的保全,故它不應(yīng)該套用在需要保全的用途上。它常常被當(dāng)作弱加密示例的典型。 public static void rotjm(string s) { string jmzf = "";//解密加密后的字符串 char[] arrey = s.ToCharArray(); Console.WriteLine("字符串長(zhǎng)度為{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("結(jié)果為{0}", jmzf); } 替換字符串 public static void thzf(string s) { Console.WriteLine("請(qǐng)輸入想要被替換的字符串"); string str1 = Console.ReadLine(); Console.WriteLine("請(qǐng)輸入想要替換成的字符串"); string str2 = Console.ReadLine(); Console.WriteLine(s.Replace(str1, str2)); } 32位MD5加密 public static void md5jm(string s) { MD5 md5 = new MD5CryptoServiceProvider(); //將字符編碼為字節(jié)序列 byte[] data = System.Text.Encoding.Default.GetBytes(s); byte[] md5data = md5.ComputeHash(data); md5.Clear(); //遍歷加密數(shù)組,加密字節(jié),該方法為32位加密 string str = ""; for (int i = 0; i < md5data.Length; i++) { str += md5data[i].ToString("x").PadLeft(2, '0'); } Console.WriteLine("加密結(jié)果為{0}",str); } 我的程序,使用.NET framework 4.0。 以上就是C#字符串處理小工具的詳細(xì)介紹的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章! 文章來(lái)源:https://www./faq/357095.html |
|
來(lái)自: k哥愛(ài)分享 > 《應(yīng)用文》