-
C#教程之C#tools(2)
本站最新发布 C#从入门到精通
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
String ToTxt(String Input) { StringBuilder sb = new StringBuilder(Input); sb.Replace(" ", " "); sb.Replace("<br>", "\r\n"); sb.Replace("<br>", "\n"); sb.Replace("<br />", "\n"); sb.Replace("<br />", "\r\n"); sb.Replace("<", "<"); sb.Replace(">", ">"); sb.Replace("&", "&"); return sb.ToString(); } #endregion #region 检测是否有Sql危险字符 /// <summary> /// 检测是否有Sql危险字符 /// </summary> /// <param name="str">要判断字符串</param> /// <returns>判断结果</returns> public static bool IsSafeSqlString(string str) { return !Regex.IsMatch(str, @"[-|;|,|\/|\(|\)|\[|\]|\}|\{|%|@|\*|!|\']"); } /// <summary> /// 检查危险字符 /// </summary> /// <param name="Input"></param> /// <returns></returns> public static string Filter(string sInput) { if (sInput == null || sInput == "") return null; string sInput1 = sInput.ToLower(); string output = sInput; string pattern = @"*|and|exec|insert|select|delete|update|count|master|truncate|declare|char(|mid(|chr(|'"; if (Regex.Match(sInput1, Regex.Escape(pattern), RegexOptions.Compiled | RegexOptions.IgnoreCase).Success) { throw new Exception("字符串中含有非法字符!"); } else { output = output.Replace("'", "''"); } return output; } /// <summary> /// 检查过滤设定的危险字符 /// </summary> /// <param name="InText">要过滤的字符串 </param> /// <returns>如果参数存在不安全字符,则返回true </returns> public static bool SqlFilter(string word, string InText) { if (InText == null) return false; foreach (string i in word.Split('|')) { if ((InText.ToLower().IndexOf(i + " ") > -1) || (InText.ToLower().IndexOf(" " + i) > -1)) { return true; } } return false; } #endregion #region 过滤特殊字符 /// <summary> /// 过滤特殊字符 /// </summary> /// <param name="Input"></param> /// <returns></returns> public static string Htmls(string Input) { if (Input != string.Empty && Input != null) { string ihtml = Input.ToLower(); ihtml = ihtml.Replace("<script", "<script"); ihtml = ihtml.Replace("script>", "script>"); ihtml = ihtml.Replace("<%", "<%"); ihtml = ihtml.Replace("%>", "%>"); ihtml = ihtml.Replace("<$", "<$"); ihtml = ihtml.Replace("$>", "$>"); ihtml = ihtml.Replace("'", "'"); ihtml = ihtml.Replace("\"", """); ihtml = ihtml.Replace("<", "<"); ihtml = ihtml = ihtml.Replace(">", ">"); ihtml = ihtml.Replace("\r", "\\\r"); ihtml = ihtml.Replace("\n", "\\\n"); ihtml = ihtml.Replace("\t", " "); return ihtml; } else { return string.Empty; } } #endregion #region 检查是否为IP地址 /// <summary> /// 是否为ip /// </summary> /// <param name="ip"></param> /// <returns></returns> public static bool IsIP(string ip) { return Regex.IsMatch(ip, @"^((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)$"); } #endregion #region 替换指定的字符串 /// <summary> /// 替换指定的字符串 /// </summary> /// <param name="originalStr">原字符串</param> /// <param name="oldStr">旧字符串</param> /// <param name="newStr">新字符串</param> /// <returns></returns> public static string ReplaceStr(string originalStr, string oldStr, string newStr) { if (string.IsNullOrEmpty(oldStr)) { return ""; } return originalStr.Replace(oldStr, newStr); } #endregion #region DATS转换城datetime /// <summary> /// 替换指定的DATS转换城datetime /// </summary> /// <param name="DatsStr">原字符串</param> /// <returns></returns> public static DateTime ReplaceDats(string datsStr) { DateTime datsTime = DateTime.MinValue; if (!string.IsNullOrEmpty(datsStr)) { if (datsStr.Trim().Length == 8) { string year = datsStr.Remove(4); string month = datsStr.Substring(4).Remove(2); string day = datsStr.Substring(4).Substring(2); datsTime = new DateTime(int.Parse(year), int.Parse(month), int.Parse(day)); } } return datsTime; } /// <summary> /// 获取枚举的特性 /// </summary> /// <param name="t"></param> /// <returns></returns> public static string DisplayEnum(Enum t) { var t_type = t.GetType(); var fieldName = Enum.GetName(t_type, t); var attributes = t_type.GetField(fieldName).GetCustomAttributes(false); var enumDisplayAttribute = attributes.FirstOrDefault(p => p.GetType().Equals(typeof(DisplayAttribute))) as DisplayAttribute; return enumDisplayAttribute == null ? fieldName : enumDisplayAttribute.Display; } /// <summary> /// 根据特性获取枚举 /// </summary> /// <param name="t"></param> /// <returns></returns> public static object DisplayEnum<T>(string code) { var t_type = typeof(T); var field = Enum.GetValues(typeof(T)).OfType<T>().ToList(); var attributes = t_type.GetFields().Select(x => new { attr = x.GetCustomAttributes(false).FirstOrDefault(y=>y.GetType().Equals(typeof(DisplayAttribute))) as DisplayAttribute, enu = x }).Where(x=>x.attr !=null); var enumValue = attributes.Where(x => x.attr.Display == code).FirstOrDefault(); if (enumValue != null) { return Enum.Parse(t_type, enumValue.enu.Name); } return null; } #endregion #region 获取GUID /// <summary> /// 获取32位的GUID /// </summary> /// <returns></returns> public static string GetGuid() { return Guid.NewGuid().ToString().Replace("-", "").ToUpper(); } /// <summary> /// 获取36位的GUID /// </summary> /// <returns></returns> public static string GetGuidLong() { return Guid.NewGuid().ToString().ToUpper(); } #endregion }
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
String ToTxt(String Input) { StringBuilder sb = new StringBuilder(Input); sb.Replace(" ", " "); sb.Replace("<br>", "\r\n"); sb.Replace("<br>", "\n"); sb.Replace("<br />", "\n"); sb.Replace("<br />", "\r\n"); sb.Replace("<", "<"); sb.Replace(">", ">"); sb.Replace("&", "&"); return sb.ToString(); } #endregion #region 检测是否有Sql危险字符 /// <summary> /// 检测是否有Sql危险字符 /// </summary> /// <param name="str">要判断字符串</param> /// <returns>判断结果</returns> public static bool IsSafeSqlString(string str) { return !Regex.IsMatch(str, @"[-|;|,|\/|\(|\)|\[|\]|\}|\{|%|@|\*|!|\']"); } /// <summary> /// 检查危险字符 /// </summary> /// <param name="Input"></param> /// <returns></returns> public static string Filter(string sInput) { if (sInput == null || sInput == "") return null; string sInput1 = sInput.ToLower(); string output = sInput; string pattern = @"*|and|exec|insert|select|delete|update|count|master|truncate|declare|char(|mid(|chr(|'"; if (Regex.Match(sInput1, Regex.Escape(pattern), RegexOptions.Compiled | RegexOptions.IgnoreCase).Success) { throw new Exception("字符串中含有非法字符!"); } else { output = output.Replace("'", "''"); } return output; } /// <summary> /// 检查过滤设定的危险字符 /// </summary> /// <param name="InText">要过滤的字符串 </param> /// <returns>如果参数存在不安全字符,则返回true </returns> public static bool SqlFilter(string word, string InText) { if (InText == null) return false; foreach (string i in word.Split('|')) { if ((InText.ToLower().IndexOf(i + " ") > -1) || (InText.ToLower().IndexOf(" " + i) > -1)) { return true; } } return false; } #endregion #region 过滤特殊字符 /// <summary> /// 过滤特殊字符 /// </summary> /// <param name="Input"></param> /// <returns></returns> public static string Htmls(string Input) { if (Input != string.Empty && Input != null) { string ihtml = Input.ToLower(); ihtml = ihtml.Replace("<script", "<script"); ihtml = ihtml.Replace("script>", "script>"); ihtml = ihtml.Replace("<%", "<%"); ihtml = ihtml.Replace("%>", "%>"); ihtml = ihtml.Replace("<$", "<$"); ihtml = ihtml.Replace("$>", "$>"); ihtml = ihtml.Replace("'", "'"); ihtml = ihtml.Replace("\"", """); ihtml = ihtml.Replace("<", "<"); ihtml = ihtml = ihtml.Replace(">", ">"); ihtml = ihtml.Replace("\r", "\\\r"); ihtml = ihtml.Replace("\n", "\\\n"); ihtml = ihtml.Replace("\t", " "); return ihtml; } else { return string.Empty; } } #endregion #region 检查是否为IP地址 /// <summary> /// 是否为ip /// </summary> /// <param name="ip"></param> /// <returns></returns> public static bool IsIP(string ip) { return Regex.IsMatch(ip, @"^((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)$"); } #endregion #region 替换指定的字符串 /// <summary> /// 替换指定的字符串 /// </summary> /// <param name="originalStr">原字符串</param> /// <param name="oldStr">旧字符串</param> /// <param name="newStr">新字符串</param> /// <returns></returns> public static string ReplaceStr(string originalStr, string oldStr, string newStr) { if (string.IsNullOrEmpty(oldStr)) { return ""; } return originalStr.Replace(oldStr, newStr); } #endregion #region DATS转换城datetime /// <summary> /// 替换指定的DATS转换城datetime /// </summary> /// <param name="DatsStr">原字符串</param> /// <returns></returns> public static DateTime ReplaceDats(string datsStr) { DateTime datsTime = DateTime.MinValue; if (!string.IsNullOrEmpty(datsStr)) { if (datsStr.Trim().Length == 8) { string year = datsStr.Remove(4); string month = datsStr.Substring(4).Remove(2); string day = datsStr.Substring(4).Substring(2); datsTime = new DateTime(int.Parse(year), int.Parse(month), int.Parse(day)); } } return datsTime; } /// <summary> /// 获取枚举的特性 /// </summary> /// <param name="t"></param> /// <returns></returns> public static string DisplayEnum(Enum t) { var t_type = t.GetType(); var fieldName = Enum.GetName(t_type, t); var attributes = t_type.GetField(fieldName).GetCustomAttributes(false); var enumDisplayAttribute = attributes.FirstOrDefault(p => p.GetType().Equals(typeof(DisplayAttribute))) as DisplayAttribute; return enumDisplayAttribute == null ? fieldName : enumDisplayAttribute.Display; } /// <summary> /// 根据特性获取枚举 /// </summary> /// <param name="t"></param> /// <returns></returns> public static object DisplayEnum<T>(string code) { var t_type = typeof(T); var field = Enum.GetValues(typeof(T)).OfType<T>().ToList(); var attributes = t_type.GetFields().Select(x => new { attr = x.GetCustomAttributes(false).FirstOrDefault(y=>y.GetType().Equals(typeof(DisplayAttribute))) as DisplayAttribute, enu = x }).Where(x=>x.attr !=null); var enumValue = attributes.Where(x => x.attr.Display == code).FirstOrDefault(); if (enumValue != null) { return Enum.Parse(t_type, enumValue.enu.Name); } return null; } #endregion #region 获取GUID /// <summary> /// 获取32位的GUID /// </summary> /// <returns></returns> public static string GetGuid() { return Guid.NewGuid().ToString().Replace("-", "").ToUpper(); } /// <summary> /// 获取36位的GUID /// </summary> /// <returns></returns> public static string GetGuidLong() { return Guid.NewGuid().ToString().ToUpper(); } #endregion }
栏目列表
最新更新
C#基于接口设计三层架构Unity篇
C#线程 入门
C#读取静态类常量属性和值
C# 插件式编程
C# 委托与事件有啥区别?
C#队列学习笔记:队列(Queue)和堆栈(Stack
linq 多表分组左连接查询查询统计
C#队列学习笔记:MSMQ入门一
C# 基础知识系列- 1 数据类型
二、C#入门—基础语法
C# 在Word中添加Latex 数学公式和符号
inncheck命令 – 检查语法
基于UDP的服务器端和客户端
再谈UDP和TCP
在socket编程中使用域名
网络数据传输时的大小端问题
socket编程实现文件传输功能
如何优雅地断开TCP连接?
图解TCP四次握手断开连接
详细分析TCP数据的传输过程
SqlServer 利用游标批量更新数据
BOS只读状态修改
SQL Server等待事件—PAGEIOLATCH_EX
数据库多行转换为单一列
获取数据表最后最后访问,修改,更新,
计算经历的时间
SQL查询结果自定义排序
修改数据库默认位置
日期简单加或减
从日期获取年,月或日