Maison >développement back-end >C++ >Comment puis-je valider de manière fiable les URL HTTP et HTTPS en entrée ?

Comment puis-je valider de manière fiable les URL HTTP et HTTPS en entrée ?

Patricia Arquette
Patricia Arquetteoriginal
2025-01-09 14:08:42321parcourir

How Can I Reliably Validate HTTP and HTTPS URLs in Input?

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn