我想做初步检查,如果输入的字符串看起来像
Vehicle Identification Number (VIN).我知道它由17个字母和数字组成,但字母I,O和Q不允许在VIN中,所以我使用这个正则表达式:
^[0-9A-Z-[IOQ]]{17}$
现在,如果我使用RegularExpressionValidator检查类似1G1FP22PXS2100001的字符串,它会失败,但是带有此OnServerValidate事件处理程序的CustomValidator
Regex r = new Regex("^[0-9A-Z-[IOQ]]{17}$"); args.IsValid = r.IsMatch(TextBox1.Text);
效果很好.
实验显示了RegularExpressionValidator不支持Character Class Subtraction,但是Regex类支持.
现在我感兴趣为什么这两个.NET类使用不同的正则表达式?它是否记录在案?