CodeIgniter多语言实现方法详解

原文:https://www.jb51.net/article/78364.htm

文实例分析了CodeIgniter多语言实现方法。分享给大家供大家参考,具体如下:

CI应用目录下有一个language语言包目录,用来配置多种不同的语言。语言的配置位于config文件中,配置格式如下:

复制代码代码如下:

$config['language'] = 'english';

 

定义语言文件

language下有个空的english目录,即上面定义的系统默认语言目录,系统会从该目录加载语言包文件。如果要定义不同的语言包,如zh_cn,则创建zh_cn目录并配置相应语言包文件即可。需要注意的是,语言文件的后缀必须为_lang.php,语言翻译通过数组的键值对来实现,为防止出现重复的键名,可以为键名增加统一的前缀。

配置的方式可参考下面:

?

1

2

3

4

5

6

7

$lang['menu_system_title'] = '系统设置';

$lang['menu_system_user_admin'] = '用户管理';

$lang['menu_system_user_list'] = '用户列表';

$lang['menu_system_user_detail'] = '用户详情';

$lang['menu_system_setting'] = '配置管理';

/* End of file user_menu_lang.php */

/* Location: ./system/language/zh_tw/user_menu_lang.php */

语言包的使用

使用语言包之前需要先加载语言包,加载和使用方式如下:

?

1

2

3

4

5

6

7

8

9

//加载方式一,加载时不需要传入_lang

$this->load->language(array('user_menu', 'user_message'));

//加载方式二

$this->lang->load('user_menu');

//使用方式一

echo $this->lang->line('language_key');

//使用方式二(需先加载language帮助函数)

$this->load->helper('language');

echo lang('menu_system_title');

可以说语言包的使用相当简单,前不久也做了个台湾版的系统,顺便说下CI中的语言包的使用及需要注意的问题。

1、$config['language'] 直接配置成 zh_cn 会怎么样?

系统中有一些默认的语言包位于system/language/english目录下,当使用系统中提供的一些类报错时会加载对应的语言包。此时系统会先到language/zh_cn目录下去查找,然后去system/language/zh_cn目录下查找,都找不到就提示找不到语言包的错误。所以若更改了language配置,最好拷贝system/language/english下的文件到对应的语言目录下。

这里看起来有点奇怪,为什么不是这种思维:先到language/zh_cn目录下去找,找不到就到system/language/english目录下去找。叫english可能不合适,应该称呼为系统默认的语言包。

2、是否需要使用语言包?

在某个系统中发现这样子的情况, 有些错误提示用的语言包,有些直接用的中文,可能因为多人开发的原因,键的命名也不太规范,经常需要去对比对应的语言文件,导致程序阅读起来相对麻烦,而中文的则没该问题,个人在系统中使用语言包也觉得有点麻烦。所以,不需要考虑多语言的程序尽量还是不要使用语言包的好。

3、如何自动检测语言包?

通常情况下可以根据浏览器的语言类型来判断,PHP中的$_SERVER['HTTP_ACCEPT_LANGUAGE']可以获取到该值,然后根据字符串分隔或者正则匹配等方式即可获取到客户端浏览器默认语言类型。获取到之后通过

复制代码代码如下:

$this->config->set_item('language', 'zh_cn');

设置即可。

 

关于是否确实使用了语言包,可以重写lang函数,带^_^即为使用了语言包,参考如下:

?

1

2

3

4

5

6

7

8

9

10

function lang($line, $param = array())

{

  $CI =& get_instance();

  $line = $CI->lang->line($line);

  if(is_array($param) && count($param) > 0) {

    array_unshift($param, $line);

    $line = call_user_func_array('sprintf', $param);

  }

  return '^_^'.$line;

}

很多情况下多语言的实现都是通过数组的形式来实现,还有一些是.mo的格式,l18n多语言的实现方式,php中需要php_gettext扩展支持,详情可查阅相关资料。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CodeIgniter本身并没有提供读写分离的功能,但是我们可以通过扩展CodeIgniter的数据库类来实现读写分离。 以下是一种简单的实现方式: 1. 在application/core目录下创建MY_DB.php文件,内容如下: ``` class MY_DB extends CI_DB { protected $_slave_db = NULL; public function __construct($params = '') { parent::__construct($params); // 连接从数据库 $this->_slave_db = $this->CI->load->database('slave', TRUE); } /** * 执行读操作 */ public function read($sql, $binds = FALSE, $return_object = TRUE) { return $this->_slave_db->query($sql, $binds, $return_object); } /** * 执行写操作 */ public function write($sql, $binds = FALSE, $return_object = TRUE) { return $this->query($sql, $binds, $return_object); } } ``` 2. 在配置文件中设置主从数据库连接信息,application/config/database.php: ``` // 主数据库 $db['default'] = array( 'dsn' => '', 'hostname' => 'localhost', 'username' => 'root', 'password' => '', 'database' => 'db_master', 'dbdriver' => 'mysqli', 'dbprefix' => '', 'pconnect' => FALSE, 'db_debug' => (ENVIRONMENT !== 'production'), 'cache_on' => FALSE, 'cachedir' => '', 'char_set' => 'utf8', 'dbcollat' => 'utf8_general_ci', 'swap_pre' => '', 'encrypt' => FALSE, 'compress' => FALSE, 'stricton' => FALSE, 'failover' => array(), 'save_queries' => TRUE ); // 从数据库 $db['slave'] = array( 'dsn' => '', 'hostname' => 'localhost', 'username' => 'root', 'password' => '', 'database' => 'db_slave', 'dbdriver' => 'mysqli', 'dbprefix' => '', 'pconnect' => FALSE, 'db_debug' => (ENVIRONMENT !== 'production'), 'cache_on' => FALSE, 'cachedir' => '', 'char_set' => 'utf8', 'dbcollat' => 'utf8_general_ci', 'swap_pre' => '', 'encrypt' => FALSE, 'compress' => FALSE, 'stricton' => FALSE, 'failover' => array(), 'save_queries' => TRUE ); ``` 3. 在控制器中使用: ``` class Example extends CI_Controller { public function index() { $this->load->database(); // 执行读操作 $result = $this->db->read("SELECT * FROM `table`"); // 执行写操作 $this->db->write("INSERT INTO `table` (`name`, `age`) VALUES (?, ?)", array('John', 20)); } } ``` 这样,就可以实现简单的读写分离了。当然,实际的应用场景可能更加复杂,需要根据具体的情况进行调整和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值