【Json与Ajax交互报错解决】No converter found for return value of type: class com.github.pagehelper.PageInfo

简介: 【Json与Ajax交互报错解决】No converter found for return value of type: class com.github.pagehelper.PageInfo

 

Hello。你好呀,我是灰小猿,一个超会写bug的程序猿!

我今天又来修BUG了!!

image.gif编辑

事情是这样的:今天在整合SSM,读取数据库数据返回JSON字符串,并传递给前端界面Ajax进行交互的时候,向后台发送请求想要获取到返回的json数据,但是却出现了这样的错误,页面显示500:

image.gif编辑

HTTP Status 500 - org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.IllegalArgumentException: No converter found for return value of type: class com.github.pagehelper.PageInfo

我翻译了一下大概意思就是:

请求处理失败; 嵌套异常是java.lang.IllegalArgumentException:没有找到转换器的类型返回值:类com.github.pagehelper.PageInfo  

然而我的能够从数据库中读取到数据并且返回JSON字符串的代码是这样的:

/**
   * 返回的数据携带json字符串 需要导入jackson包 
   * @param pn
   * @param model
   * @return
   */
  @RequestMapping("/emps")
  @ResponseBody
  public PageInfo getEmpsWithJson(@RequestParam(value = "pn", defaultValue = "1") Integer pn) {
    // 传入需要跳转的页面以及展示的数据量
    PageHelper.startPage(pn, 5);
    // 获取到全部数据
    List<Employee> employees = employeeService.getAll();
    System.out.println("查询到的数据:");
    System.out.println(employees);
    // 使用pageinfo包装查询的数据,只需要将pageinfo交给页面即可
    // 传入数据,以及要显示多少页
    PageInfo page = new PageInfo(employees, 5);
    System.out.println("封装数据:");
//    System.out.println(page);
    return page;
  }

image.gif

我这里使用了@responseBody注解,该注解的作用就是会自动将返回数据封装成json格式,但是现在我的前台接收不到封装的json对象,查到的数据也无法封装成JSON对象,

最开始我找不到问题的解决,在网上找到了很多类似的错误,但是他们回答都模棱两可,并不能实际的解决问题,难道说程序员寻找bug的救命稻草的时候都是这样的嘛?

image.gif编辑

网上的解决基本上都是说导入json的依赖,但是现在使用Maven做项目的时候,在pom.xml中引入json的依赖坐标,一般都会自动生成相应的三个jar包,分别是

    • jackson-databind-x.x.x.jar
    • jackson-annotations-x.x.x.jar
    • jackson-core-x.x.x.jar

    小伙伴们看一下,如果说哪个小伙伴发现确实是缺少这三个jar中的其中一个,那么你去导入一下就行了,导入的时候可以到如下的maven仓库导入:

    https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind/2.7.4

    但是现在基本上都不会说是缺少上面的哪个jar包了,

    所以如果你并没有缺少jar包,那么应该咱们的问题就一样了!

    解决方案:

    对于No converter found for return value of type错误,原因一般都是jar包版本冲突的问题,和它冲突的jar包是spring的相关jar包,具体为什么冲突我也不知道........

    image.gif编辑

    我的spring的jar包的版本是4.3.7的,然后json的版本使用2.8.8的运行会报上述错误,

    所以解决就是更换其他版本的json的jar包,我建议的是更换低版本的,我更换了2.7.4的jar包,然后再运行就可以了,如果你的不行,你可以再换个其他版本的jar包试试,

    在pom.xml中导入json的jar包的依赖代码是:

    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.7.4</version>
    </dependency>

    image.gif

    接着重新启动tomcat,再运行就正确了!

    image.gif编辑

    如果大家还有其他解决方法,欢迎留言提出!

    我是灰小猿,我们下期见!

    image.gif编辑

    目录
    相关文章
    |
    2月前
    |
    前端开发 API UED
    Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
    Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
    81 2
    |
    2天前
    |
    前端开发 API 开发者
    Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
    在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
    8 1
    |
    7天前
    |
    存储 JSON 监控
    公司用什么软件监控电脑:JSON 在监控信息交互中的应用探索
    在现代企业管理中,电脑监控软件广泛应用于保障信息安全和提升工作效率。JSON(JavaScript Object Notation)因其简洁和易读性,在监控信息的收集、传输和处理中扮演着关键角色。本文介绍了 JSON 在监控数据结构、信息传输及服务器端处理中的具体应用,展示了其在高效监控系统中的重要性。
    22 0
    |
    1月前
    |
    前端开发 API 开发者
    从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
    从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
    38 3
    |
    23天前
    |
    存储 JSON 前端开发
    JSON与现代Web开发:数据交互的最佳选择
    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也便于机器解析和生成。它以文本格式存储数据,常用于Web应用中的数据传输,尤其是在客户端和服务器之间。
    32 0
    |
    25天前
    |
    数据安全/隐私保护
    github报错(完美解决):获取token。remote: Support for password authentication was removed on August 13, 2021.
    这篇文章介绍了如何在GitHub上解决因密码认证被移除而导致的推送错误,通过创建和使用个人访问令牌(token)来代替密码进行身份验证。
    143 0
    |
    2月前
    |
    JSON 前端开发 JavaScript
    JavaWeb基础8——Filter,Listener,Ajax,Axios,JSON
    Filter过滤器、Listener监听器、AJAX、 同步、异步优点和使用场景、Axios异步框架、JSON、js和JSON转换、案例,Axios + JSON 品牌列表查询和添加
    JavaWeb基础8——Filter,Listener,Ajax,Axios,JSON
    |
    3月前
    |
    XML 存储 前端开发
    后端程序员的前后端交互核心-Ajax
    后端程序员的前后端交互核心-Ajax
    54 6
    后端程序员的前后端交互核心-Ajax
    |
    3月前
    |
    前端开发 JavaScript Java
    Ajax进行异步交互:提升Java Web应用的用户体验
    Ajax 技术允许在不重载整个页面的情况下与服务器异步交换数据,通过局部更新页面内容,极大提升了 Java Web 应用的响应速度和用户体验。本文介绍 Ajax 的基本原理及其实现方式,包括使用 XMLHttpRequest 对象发送请求、处理响应数据,并在 Java Web 应用中集成 Ajax。此外,还探讨了 Ajax 如何通过减少页面刷新、实时数据更新等功能改善用户体验。
    67 3
    |
    3月前
    |
    JSON 前端开发 JavaScript
    JSON parse error: Cannot deserialize value of type `java.lang.Integer` from Boolean value
    这篇文章讨论了前端Vue应用向后端Spring Boot服务传输数据时发生的类型不匹配问题,即后端期望接收的字段类型为`int`,而前端实际传输的类型为`Boolean`,导致无法反序列化的问题,并提供了问题的诊断和解决方案。
    JSON parse error: Cannot deserialize value of type `java.lang.Integer` from Boolean value