前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >如何解决 .JsonParseException: Unexpected character (‘<‘ (code 60)): expected a valid value (JSON String,

如何解决 .JsonParseException: Unexpected character (‘<‘ (code 60)): expected a valid value (JSON String,

作者头像
猫头虎
发布2025-03-21 08:43:34
发布2025-03-21 08:43:34
3900
代码可运行
举报
运行总次数:0
代码可运行

如何解决 .JsonParseException: Unexpected character ('<' (code 60)): expected a valid value (JSON String, Number, Array, Object or token 'null', 'true' or 'false')

在开发过程中,处理 JSON 数据时遇到 JsonParseException 错误是非常常见的。尤其是以下这种错误提示:

代码语言:javascript
代码运行次数:0
运行
复制
.JsonParseException: Unexpected character ('<' (code 60)): expected a valid value (JSON String, Number, Array, Object or token 'null', 'true' or 'false')

这个错误通常出现在你尝试解析一个 JSON 数据时,数据的格式不符合预期。具体来说,这个错误说明在解析过程中,遇到了一个 < 字符,这通常意味着你期望解析一个有效的 JSON 数据(如字符串、数字、数组、对象等),但实际上得到的是 HTML 页面或者错误信息。

正文

错误原因

这个错误通常发生在以下几种场景:

  1. 错误的 URL 或 API 响应:你可能请求了一个 API 或加载了一个 URL,预期返回的是 JSON 数据,但实际返回的是 HTML(可能是一个错误页面)。HTML 页面通常会包含 < 字符,因此导致了解析错误。
  2. 服务器返回 HTML 错误信息:如果服务器在遇到错误时返回了 HTML 格式的错误页面,而你仍然尝试将其解析为 JSON 数据,也会遇到这个错误。
  3. 网络问题:网络中断或请求超时等问题可能导致返回的不是预期的 JSON,而是一个 HTML 页面,包含 < 字符。

解决方案

为了修复这个问题,我们可以采取以下几种方法来确保正确处理 JSON 数据。

1. 检查 API 响应

首先,确认你请求的 URL 或 API 确实返回 JSON 数据。你可以通过以下方式进行验证:

  • 手动检查响应:使用浏览器或者工具(如 Postman)访问 API,查看返回的内容是不是 JSON 格式。若返回 HTML 页面,说明 API 出现问题。
  • 查看响应头:确保响应头中的 Content-Typeapplication/json,这可以帮助你判断服务器返回的数据类型。
2. 添加错误处理机制

确保你在解析 JSON 数据时,添加适当的错误处理机制,以防万一遇到非预期的响应格式。可以通过捕获异常来处理这种情况:

代码语言:javascript
代码运行次数:0
运行
复制
try {
    String jsonResponse = getApiResponse();  // 假设这是获取 API 响应的代码
    JSONObject jsonObject = new JSONObject(jsonResponse);  // 解析 JSON
} catch (JsonParseException e) {
    System.out.println("JSON 解析错误: " + e.getMessage());
    // 处理错误或打印出更多的错误信息
} catch (Exception e) {
    System.out.println("其他错误: " + e.getMessage());
    // 其他错误处理
}

通过这种方式,你可以捕获和记录错误,避免程序崩溃,同时让用户知道发生了什么。

3. 调试与日志记录

启用日志记录可以帮助你分析发生错误的原因,尤其是在请求过程中。如果你使用的是某些框架(例如 Spring),可以启用 HTTP 请求和响应的日志记录,以便查看请求的实际内容。

代码语言:javascript
代码运行次数:0
运行
复制
// 在 Spring 中,可以通过拦截器来记录请求和响应的详细信息
public class LoggingInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("Request URL: " + request.getRequestURL());
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("Response Status: " + response.getStatus());
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        // 可以记录响应内容
    }
}
4. 使用条件判断

如果你不确定返回的数据类型,可以首先检查返回的内容,判断是否为 JSON 格式。如果不是,可以选择跳过解析或者尝试其他的处理方法。

代码语言:javascript
代码运行次数:0
运行
复制
if (jsonResponse.startsWith("{") || jsonResponse.startsWith("[")) {
    // 如果数据以 '{' 或 '[' 开头,说明是 JSON 数据
    try {
        JSONObject jsonObject = new JSONObject(jsonResponse);
    } catch (JsonParseException e) {
        // 处理解析错误
    }
} else {
    // 如果不是 JSON 数据,进行相应处理
    System.out.println("返回的数据不是 JSON 格式");
}
5. 检查网络请求

如果你怀疑问题是由网络连接问题引起的(例如,超时或中断导致的 HTML 错误页面),可以检查你的网络请求设置,确保它们在请求失败时进行适当的重试或超时处理。

代码语言:javascript
代码运行次数:0
运行
复制
RequestConfig requestConfig = RequestConfig.custom()
    .setConnectTimeout(5000)  // 设置连接超时
    .setSocketTimeout(5000)   // 设置读取超时
    .build();
CloseableHttpClient httpClient = HttpClients.custom().setDefaultRequestConfig(requestConfig).build();
总结

JsonParseException: Unexpected character ('<' (code 60)) 错误通常是因为服务器返回了 HTML 页面,而你期望的是 JSON 格式的数据。通过检查 API 响应、增加错误处理、启用日志记录和检查网络请求,可以有效地解决这个问题。最重要的是在开发过程中保持灵活性和健壮性,确保对可能发生的各种错误做出合适的处理。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-03-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 如何解决 .JsonParseException: Unexpected character ('<' (code 60)): expected a valid value (JSON String, Number, Array, Object or token 'null', 'true' or 'false')
  • 正文
    • 错误原因
    • 解决方案
      • 1. 检查 API 响应
      • 2. 添加错误处理机制
      • 3. 调试与日志记录
      • 4. 使用条件判断
      • 5. 检查网络请求
      • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档