在我的 PHP 网站中,我使用SiteTranslator脚本将网站翻译成 30 种语言。每个翻译都存储在自己的表中(text_en、text_de...),每个表有 3 列(textKey、textValue、lastUpdate)。
现在我想在我的 CodeIgniter 应用程序中使用该数据库。最好的方法是什么?
在我的 PHP 网站中,我使用SiteTranslator脚本将网站翻译成 30 种语言。每个翻译都存储在自己的表中(text_en、text_de...),每个表有 3 列(textKey、textValue、lastUpdate)。
现在我想在我的 CodeIgniter 应用程序中使用该数据库。最好的方法是什么?
您可以按照建议使用多个数据库,您仍然需要设置您的应用程序语言文件
{在用户指南中阅读更多内容}
根据第一个 uri 段,您可以尝试这样的事情。
添加路线
$route['en|fr|gr/test'] = 'test';
第一段检查en或fr或其他任何东西。
然后主控制器在初始化测试控制器并设置db(object) && app(language)文件之前捕获第一段
www.site.com/en/test => 加载英语语言文件(application/language/english/mylanguage)和 db
www.site.com/fr/test => 加载法语语言文件(application/language/french/mylanguage)和db ...等等
主控制器
class MY_Controller extends CI_Controller{
protected $lang, $db;
public function __construct(){
parent::__construct();
$this->set_language();
}
protected function set_language(){
switch($this->uri->segment(1))
{
case 'en':
$this->lang = $this->lang->load('mylanguage', 'english');
$this->db = $this->load->database('en', TRUE);
break;
case 'fr':
$this->lang = $this->lang->load('mylanguage', 'french');
$this->db = $this->load->database('fr', TRUE);
break;
default:
$this->lang = $this->lang->load('mylanguage', 'english');
$this->db = $this->load->database('en', TRUE);
break;
}
}
}