首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在mysql和filemaker之间获得正确的字符编码

如何在mysql和filemaker之间获得正确的字符编码
EN

Stack Overflow用户
提问于 2011-07-27 16:34:05
回答 3查看 1.1K关注 0票数 1

我不确定这是php、filemaker、mysql还是odbc驱动程序的问题。

出于安全原因,我当前php webform的输入域将特殊字符转换为十六进制代码(例如:#变成' )此十六进制代码保存在数据库中,也将在Filemaker11中显示为十六进制代码。这不是我想要的。如何确保特殊字符将按其应有的方式显示?

反过来(从filemaker到db),在插入特殊字符时不会进行任何转换。

我怎样才能确保每件事都是一致的?

致以亲切的问候,杰伦

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-07-29 05:19:30

解决了!似乎我必须在PHP脚本中添加额外的一行。

在建立连接之后,php需要告诉mysql需要什么编码。这可以使用下面的代码行来完成:

代码语言:javascript
复制
$dbh->query("SET NAMES 'utf8'");

谢谢大家的努力!

票数 1
EN

Stack Overflow用户

发布于 2011-07-27 23:49:21

FileMaker只是显示存储在MySQL中的数据。如果在PhpMyAdmin这样的工具中启动DB,您应该会看到varchar也包含编码。由于FMP只是将其视为文本字段,因此它显示了存储的编码。如果你想在FMP中解码,你可以显示varchar的calc字段,它有一个自定义函数来解码文本。(但这将不允许更新数据。)您还可以尝试在记录加载时使用触发器来解码字段中的数据,以便可以正确地查看/编辑。

票数 1
EN

Stack Overflow用户

发布于 2011-07-27 17:29:53

这一点:'类型的编码不是由浏览器自动完成的。有什么东西在做这件事。通常情况下,您只对输出执行此操作,而不对输入执行此操作。

您可以使用html_entity_decode()来撤消它。但我强烈建议你首先弄清楚为什么会发生这种情况。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6841512

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档