欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C# 字符串处理小工具

程序员文章站 2023-11-18 20:27:58
之前刚上大学时沉迷于安全方面,当时一直想写一个处理字符串的小程序。 无奈当时没有太多时间,一直拖延到这寒假。 寒假闲来无事,所以就写写小程序来练手,顺便复习一下窗体和基...

之前刚上大学时沉迷于安全方面,当时一直想写一个处理字符串的小程序。

无奈当时没有太多时间,一直拖延到这寒假。

寒假闲来无事,所以就写写小程序来练手,顺便复习一下窗体和基础。

实现的功能有以下:

转换为大写

转换为小写

反转字符串

匹配某字符串出现次数

正则匹配

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。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!