Dans mon application, je crée une série de classes de validation pour vérifier, par exemple, qu'un utilisateur entré dans la propriété Name de la classe (à partir d'un WinForm) ne dépasse pas la taille de varchar() dans la base de données.Validation des données de classe
Actuellement, le code de validation lancera une exception personnalisée si le champ Nom est trop grand. (L'exception personnalisée, lorsqu'elle est interceptée par l'interface utilisateur, affiche le message d'exception personnalisé dans un MessageBox par opposition à mon formulaire d'erreur générique pour les exceptions régulières.) Les classes de validation se trouvent dans la bibliothèque de classes de l'application. Le flux ressemble à ceci:
- La fonction publique DLL couche utilisée par les WinForms - (appels) -> Friend Validation couche
- Layer de la fonction publique de la DLL utilisée par les WinForms - (appels) - -> Couche d'accès aux données d'ami si la validation réussit.
Exemple simplifié:
Public Shared Sub CreateCustomer(cust as Customer)
Validation.Customer.ValidateForCreate(cust) ' scoped as Friend
Dal.Customer.Create(cust) ' scoped as Friend
End Sub
est-il la conception « intelligente » pour faire revenir le jet couche de validation des exceptions personnalisées à l'interface utilisateur lorsque la validation échoue?
Est-il préférable de renvoyer True/False à partir du calque Validation avec un message String de ce qui a échoué, et que le niveau de service gère les exceptions de lancement? Est-il préférable de renvoyer Vrai/Faux à partir du Couche de Validation, et de faire en sorte que la Couche Services passe du Vrai/Faux à l'UI avec un message String de ce qui a échoué? J'essaie de garder une approche orientée objet. Mon opinion est que lancer des exceptions personnalisées ne brise pas les principes de la POO, mais j'aimerais d'autres opinions :)
Supposant qu'il ya en fait plusieurs violations de règles métier dans un « nouveau client », vous capturez toutes les violations en un seul passage et les présenter dans l'interface utilisateur, ou échouez-vous sur la première violation? –
J'échoue sur le premier. – HardCode
Hmm. J'allais suggérer que retourner une collection de "violations" serait une bonne justification pour une exception personnalisée.Seulement vous connaissez vos besoins, mais je serais inquiet qu'un utilisateur pourrait être frustré ... –