php – 保存行时字符丢失?

$userTb = new My_Tb_User();  //Child of Zend_Db_Table_Abstract
$row = $userTb->find(9)->current();
$row->name = 'STÖVER';
$row->save();

在第9行的内部用户表中,名称列值ST是否存储而不是STÖVER?

Ö是UTF-8支持的德语字符.如果我使用phpmyadmin手动输入’STÖVER’,它将被正确存储.

在创建db adapter时我也传递了值为utf8的charset参数,但仍然没有运气!

解决方法:

使用utf8_encode是一种不好的做法,这会给你的应用增加很多复杂性.尝试通过查找源来解决问题.

Ssome的想法:

>数据库服务器charset问题(检查服务器的编码)
>数据库客户端字符集问题(检查连接的编码)
>数据库表charset问题(检查表的编码)
>一个php默认编码问题(检查parameters.ini中的default_encoding参数)
>多字节未配置(请参阅parameters.ini中的mb_string参数)
> a< form> charset问题(检查它是否以utf-8发送)
> a< html> charset问题(你的html文件中没有设置enctype)
>内容编码:问题(Apache发送错误的编码).

上一篇:PHP中的多字节安全保护


下一篇:在哪里可以获得PHP的所有多字节函数的完整列表?