php – 非拉丁字符&ouch

我开始了解Cake PHP,它已经发现了关于PHP / MysqL字符集内容的最佳实践的一般性问题,我希望可以在这里得到解答.

我的(练习)系统包含一个电影的MysqL表.此列表源自Excel工作表,该工作表已导出为CSV,并通过PHPMyAdmin导入.

我注意到具有更多“异国情调”字形的标题在浏览器中呈现出问题,例如Amélie中的é.使用Cake或普通PHP,它呈现为?,除非通过htmlentities转换为& eacute;.具有特殊字符的链接根本不会呈现.

如果我使用我的Cake输入表单输入< alt> 0233,则会在源代码中正确呈现,但作为& Atilde;& copy;通过htmlentities.

经过快速的SO搜索后,我决定UTF-8可以解决问题,因此我

>将PHP源和CSV文件编码更改为UTF-8
>确保< Meta>东西在那里(它已经通过Cake的认布局).
>确保我的浏览器认为该文档是UTF-8(他们这样做)
>将MysqL DB上的排序规则更改为utf-8 general_ci(作为有缺陷的UTF-8选项的受过教育的准备)
>删除并重新导入我的数据

但是,我仍然被卡住了.我注意到PHPMyAdmin设法在浏览记录时在其HTML源中“正确”呈现字符.

我觉得文档编码是罪魁祸首,但是,我想知道是否有人可以提供最佳答案:

>将数据从Excel移动到MysqL以保留字形的最佳方法是什么?
>为了适应这种情况,我的桌子的最佳设置是什么?
>我更喜欢使用UTF-8本地显示é,我可以在Cake中做什么,以避免对htmlentities这样的调用进行大量调用,即是否有配置设置或方式我设置的东西使得这个更友好,让蛋糕原生助手像Html->链接工作?

一些代码,以防万一:

电影控制器摘录..

function index() {
        $this->set('movies' , $this->Movie->find('all'));

}

index.ctp视图摘录

<?PHP foreach ($movies as $movie): ?>
<tr>
    <td><?PHP echo $movie['Movie']['id']; ?></td>
    <td><?PHP echo htmlentities($movie['Movie']['title']); ?>
    <td><?PHP echo $this->Html->link($movie['Movie']['title'] , 
    array('controller' => 'movies' , 'action' => 'view' , $movie['Movie']['id'])); ?>
    </td>

    <td><?PHP echo $this->Html->link("Edit", 
    array('action' => 'edit' , $movie['Movie']['id'])); ?>
    </td>

    <td>
    <?PHP echo $this->Html->link('Delete', array('action' => 'delete', $movie['Movie']['id']), null, 'Are you sure?')?>
    </td>

</tr>
<?PHP endforeach; ?>

提前感谢任何帮助/提示.

解决方法:

确保在导入数据时将MysqL连接设置为UTF-8.排序规则仅用于排序和比较,而不用于保存数据.

您可以使用SET NAMES’utf-8’设置连接的字符集;在sql文件的开头.

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...