本文主要介紹C#字串處理小工具,實作功能包括:轉換為大寫;轉換為小寫;反轉字串;符合某字串出現次數;正規匹配;base64加密;base64解密;ROT13加密解密;MD5 32位元加密。具有很好的參考價值。下面跟著小編一起來看下吧
之前剛上大學時沉迷於安全方面,當時一直想寫一個處理字符串的小程式。
無奈當時沒有太多時間,一直拖延到這寒假。
寒假閒來無事,所以就寫寫小程式來練手,順便複習一下窗體和基礎。
實作的功能有以下:
轉換成大寫
轉換成小寫
反轉字串
#符合某字串出現次數
#正規符合
#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。
以上是C#字串處理小工具的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!