json_encode produce JSON_ERROR_UTF8 from MSSQL-SELECT


json_encode produce JSON_ERROR_UTF8 from MSSQL-SELECT

我在向mssql查询数据库时遇到了一个恼人的问题。如果结果包含像德语"ä"这样的特殊字符,我无法使用json_encode将结果正确地作为json获得。

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

phpmssql.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 
));

对我来说,这是一种更轻松的方式。