PHP ne peut pas obtenir le src de l'image
Avec le développement continu de la technologie réseau, les pages Web utilisent non seulement le texte comme contenu principal, mais évoluent également progressivement vers l'intégration d'éléments multimédias tels que des images, de l'audio et de la vidéo. De nos jours, lorsque nous visitons des pages Web, nous nous appuyons davantage sur ces éléments multimédias, qui enrichissent notre expérience esthétique et rendent les pages plus vivantes et intuitives.
Parmi eux, les images sont l'un des éléments multimédias les plus courants. Dans le développement Web, l'utilisation d'images peut enrichir le contenu d'une page et enrichir l'expérience utilisateur. Parfois, nous devons obtenir l'adresse src de l'image côté serveur pour effectuer les opérations associées. En PHP, il existe de nombreuses façons d'obtenir l'adresse src d'une image, mais vous pouvez rencontrer certains problèmes, faisant échouer l'acquisition. Cet article présentera en détail les raisons et les solutions pour lesquelles PHP ne peut pas obtenir l'image src.
1. Comment obtenir le src d'une image
En PHP, il existe de nombreuses façons d'obtenir l'adresse src d'une image. Voici deux méthodes courantes.
- Utilisez des expressions régulières pour obtenir le src de l'image
En HTML, le src de l'adresse de l'image est généralement écrit dans l'attribut src de la balise img. Par conséquent, nous pouvons utiliser des expressions régulières pour obtenir la valeur de l'attribut src dans la balise img.
function getImgSrc($html){ $pattern = '/<img.*?src="(.*?)".*?>/is'; preg_match_all($pattern, $html, $matches); $src_array = $matches[1]; return $src_array; }
Dans la fonction ci-dessus, $html est la forme de chaîne d'une page html. Utilisez des expressions régulières pour faire correspondre les valeurs de l'attribut src de toutes les balises img en HTML et renvoyez un tableau $src_array, qui stocke les adresses src de toutes les images.
- Obtenir le src de l'image à l'aide de DOMDocument
DOMDocument est l'un des principaux outils PHP pour travailler avec des documents XML et HTML. Il fournit une série de méthodes pour obtenir facilement des éléments et leurs attributs dans des documents HTML. Nous pouvons utiliser DOMDocument pour obtenir la valeur de l'attribut src de la balise img.
function getImgSrc($html){ $dom = new DOMDocument(); @$dom->loadHTML($html); $xpath = new DOMXPath($dom); $src_array = array(); $img_list = $xpath->query('//img'); foreach($img_list as $img){ $src_array[] = $img->getAttribute('src'); } return $src_array; }
Dans la fonction ci-dessus, $html est également la forme de chaîne d'une page html. À l'aide de DOMDocument, créez un objet document $dom et utilisez la méthode loadHTML pour charger la page html. Ensuite, utilisez DOMXPath pour obtenir toutes les balises img, puis parcourez chaque balise img pour obtenir sa valeur d'attribut src.
2. Raisons et solutions de l'échec de l'acquisition
Lorsque vous utilisez la méthode ci-dessus pour obtenir le src de l'image, vous pouvez rencontrer un échec d'acquisition. Voici plusieurs causes possibles et solutions correspondantes.
- Le html entrant est incomplet
Le paramètre $html passé dans la fonction getImgSrc devrait être un document html complet, mais parfois, nous n'obtenons qu'une partie du contenu de la page, ou il y a du contenu incomplet dans la balise du document html , cela entraînera l’échec de l’acquisition. À ce stade, nous devons nous assurer que le document HTML entrant est complet et correct.
- L'image src utilise un chemin relatif
Parfois, l'attribut src de l'image utilise un chemin relatif, donc lorsque nous obtenons l'image côté serveur, nous devons la convertir en chemin absolu. Vous pouvez utiliser la fonction dirname et la fonction parse_url de PHP pour convertir les chemins relatifs en chemins absolus.
function getAbsoluteUrl($base, $relative){ $parse_base = parse_url($base); if(!isset($parse_base['path'])){ $parse_base['path'] = '/'; } $dir = dirname($parse_base['path']); if($relative[0] == '/'){ $relative = substr($relative, 1); } if($relative[0] == '.'){ $i = 0; while(substr($relative, 0, 2) == './'){ $relative = substr($relative, 2); } $dir .= '/'; } $result = $parse_base['scheme']."://".$parse_base['host']; if(isset($parse_base['port']) && $parse_base['port'] != '80'){ $result .= ':'.$parse_base['port']; } $result .= $dir.$relative; return $result; }
Dans la fonction ci-dessus, $base est l'adresse de base du chemin relatif et $relative est le chemin relatif. Utilisez la fonction dirname pour obtenir le chemin du répertoire $dir de l'adresse de base, puis découpez le chemin absolu complet en fonction du chemin relatif.
- Raisons liées au réseau
L'obtention du src de l'image sera également affectée par l'environnement réseau. Si le réseau est instable ou interrompu, l'acquisition échouera. À ce stade, vous pouvez tenter de l'obtenir à nouveau ou attendre que le réseau se stabilise et tenter de l'obtenir à nouveau.
Pour résumer, cet article présente les raisons et les solutions pour lesquelles PHP ne peut pas obtenir l'image src. L'obtention du src de l'image côté serveur est une exigence de développement courante. La maîtrise de la méthode d'acquisition et de certaines solutions en cas de problèmes peut mieux améliorer l'efficacité du développement et réduire l'impact des problèmes.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds





L'article traite des 10 meilleures vulnérabilités de l'OWASP dans les stratégies PHP et d'atténuation. Les problèmes clés incluent l'injection, l'authentification brisée et les XS, avec des outils recommandés pour surveiller et sécuriser les applications PHP.

La compilation JIT de PHP 8 améliore les performances en compilant le code fréquemment exécuté en code machine, bénéficiant aux applications avec des calculs lourds et en réduisant les temps d'exécution.

L'article traite de la sécurisation des téléchargements de fichiers PHP pour éviter les vulnérabilités comme l'injection de code. Il se concentre sur la validation du type de fichier, le stockage sécurisé et la gestion des erreurs pour améliorer la sécurité de l'application.

L'article traite du cryptage symétrique et asymétrique en PHP, en comparant leur aptitude, leurs performances et leurs différences de sécurité. Le chiffrement symétrique est plus rapide et adapté aux données en vrac, tandis que l'asymétrique est utilisé pour l'échange de clés sécurisé.

L'article examine la mise en œuvre d'authentification et d'autorisation robustes dans PHP pour empêcher un accès non autorisé, détaillant les meilleures pratiques et recommandant des outils d'amélioration de la sécurité.

L'article traite des stratégies de mise en œuvre de la limitation du taux d'API en PHP, y compris des algorithmes comme un godet de jeton et un seau qui fuit, et en utilisant des bibliothèques comme Symfony / Rate-Limiter. Il couvre également la surveillance, l'ajustement dynamiquement des limites de taux et la main

L'article traite des meilleures pratiques pour la validation des entrées PHP pour améliorer la sécurité, en se concentrant sur des techniques telles que l'utilisation de fonctions intégrées, une approche de liste blanche et une validation côté serveur.

L'article traite des stratégies pour prévenir les attaques du CSRF dans PHP, notamment en utilisant des jetons CSRF, des cookies de même site et une bonne gestion de session.
