1

在我的 PHP 网站中,我使用SiteTranslator脚本将网站翻译成 30 种语言。每个翻译都存储在自己的表中(text_en、text_de...),每个表有 3 列(textKey、textValue、lastUpdate)。

现在我想在我的 CodeIgniter 应用程序中使用该数据库。最好的方法是什么?

4

1 回答 1

1

您可以按照建议使用多个数据库,您仍然需要设置您的应用程序语言文件

{在用户指南中阅读更多内容}

根据第一个 uri 段,您可以尝试这样的事情。

添加路线

$route['en|fr|gr/test'] = 'test';

第一段检查enfr或其他任何东西。

然后主控制器在初始化测试控制器并设置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;
        }
    }


}
于 2012-09-06T12:17:26.657 回答