当前位置:
首页 > temp > 简明python教程 >
-
C#tools(2)
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
}
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数