C# 字符串處理小工具
之前剛上大學時沉迷于安全方面,當時一直想寫一個處理字符串的小程序。
無奈當時沒有太多時間,一直拖延到這寒假。
寒假閑來無事,所以就寫寫小程序來練手,順便復習一下窗體和基礎。
實現(xiàn)的功能有以下:
轉換為大寫
轉換為小寫
反轉字符串
匹配某字符串出現(xiàn)次數(shù)
正則匹配
base64加密
base64解密
ROT13加密解密
MD5 32位加密
程序還是非常簡陋的,沒有健壯性,也沒有輸入的校驗。
用心創(chuàng)造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);
}
查看某一短字符串在其中的數(shù)量
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("字符串中出現(xiàn)了{0}次{1}", count, s2);
}
正則匹配
沒有學過正則類的知識,網上看了很多大部分都是講正則而不是正則類的。當時寫這個大概卡了一天,現(xiàn)在這個依然有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 也是過去在古羅馬開發(fā)的凱撒加密的一種變體。
ROT13是向后替換13位,即A轉為N,B轉為O以此類推。
凱撒密碼是向后替換3位。這個方法再改一下還可以實現(xiàn)凱撒密碼的爆破,而且該方法是區(qū)分大小寫的。
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();
//將字符編碼為字節(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("加密結果為{0}",str);
}
我的程序,使用.NET framework 4.0。
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關文章
C#從數(shù)據庫讀取數(shù)據到DataSet并保存到xml文件的方法
這篇文章主要介紹了C#從數(shù)據庫讀取數(shù)據到DataSet并保存到xml文件的方法,涉及C#操作DataSet保存到XML文件的技巧,需要的朋友可以參考下2015-04-04
C#使用ICSharpCode.SharpZipLib.dll進行文件的壓縮與解壓功能
這篇文章主要介紹了C#使用ICSharpCode.SharpZipLib.dll進行文件的壓縮與解壓功能,需要的朋友可以參考下2017-12-12

