json_encode从MSSQL-SELECT生成JSON_ERROR_UTF8?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (287)

我对mssql的数据库查询有一个恼人的问题。如果结果包含像德语'ä'这样的特殊字符,我就不能使用json_encode将结果正确地作为json。

json_last_error返回5,等于JSON_ERROR_UTF8。我猜数据库不会返回UTF-8编码的值。数据库集合是* Latin1_General_CI_AS *,受影响的列是varchars

php mssql.charset配置无效。

我读过mysql用户可以用来mysql_query('SET CHARACTER SET utf8');正确编码返回值。我该怎么做才能正确获取mssql的值?

提问于
用户回答回答于

在进行JSON编码之前,请使用utf8_encode()

用户回答回答于

你可以在连接中设置如下内容:

$result = sqlsrv_connect($hostname, array(
    'UID' => $username,
    'PWD' => $password,
    'Database' => $database,
    "CharacterSet" => "UTF-8"   // <---- here the magic happens 
));

扫码关注云+社区

领取腾讯云代金券