using System.Globalization;
using System.Text;
using System.Text.RegularExpressions;
namespace DS.Module.Core.Extensions;
public static class StringExtensions
{
///
/// sql
///
///
///
public static bool IsSqlInjection(this string input)
{
string[] sqlCheckList = { "TRUNCATE", "INSERT", "UPDATE", "DELETE", "DROP", "--" };
foreach (string item in sqlCheckList)
{
if (input.IndexOf(item, StringComparison.OrdinalIgnoreCase) >= 0)
{
return true;
}
}
return false;
}
///
/// 以指定字符串作为分隔符将指定字符串分隔成数组
///
/// 要分割的字符串
/// 字符串类型的分隔符
/// 是否移除数据中元素为空字符串的项
/// 分割后的数据
public static string[] Split(this string value, string strSplit, bool removeEmptyEntries = false)
{
value.NotNullOrEmpty(nameof(value));
strSplit.NotNullOrEmpty(nameof(strSplit));
return value.Split(new[] { strSplit },
removeEmptyEntries ? StringSplitOptions.RemoveEmptyEntries : StringSplitOptions.None);
}
///
/// 将字符中拼接
///
///
///
///
///
///
public static string StrToJoin(this string value, string left, string right, string separator = ",")
{
value.NotNullOrEmpty(nameof(value));
left.NotNullOrEmpty(nameof(left));
right.NotNullOrEmpty(nameof(right));
StringBuilder sb = new StringBuilder();
if (!value.IsNullOrEmpty())
{
foreach (var item in value.Split(separator))
{
sb.AppendFormat("{0}{1}{2}{3}", left, item, right, separator);
}
}
return sb.ToString().TrimEnd(separator.ToCharArray());
}
///
///把字符串转成SQL中IN
///
/// 要转换的值
/// 左边符
/// 右边符
/// in里面中间分割符:"'a','b'"
/// 值分割符如:"a,b,c,d"
/// 返回组装好的值,例如"'a','b'"
public static string ToSqlIn(this string value, string left = "'", string right = "'",
string inMiddleSeparator = ",",
string valueSeparator = ",")
{
value.NotNullOrEmpty(nameof(value));
StringBuilder sb = new StringBuilder();
if (!value.IsNullOrEmpty())
{
foreach (var item in value.Split(valueSeparator))
{
sb.AppendFormat("{0}{1}{2}{3}", left, item, right, inMiddleSeparator);
}
}
else
{
return value;
}
return sb.ToString().TrimEnd(inMiddleSeparator.ToCharArray());
}
///
/// 是否为空或者为null或者空格
///
/// 要判断的值
/// 返回true/false
public static bool IsNullOrWhiteSpace(this string value)
{
return string.IsNullOrWhiteSpace(value);
}
///
/// 是否为空或者为null
///
/// 要判断的值
/// 返回true/false
public static bool IsNullOrEmpty(this string value)
{
return string.IsNullOrEmpty(value);
}
///
/// 判断是否数字
///
///
///
public static bool IsInt(this string value)
{
return Regex.IsMatch(value, @"^[0-9]*$");
}
///
/// 在指定的输入字符串中搜索指定的正则表达式的第一个匹配项
///
/// 要搜索匹配项的字符串
/// 要匹配的正则表达式模式
/// 一个对象,包含有关匹配项的信息
public static string Match(this string value, string pattern)
{
if (value == null)
{
return null;
}
return Regex.Match(value, pattern).Value;
}
public static string FormatWith(this string format, params object[] args)
{
format.NotNull("format");
return string.Format(CultureInfo.CurrentCulture, format, args);
}
///
/// 将驼峰字符串的第一个字符小写
///
public static string LowerFirstChar(this string str)
{
if (string.IsNullOrEmpty(str) || !char.IsUpper(str[0]))
{
return str;
}
if (str.Length == 1)
{
return char.ToLower(str[0]).ToString();
}
return char.ToLower(str[0]) + str.Substring(1, str.Length - 1);
}
}