页面数据校验类--很不错的喔.一直在用.

本文介绍了一个用于网页数据验证的类实现,该类通过正则表达式来校验数字、带符号数字、浮点数、电子邮件地址及中文字符等。同时还提供了字符串长度限制、HTML编码等功能。

using System;
using System.Text;
using System.Web;
using System.Web.UI.WebControls;
using System.Text.RegularExpressions;
namespace zcl
{
 /// <summary>
 /// 页面数据校验类
 /// Chandler
 /// 2006.1
 /// </summary>
 public class PageValidate
 {
  private static Regex RegNumber = new Regex("^[0-9]+$");
  private static Regex RegNumberSign = new Regex("^[+-]?[0-9]+$");
  private static Regex RegDecimal = new Regex("^[0-9]+[.]?[0-9]+$");
  private static Regex RegDecimalSign = new Regex("^[+-]?[0-9]+[.]?[0-9]+$"); //等价于^[+-]?/d+[.]?/d+$
  private static Regex RegEmail = new Regex("^[//w-]+@[//w-]+//.(com|net|org|edu|mil|tv|biz|info)$");//w 英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样
  private static Regex RegCHZN = new Regex("[/u4e00-/u9fa5]");

  public PageValidate()
  {
  }


  #region 数字字符串检查  
  
  /// <summary>
  /// 检查Request查询字符串的键值,是否是数字,最大长度限制
  /// </summary>
  /// <param name="req">Request</param>
  /// <param name="inputKey">Request的键值</param>
  /// <param name="maxLen">最大长度</param>
  /// <returns>返回Request查询字符串</returns>
  public static string FetchInputDigit(HttpRequest req, string inputKey, int maxLen)
  {
   string retVal = string.Empty;
   if(inputKey != null && inputKey != string.Empty)
   {
    retVal = req.QueryString[inputKey];
    if(null == retVal)
     retVal = req.Form[inputKey];
    if(null != retVal)
    {
     retVal = SqlText(retVal, maxLen);
     if(!IsNumber(retVal))
      retVal = string.Empty;
    }
   }
   if(retVal == null)
    retVal = string.Empty;
   return retVal;
  }  
  /// <summary>
  /// 是否数字字符串
  /// </summary>
  /// <param name="inputData">输入字符串</param>
  /// <returns></returns>
  public static bool IsNumber(string inputData)
  {
   Match m = RegNumber.Match(inputData);
   return m.Success;
  }  
  /// <summary>
  /// 是否数字字符串 可带正负号
  /// </summary>
  /// <param name="inputData">输入字符串</param>
  /// <returns></returns>
  public static bool IsNumberSign(string inputData)
  {
   Match m = RegNumberSign.Match(inputData);
   return m.Success;
  }  
  /// <summary>
  /// 是否是浮点数
  /// </summary>
  /// <param name="inputData">输入字符串</param>
  /// <returns></returns>
  public static bool IsDecimal(string inputData)
  {
   Match m = RegDecimal.Match(inputData);
   return m.Success;
  }  
  /// <summary>
  /// 是否是浮点数 可带正负号
  /// </summary>
  /// <param name="inputData">输入字符串</param>
  /// <returns></returns>
  public static bool IsDecimalSign(string inputData)
  {
   Match m = RegDecimalSign.Match(inputData);
   return m.Success;
  }  

  #endregion

  #region 中文检测

  /// <summary>
  /// 检测是否有中文字符
  /// </summary>
  /// <param name="inputData"></param>
  /// <returns></returns>
  public static bool IsHasCHZN(string inputData)
  {
   Match m = RegCHZN.Match(inputData);
   return m.Success;
  } 

  #endregion

  #region 邮件地址
  /// <summary>
  /// 是否是浮点数 可带正负号
  /// </summary>
  /// <param name="inputData">输入字符串</param>
  /// <returns></returns>
  public static bool IsEmail(string inputData)
  {
   Match m = RegEmail.Match(inputData);
   return m.Success;
  }  

  #endregion

  #region 其他

  /// <summary>
  /// 检查字符串最大长度,返回指定长度的串
  /// </summary>
  /// <param name="sqlInput">输入字符串</param>
  /// <param name="maxLength">最大长度</param>
  /// <returns></returns>   
  public static string SqlText(string sqlInput, int maxLength)
  {   
   if(sqlInput != null && sqlInput != string.Empty)
   {
    sqlInput = sqlInput.Trim();       
    if(sqlInput.Length > maxLength)//按最大长度截取字符串
     sqlInput = sqlInput.Substring(0, maxLength);
   }
   return sqlInput;
  }
  public static bool IsDateTime(string inputDateTime)
  {
    return true;
  }
  
  /// <summary>
  /// 字符串编码
  /// </summary>
  /// <param name="inputData"></param>
  /// <returns></returns>
  public static string HtmlEncode(string inputData)
  {
   return HttpUtility.HtmlEncode(inputData);
  }
  /// <summary>
  /// 设置Label显示Encode的字符串
  /// </summary>
  /// <param name="lbl"></param>
  /// <param name="txtInput"></param>
  public static void SetLabel(Label lbl, string txtInput)
  {
   lbl.Text = HtmlEncode(txtInput);
  }
  public static void SetLabel(Label lbl, object inputObj)
  {
   SetLabel(lbl, inputObj.ToString());
  }  

  #endregion


 }
}

在 element-plus 里,`addFurloughFormRef.value.validate` 表单验证器一直阻塞,可能存在以下原因: ### 自定义规则未调用 callback 在自定义表单规则时,若未正确调用 `callback`,会使表单验证无法正常结束。像在自定义数字校验规则时,不管判定成功或者失败,都得调用 `callback`,不然就不会执行 element 的 `validate` 表单校验。示例如下: ```javascript // 数字校验规则 const numberRule = (rule, value, callback) => { const num = Number(value); if (!isNaN(num) && num > 0 && value.length < 6) { return callback(); // 验证成功,调用 callback } return callback(new Error('请输入1~5位数字')); // 验证失败,传递错误信息 }; ``` 若在自定义规则里遗漏了 `callback` 的调用,就会造成验证器一直阻塞[^1]。 ### 异步验证未正确处理 要是验证规则包含异步操作,比如请求接口来验证数据,就必须正确处理异步操作,保证在异步操作完成后调用 `callback`。示例如下: ```javascript const asyncRule = (rule, value, callback) => { // 模拟异步请求 setTimeout(() => { if (value === 'valid') { callback(); } else { callback(new Error('输入无效')); } }, 1000); }; ``` 若异步操作未正确处理,或者未在操作完成后调用 `callback`,验证器也会一直阻塞。 ### 表单组件引用问题 若 `addFurloughFormRef` 引用的表单组件未正确挂载或者引用错误,也可能导致验证器阻塞。要保证在调用 `validate` 方法之前,表单组件已经正确挂载,并且引用无误。示例如下: ```javascript // 在 setup 中正确获取表单引用 const addFurloughFormRef = ref(null); // 确保在表单组件挂载后调用验证方法 onMounted(() => { addFurloughFormRef.value.validate((valid) => { if (valid) { // 验证通过 } else { // 验证失败 } }); }); ``` ### 其他组件冲突 页面上的其他组件或者插件可能和表单验证器产生冲突,从而导致验证器阻塞。可以尝试暂时移除其他组件,查看验证器是否恢复正常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值