当前位置:首页 > 技术文档 > 正文内容

用php gettext库来开发多语言系统

admin10年前 (2015-06-05)技术文档1988

通常人们写程序时都是将文字写死在程序里的, 比如:echo "Hello World!";  ,假如要改成它国语言,写国际化程序,就要逐个打开进行修改,程序较短时还行,若程序有上万甚至更多,改起来就不是那么容易了。近来随着i18n的逐渐标 准化,我也来讲一讲在PHP中如何实现国际化支持。跟其他程序语言一样,在 PHP 也可以利用 gettext 套件写作 i18n 程序,实现  NLS(Native Language Support) 国际化支持,具体请参考官方文档( http://www.gnu.org/manual/gettext/index.html )。

  实现流程:程序设计者在程序码中写入所要显示的信息,在运行程序时并不会直接显示程序设计师所写的信息,而会先去找一个所设置语系的信息档。如果未找到,才会去显示程式码中的信息。

  一、安装设置gettext套件:
  1) *nix系统:
  1、从 http://www.gnu.org/software/gettext/gettext.html 下载 gettext package,进行安装
  2、编译PHP的时候加上“--with-gettext[=DIR]”,其中DIR为gettext安装的
目录,缺省为:/usr/local
  3、保存,然后 restart server。

  2) windows系统:
  1、打开php.ini档,查找extension=php_gettext.dll,去掉前面的“;”
  2、保存,然后restart server。

  若一切顺利,就可以在 phpinfo() 中看到 gettext 字样,至此已设置完毕。

 

  二、php_gettext.dll套件里有好几个函式

  具体请看相关的manual。在这里我们只用记住3个函式就行了,如下:

string bindtextdomain ( string domain, string directory) string textdomain ( string text_domain) string gettext ( string message)

 

 

  三、写作i18n程序:

<?php // 常规的程序  echo "Hello World!");  ?>

 

  下面是 i18n 程序:hello.php

复制代码

<?php // I18N 程序范例开始  define('PACKAGE', 'hello'); // 定义要用的mo文件名称,常规来说,我们都把PACKAGE的名称定义和程序名称相同。  putenv('LANG=zh_CN');  setlocale(LC_ALL, 'zh_CN'); // 指定要用的语系,如:en_US、zh_CN、zh_TW   bindtextdomain(PACKAGE, 'e:/phpbulo.com/language');  textdomain(PACKAGE);  // The .mo file searched is:  // e:/phpbulo.com/language/zh_CN/LC_MESSAGES/hello.mo  echo gettext("Hello World!");  ?>

