Maison >développement back-end >Problème PHP >Pourquoi la page PHP apparaît-elle avec des caractères HTML tronqués ?

Pourquoi la page PHP apparaît-elle avec des caractères HTML tronqués ?

Guanhui
Guanhuioriginal
2020-05-14 15:18:403404parcourir

Pourquoi la page PHP apparaît-elle avec des caractères HTML tronqués ?

Pourquoi la page PHP apparaît-elle avec des caractères HTML tronqués

1. Erreur d'encodage de la page Web PHP

Si vous souhaitez utiliser l'encodage gb2312, alors PHP doit afficher l'en-tête : header("Content-Type: text/html; charset=gb2312"), l'ajouter à la page statique, et le format d'encodage de tous les fichiers est ANSI Vous pouvez l'ouvrir avec le Bloc-notes et l'enregistrer comme encodage sélectionné. Pour ANSI, écrasez le fichier source.

Si vous souhaitez utiliser l'encodage utf-8, alors php doit afficher l'en-tête : header("Content-Type: text/html; charset=utf-8"), ajouter une page statique et l'encodage le format de tous les fichiers est utf -8. L'enregistrement au format utf-8 peut être un peu gênant. Généralement, les fichiers utf-8 auront une nomenclature au début. Si vous utilisez une session, il y aura des problèmes. Vous pouvez utiliser editplus pour enregistrer. Sélection des paramètres->Fichier-> Signature UTF-8, sélectionnez Toujours supprimer, puis enregistrez pour supprimer les informations de nomenclature.

php lui-même n'est pas Unicode, toutes les fonctions telles que substr doivent être modifiées en mb_substr (l'extension mbstring doit être installée ou utiliser iconv pour transcoder) ;

2. L'encodage MySQL est incohérent avec l'encodage PHP ;

Solution :

Modifier le fichier de configuration mysql my.ini ou my.cnf, mysql est le meilleur Encodage utf8 facile à utiliser [mysql] default-character-set=utf8 [mysqld] default-character-set=utf8 default-storage-engine=MyISAM Ajouter sous [mysqld] : default-collation=utf8_bin init_connect='SET NAMES utf8'

Ajoutez mysql_query("set names 'encoding'"); avant le programme PHP qui doit effectuer les opérations de base de données. L'encodage est cohérent avec l'encodage PHP. Si l'encodage PHP est gb2312, alors le codage est gb2312. L'encodage mysql est gb2312. S'il s'agit de utf-8, l'encodage mysql est utf8, de sorte qu'il n'y aura pas de caractères tronqués lors de l'insertion ou de la récupération de données

3. L'encodage de PHP et du système d'exploitation. sont incohérents.

L'encodage de Windows et Linux est différent Dans l'environnement Windows, lors de l'appel de fonctions PHP, si les paramètres sont encodés en utf-8, des erreurs se produiront, telles que. comme move_uploaded_file(), filesize(), readfile(), etc. Ces fonctions sont souvent utilisées lors du traitement des téléchargements et des téléchargements. L'erreur suivante peut se produire lors de l'appel :

Warning: move_uploaded_file()[function.move-uploaded-file]:failed to open stream: Invalid argument in ...
Warning: move_uploaded_file()[function.move-uploaded-file]:Unable to move '' to '' in ...
Warning: filesize() [function.filesize]: stat failed for ... in ...
Warning: readfile() [function.readfile]: failed to open stream: Invalid argument in ..

Bien que vous utilisiez l'encodage gb2312 dans un environnement Linux, ces erreurs. cela ne se produira pas, mais le nom du fichier enregistré sera tronqué et le fichier ne pourra pas être lu. Dans ce cas, vous pouvez d'abord convertir les paramètres dans l'encodage reconnu par le système d'exploitation. Pour la conversion de l'encodage, vous pouvez utiliser mb_convert_encoding (string, new. encodage, encodage original) ou iconv (encodage original, nouvel encodage, chaîne), de sorte que le nom du fichier enregistré après le traitement ne soit pas tronqué et que le fichier puisse être lu normalement pour réaliser le téléchargement de fichiers avec des noms chinois.

En fait, il existe une meilleure solution, complètement déconnectée du système, et il n'est pas nécessaire de considérer l'encodage du système. Vous pouvez générer une séquence composée uniquement de lettres et de chiffres comme nom de fichier et enregistrer le nom original avec des caractères chinois dans la base de données. De cette façon, il n'y aura aucun problème lors de l'appel de move_uploaded_file(). Lors du téléchargement, il vous suffit de le modifier. le nom du fichier au nom d'origine avec des caractères chinois. Le code pour implémenter le téléchargement est le suivant

header("Pragma: public");
header("Expires: 0");
header("Cache-Component: must-revalidate, post-check=0, pre-check=0");
header("Content-type: $file_type");
header("Content-Length: $file_size");
       header("Content-Disposition: attachment; filename=\"$file_name\"");
header("Content-Transfer-Encoding: binary");
readfile($file_path);

$file_type est le type de fichier, $file_name est le nom d'origine et $file_path est l'adresse du fichier enregistré sur le service.
Tutoriel recommandé : "Tutoriel PHP"

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