Validation d'entrée robuste pour les URL HTTP et HTTPS
Les méthodes de validation d'URL courantes telles que Uri.IsWellFormedUriString
et Uri.TryCreate
ne parviennent parfois pas à distinguer de manière fiable les URL HTTP valides des autres chemins de fichiers. Cela présente un défi important lors de la validation des entrées utilisateur où seules les URL HTTP ou HTTPS sont acceptables.
Une approche plus précise : combiner la validation d'URI et la vérification de schéma
Une solution plus robuste consiste à combiner la validation structurelle d'URI avec une vérification spécifique pour le schéma HTTP ou HTTPS :
<code class="language-csharp">Uri uriResult; bool isValidHttpUrl = Uri.TryCreate(uriString, UriKind.Absolute, out uriResult) && uriResult.Scheme == Uri.UriSchemeHttp;</code>
Ce code utilise d'abord Uri.TryCreate
pour vérifier la chaîne d'entrée (uriString
) en tant qu'URI bien formé. En cas de succès, il vérifie ensuite si le schéma de l'URI est Uri.UriSchemeHttp
.
Extension de la validation pour inclure HTTPS
Pour inclure les URL HTTPS, développez simplement la comparaison des schémas :
<code class="language-csharp">Uri uriResult; bool isValidHttpOrHttpsUrl = Uri.TryCreate(uriString, UriKind.Absolute, out uriResult) && (uriResult.Scheme == Uri.UriSchemeHttp || uriResult.Scheme == Uri.UriSchemeHttps);</code>
Cette vérification améliorée accepte les protocoles HTTP et HTTPS, fournissant une validation d'URL complète pour votre entrée.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!