复制代码  

  在IE中输入:http://localhost/hello.php,输出结果为:“Hello World!”
  note:按照 GNU package 里面的习惯,可以使用 _(...) 来代替 gettext(...) ,这样就可以少打很多 gettext 了

 

  四、接下来设置gettext po档:
  1、创建目录结构,如下所示:
    bindtextdomain's dir
      /language
        /LC_MESSAGES
          domain.po
          domain.mo
  其中 bindtextdomain's dir 为 bindtextdomain() 所用的目录,language 为要用的语系,domain 为 PACKAGE 名称。

  以上面为例:
    /locale
      /zh_CN
        /LC_MESSAGES
          hello.po
          hello.mo

  2、创建po档
  xgettext -Cd [您定义的PACKAGE名称] [程序文件名]
  windows下面的xgettext、msgfmt程序档可以从 ( http://switch.dl.sourceforge.net/sourceforge/gnuwin32/gettext-0.10.40-bi... ) 下载,需要libiconv.dll,、libintl.dll 的支持。
  libiconv下载:http://mirrors.kernel.org/gnu/libiconv/libiconv-1.9.1.bin.woe32.zip
  将libiconv-1.9.1.bin.woe32\bin下的iconv.dll拷贝到gettext-0.10.40-bin/bin目录下,并重命名为libiconv.dll

 

  以上面hello.php档为例,
  $ xgettext -Cd e:/phpbulo.com/language/zh_CN/LC_MESSAGES/hello e:/phpbulo.com/hello.php
  运行后将产生一个hello.po档,内容如下:

复制代码

# SOME DESCRIPTIVE TITLE. # Copyright (C) YEAR Free Software Foundation, Inc. # FIRST AUTHOR <EMAIL@ADDRESS>, YEAR. # #, fuzzy msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "POT-Creation-Date: 2007-07-16 13:44+0800\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n" "Language-Team: LANGUAGE <LL@li.org>\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=CHARSET\n" "Content-Transfer-Encoding: 8bit\n" #: e:/phpbulo.com/hello.php:7 msgid "hello world" msgstr ""

复制代码

  里面列出 hello.php 档里所有调用 gettext 函式的字符串,翻译的时候只需将msgid 值翻译填入 msgstr 即可,如翻译成中文。

复制代码

# SOME DESCRIPTIVE TITLE. # Copyright (C) YEAR Free Software Foundation, Inc. # FIRST AUTHOR <EMAIL@ADDRESS>, YEAR. # #, fuzzy msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "POT-Creation-Date: 2007-07-16 13:44+0800\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n" "Language-Team: LANGUAGE <LL@li.org>\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=CHARSET\n" "Content-Transfer-Encoding: 8bit\n" #: e:/phpbulo.com/hello.php:7 msgid "hello world" msgstr "你好,世界!"

复制代码

 

  3、创建mo档

  msgfmt -o E:\work\test\language\zh_cn\LC_MESSAGES\hello.mo E:\work\test\language\zh_cn\LC_MESSAGES\hello.po

  运行后将产生一个hello.mo二进制档。

 

  五、

  在IE中输入: http://localhost/hello.php ,现在的结果就是:“你好,世界!”

 

转自:

  用php gettext库来开发多语言系统:http://hi.baidu.com/vincent_luo/blog/item/be52aac747c86cdfd00060f3.html

 

其他参考:

  [1] 通过gettext方式实现PHP国际化(i18n:http://www.lfyzjck.com/2010-12-29/399.html

  [2] 创建一个可翻译的WordPress模板:http://www.wordpress.la/how-to-make-a-translatable-wordpress-theme.html


分享到:

扫描二维码推送至手机访问。

版权声明:本文由云河空间发布,如需转载请注明出处。

本文链接:http://yuyunhe.cn/index.php/post/56.html

分享给朋友:

“用php gettext库来开发多语言系统” 的相关文章

php登录函数login session+mysql

<?php // 为php和mysql剔除不安全html代码。 //http://blog.ddian.cn function safestrip($string){    $string = strip_tags(...

git的几个小技巧

git的几个小技巧

分享git的几个小技巧,后面会根据使用补充。目前包括git撤销本地修改、git回退到前n个版本、git多用户提交冲突解决、git 命令简化。欢迎大家补充^_*1、git撤销本地修改 Java git reset --hard origin/ma...

thinkphp获取URL参数

一般情况下URL中的参数就是通过GET方法获取,但是由于PATHINFO的特 殊性,URL地址最终需要被解析才能转换成GET参数,ThinkPHP对URL是按照一定的规则进行解析的,除非你使用了URL路由规则,如果你对 URL做了特别的定制,但是又不想使用URL路由,那么可以使用框架提供的URL...

ThinkPHP分页的实现

分页类需要和查询相结合,我们可以使用ThinkPHP自带的limit方法或者page方法,目的就是为了获取当前分页的数据(也有先获取完整数据然后前端分页显示的方法,不在本文描述内容中,也不建议)。使用limit方法或者page方法是和数据库类型无关的。我们首先在数据库里面创建一个think_data...

phpcms v9更换模板的具体操作方法

phpcms v9更换模板的具体操作方法

这篇文章主要介绍了phpcms v9更换模板的具体操作方法,需要的朋友可以参考下分享一下Phpcms V9更换模板的具体操作方法先分享下大概的步骤:1、上传模版文件到服务器;2、在站点管理 里边【模板风格配置】选择新模板;3、设置不同模型对应模板;4、修改现有的栏目,匹配新模板;5、更新栏目缓存、系...

php利用百度地图API进行IP定位和GPS定位

最 近在做一个手机端的webapp地图应用,而核心内容当然是定位了,但是定位的话有几种方式,IP定位,GPS定位,基站定位(这个貌似webapp用不 了), 那么剩下核心的gps定位和ip定位了,我们知道,html5有定位API,但是该API拿到的GPS数据是硬件坐标,无法直接显示在地图上。...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。