Contrôle validateur d'expression régulière, exemple
Le contrôle validateur d'expression régulière montré ici étend le contrôle validateur de base décrit dans l'exemple de contrôle validateur de base. Ce validateur ajoute les fonctionnalités suivantes au validateur de base :
- Il expose une propriété nommée
ValidationExpression
qui permet à un utilisateur (développeur de pages) de spécifier une expression régulière. - Il substitue la méthode
EvaluateIsValid
(définie en tant que méthode abstraite dansBaseDomValidator
) pour fournir une logique permettant de déterminer si le champ à valider correspond au modèle spécifié par l'expression régulière. - Il substitue AddAttributesToRender (hérité de WebControl) pour fournir un gestionnaire côté client pour la logique d'évaluation. Le gestionnaire côté client est une fonction définie dans la bibliothèque de scripts.
Pour compiler et générer cet exemple, consultez les instructions fournies dans Exemples de contrôle validateur. Pour une vue d'ensemble de l'écriture de scripts côté client dans les contrôles serveur, consultez Fonctionnalités côté client dans un contrôle serveur.
// RegexDomValidator.cs.
namespace DomValidators {
using System.ComponentModel;
using System.ComponentModel.Design;
using System.Diagnostics;
using System.Text.RegularExpressions;
using System.Drawing.Design;
using System;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
[
ToolboxData("<{0}:RegexDomValidator runat=server ErrorMessage=\"RegexDomValidator\"></{0}:RegexDomValidator>")
]
public class RegexDomValidator : BaseDomValidator {
[
Bindable(true),
Category("Behavior"),
DefaultValue(""),
Editor("System.Web.UI.Design.WebControls.RegexTypeEditor,System.Design", typeof(UITypeEditor)),
Description("ValidationExpression")
]
public string ValidationExpression {
get {
object o = ViewState["ValidationExpression"];
return((o == null) ? String.Empty : (string)o);
}
set {
try {
Regex.IsMatch("", value);
}
catch (Exception e) {
//Throw new HttpException.
// HttpRuntime.FormatResourceString(SR.Validator_bad_regex, value), e);
throw new HttpException("Bad Expression", e);
}
ViewState["ValidationExpression"] = value;
}
}
protected override void AddAttributesToRender(HtmlTextWriter writer) {
base.AddAttributesToRender(writer);
if (RenderUplevel) {
writer.AddAttribute("evaluationfunction", "RegularExpressionValidatorEvaluateIsValid");
if (ValidationExpression.Length > 0) {
writer.AddAttribute("validationexpression", ValidationExpression);
}
}
}
protected override bool EvaluateIsValid() {
// Validation always succeeds if input is empty or value was not found.
string controlValue = GetControlValidationValue(ControlToValidate);
Debug.Assert(controlValue != null, "Should have already been checked");
if (controlValue == null || controlValue.Length == 0) {
return true;
}
try {
// Looking for an exact match, not just a search hit.
Match m = Regex.Match(controlValue, ValidationExpression);
return(m.Success && m.Index == 0 && m.Length == controlValue.Length);
}
catch {
Debug.Fail("Regex error should have been caught in property setter.");
return true;
}
}
}
}
[Visual Basic]
' RegexDomValidator.vb
Option Explicit
Option Strict
Imports System.ComponentModel
Imports System.ComponentModel.Design
Imports System.Diagnostics
Imports System.Text.RegularExpressions
Imports System.Drawing.Design
Imports System
Imports System.Web
Imports System.Web.UI
Imports System.Web.UI.WebControls
Namespace DomValidators
<ToolboxData("<{0}:RegexDomValidator runat=server ErrorMessage=""RegexDomValidator""></{0}:RegexDomValidator>")> _
Public Class RegexDomValidator
Inherits BaseDomValidator
<Bindable(True), _
Category("Behavior"), _
DefaultValue(""), _
Editor("System.Web.UI.Design.WebControls.RegexTypeEditor,System.Design", _
GetType(UITypeEditor)), _
Description("ValidationExpression")> _
Public Property ValidationExpression() As String
Get
Dim o As Object = ViewState("ValidationExpression")
If o Is Nothing Then
Return String.Empty
Else
Return CStr(o)
End If
End Get
Set
Try
Regex.IsMatch("", value)
Catch e As Exception
'Throw new HttpException.
' HttpRuntime.FormatResourceString(SR.Validator_bad_regex, value), e);
Throw New HttpException("Bad Expression", e)
End Try
ViewState("ValidationExpression") = value
End Set
End Property
Protected Overrides Sub AddAttributesToRender(writer As HtmlTextWriter)
MyBase.AddAttributesToRender(writer)
If RenderUplevel Then
writer.AddAttribute("evaluationfunction", "RegularExpressionValidatorEvaluateIsValid")
If ValidationExpression.Length > 0 Then
writer.AddAttribute("validationexpression", ValidationExpression)
End If
End If
End Sub
Protected Overrides Function EvaluateIsValid() As Boolean
' Always succeeds if input is empty or value was not found.
Dim controlValue As String = GetControlValidationValue(ControlToValidate)
Debug.Assert( Not (controlValue Is Nothing), "Should have already been checked")
If controlValue Is Nothing Or controlValue.Length = 0 Then
Return True
End If
Try
' Looking for an exact match, not just a search hit.
Dim m As Match = Regex.Match(controlValue, ValidationExpression)
Return m.Success And m.Index = 0 And m.Length = controlValue.Length
Catch
End Try
End Function
End Class
End Namespace
Voir aussi
Exemples de contrôle validateur | Contrôle validateur de base, exemple | Contrôle validateur de champ obligatoire, exemple | Bibliothèque de scripts pour validateur, exemple | Fichier de configuration pour l'exemple de validateur | Page de test pour l'exemple de validateur | Développement d'un contrôle validateur