recherche

php 国际化

Nov 24, 2016 am 09:58 AM

PHP的gettext用法  

gettext程序在Linux/Unix世界中很常见,但一般人日常使用的机会不多。它用来为应用程序添加国际化支持。举个例子,如果一个程序中的字符串资源没有硬编码在程序源文件中,而是以一种语言包的文件存在的,那么就可以通过添加语言包文件来改变程序界面的语言。gettext就可以做这种事。 

Windows下的PHP5中已经带有了gettext扩展,Zend Server也以带有该扩展。在php.ini文件中将“extension=php_gettext.dll”前面的分号去掉,重启Apache,如果一切正常的话,在phpinfo()的输出中应该会有gettext一节。下面有一个简单的“Hello World”的例子来看看如何用gettext来达到支持多语言的目的。 

创建一个PHP文件test.php,内容如下: 
putenv(“LANG=zh_CN”);
setlocale(LC_ALL, ‘zh_CN’);

bindtextdomain(‘test’, ‘./locale’);
textdomain(‘test’);

echo gettext(‘Hello World!’);
?> 

开头两行代码设置语言环境为’zh_CN’,也就是简体中文。bindtextdomain设置域test的目录为当前目录下的locale目录。textdomain(’text’)告诉PHP解释器,gettext函数要去test域中去寻找替代字符串。 

在浏览器中打开这个文件,可以看到结果为“Hello World”,只是原样输出而已,因为还没有制作中文语言包。要让浏览器输出中文而不改变源程序,需要准备两个文件,PO和MO文件。为了得到这两个文件,需要使用xgettext和msgfmt两个程序。Windows用户可以去GnuWin32下载GetText软件包,里面就有这两个程序。 

接着建立相应的目录结构。在test.php的目录下建立“locale\zh_CN\LC_MESSAGES”这样的目录。目录名zh_CN一定要和代码中的语言名称zh_CN相同。然后在命令提示符下执行: 
xgettext -d test test.php 
“-d test”表示domain为“test”,这会在当前目录下生成test.po这个文件。用文本编辑器打开它,做如下修改: 

… 
“Content-Type: text/plain; charset=GB2312\n” 
“Content-Transfer-Encoding: 8bit\n” 

#: test.php:11 
msgid “Hello World!” 
msgstr “你好,世界!” 

即将charset设置为中文编码“GB2312”,将相应的msgid中的英文字符串翻译成中文填入到下面的msgstr中。接下来用msgfmt生成MO文件。MO是一个二进制格式的文件,gettext从它里面提取字符串资源。在命令提示符中执行以下命令可以从刚刚修改的PO文件得到MO文件: 
msgfmt -o test.mo test.po 

最后将test.po和test.mo放在locale\zh_CN\LC_MESSAGES目录下,刷新浏览器,即可看到显示的是中文。

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
Comment pouvez-vous empêcher les attaques de fixation de session?Comment pouvez-vous empêcher les attaques de fixation de session?Apr 28, 2025 am 12:25 AM

Des méthodes efficaces pour empêcher les attaques fixes de session incluent: 1. Régénérer l'ID de session après que l'utilisateur se connecte; 2. Utilisez un algorithme de génération d'ID de session sécurisé; 3. Mettre en œuvre le mécanisme de délai d'expiration de la session; 4. Cryptez les données de session à l'aide de HTTPS. Ces mesures peuvent garantir que l'application est indestructible lorsqu'il est confronté à des attaques fixes de session.

Comment implémentez-vous l'authentification sans session?Comment implémentez-vous l'authentification sans session?Apr 28, 2025 am 12:24 AM

La mise en œuvre d'authentification sans session peut être réalisée à l'aide de JSONWebtokens (JWT), un système d'authentification basé sur des jetons où toutes les informations nécessaires sont stockées dans le jeton sans stockage de session côté serveur. 1) Utilisez JWT pour générer et vérifier les jetons, 2) Assurez-vous que HTTPS est utilisé pour empêcher les jetons d'être interceptés, 3) stocker en toute sécurité les jetons du côté client, 4) Vérifiez les jetons du côté serveur pour empêcher la falsification, 5) implémenter des mécanismes de révocation des jetons, comme l'utilisation des jetons d'accès à court terme et des jetons à long terme.

Quels sont les risques de sécurité communs associés aux séances PHP?Quels sont les risques de sécurité communs associés aux séances PHP?Apr 28, 2025 am 12:24 AM

Les risques de sécurité des séances PHP incluent principalement le détournement de session, la fixation de session, la prédiction de session et l'empoisonnement de session. 1. Le détournement de session peut être évité en utilisant HTTPS et en protégeant les cookies. 2. La fixation de la session peut être évitée en régénérant l'ID de session avant que l'utilisateur ne se connecte. 3. La prédiction de session doit assurer l'aléatoire et l'imprévisibilité des ID de session. 4. L'empoisonnement de la session peut être évité en vérifiant et en filtrant les données de session.

Comment détruisez-vous une session PHP?Comment détruisez-vous une session PHP?Apr 28, 2025 am 12:16 AM

Pour détruire une session PHP, vous devez d'abord démarrer la session, puis effacer les données et détruire le fichier de session. 1. Utilisez session_start () pour démarrer la session. 2. Utilisez session_unset () pour effacer les données de session. 3. Enfin, utilisez Session_Destroy () pour détruire le fichier de session pour assurer la sécurité des données et la version des ressources.

Comment pouvez-vous modifier le chemin de sauvegarde de session par défaut dans PHP?Comment pouvez-vous modifier le chemin de sauvegarde de session par défaut dans PHP?Apr 28, 2025 am 12:12 AM

Comment modifier le chemin d'enregistrement de la session par défaut de PHP? Il peut être réalisé via les étapes suivantes: utilisez session_save_path ('/ var / www / sessions'); session_start (); Dans PHP Scripts pour définir le chemin de sauvegarde de session. Set session.save_path = "/ var / www / sessions" dans le fichier php.ini pour modifier le chemin d'enregistrement de session globalement. Utilisez Memcached ou Redis pour stocker des données de session, telles que ini_set ('session.save_handler', 'memcached'); ini_set (

Comment modifiez-vous les données stockées dans une session PHP?Comment modifiez-vous les données stockées dans une session PHP?Apr 27, 2025 am 12:23 AM

TomodifyDatainaphPSession, startTheSessionwithSession_start (), puis utilisez $ _sessiontoset, modifiez, orremovevariables.1) startTheSession.2) setorModifySessionVariblesusing $ _Session.3) retireVariableswithunset (). 4) ClearAllVariblesWithSession_unset (). 5).

Donnez un exemple de stockage d'un tableau dans une session PHP.Donnez un exemple de stockage d'un tableau dans une session PHP.Apr 27, 2025 am 12:20 AM

Les tableaux peuvent être stockés en séances PHP. 1. Démarrez la session et utilisez session_start (). 2. Créez un tableau et stockez-le en $ _SESSION. 3. Récupérez le tableau via $ _SESSION. 4. Optimiser les données de session pour améliorer les performances.

Comment fonctionne la collecte des ordures pour les séances PHP?Comment fonctionne la collecte des ordures pour les séances PHP?Apr 27, 2025 am 12:19 AM

La collecte de déchets de session PHP est déclenchée par un mécanisme de probabilité pour nettoyer les données de session expirées. 1) définir le cycle de vie de probabilité de déclenchement et de session dans le fichier de configuration; 2) Vous pouvez utiliser des tâches CRON pour optimiser les applications de haute charge; 3) Vous devez équilibrer la fréquence et les performances de collecte des ordures pour éviter la perte de données.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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 !

Outils chauds

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code