Flutter从服务器中获取日语字符,解码错误
问题内容:
我正在使用Flutter构建移动应用程序。
我需要json
从服务器中获取包含日语文本的文件。返回的一部分json
是:
{
"id": "egsPu39L5bLhx3m21t1n",
"userId": "MCetEAeZviyYn5IMYjnp",
"userName": "巽 裕亮",
"content": "フルマラソン完走に対して2018/05/06のふりかえりを行いました!"
}
在邮递员或chrome上尝试相同的请求将获得预期的结果(日语字符在输出中正确呈现)。
但是,通过以下代码段使用Dart提取数据时:
import 'dart:convert';
import 'package:http/http.dart' as http;
//irrelevant parts have been omitted
final response = await http.get('SOME URL',headers: {'Content-Type': 'application/json'});
final List<dynamic> responseJson = json.decode(response.body)
print(responseJson);
print
logcat中语句的结果是
{
id: egsPu39L5bLhx3m21t1n,
userId: MCetEAeZviyYn5IMYjnp,
userName: å·½ è£äº®,
content: ãã«ãã©ã½ã³å®èµ°ã«å¯¾ãã¦2018/05/06ã®ãµãããããè¡ãã¾ããï¼
}
请注意,只有日语字符(content
键的值)变成乱码,其他非日语值仍然可以正确显示。
有两个注意事项:
- 如果我尝试通过来在我的应用程序中显示此日语文本,
Text()
则会呈现相同的乱码,因此这不是Android Studio的logcat的错误。 - 如果我使用
Text('put some Japanese text here directly')
(exText('睡眠')
:),Flutter会正确显示它,所以不是Text
使日语字符弄乱的小部件。
问题答案:
如果查看邮递员,您可能会看到Content-Type
服务器发送的http标头缺少该encoding
标记。这会导致Dart
http客户端将主体解码为Latin-1而不是utf-8。有一个简单的解决方法:
http.Response response = await http.get('SOME URL',headers: {'Content-Type': 'application/json'});
List<dynamic> responseJson = json.decode(utf8.decode(response.bodyBytes));