我想弄清楚如何使用 xml 和 php 处理多语言?我希望能够默认使用英语,但是如果用户选择了一种语言,比如说德语,我想将语言更改为该语言。这部分我可以弄清楚,但如果某个语言字符串尚未翻译成德语,我希望能够选择该字符串的英文版本。我已经用常规的 php 和 mysql 做到了这一点,如下所示:
$language = "de";
$sql = "SELECT * FROM ".$prefix."_countries WHERE con_id=$language";
$result = mysql_query($sql) ;
$row = mysql_fetch_assoc($result);
$userlang = $row['lang'];
$languagestring = array();
$res1 = mysql_query("SELECT * FROM ".$prefix."_language WHERE lang = 'en'");
while($row1 = mysql_fetch_assoc($res1)){
$langid = $row1['id'];
$res = mysql_query("SELECT * FROM ".$prefix."_language WHERE fk_id = $langid AND lang = '$userlang'");
$row = mysql_fetch_assoc($res);
if(!$row){
$languagestring[] = $row1['text'];
} else {
$str = $row['text'];
$languagestring[] = $str;
}
}
现在我已经以与数据库相同的方式构建了我的 xml,如下所示:
<data>
<record id="1">
<fk_id>0</fk_id>
<lang>en</lang>
<text>Network Error</text>
</record>
<record id="2">
<fk_id>0</fk_id>
<lang>en</lang>
<text>There is a problem with the network!</text>
</record>
<record id="3">
<fk_id>0</fk_id>
<lang>en</lang>
<text>OK</text>
</record>
<record id="4">
<fk_id>1</fk_id>
<lang>de</lang>
<text>Das netvaerk sind corrupt!</text>
</record>
' 我怎样才能用 xml 完成我对 mysql 所做的事情?
任何帮助表示赞赏:-)