【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编辑

    目录
    相关文章
    |
    4月前
    |
    前端开发 API UED
    Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
    Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
    135 2
    |
    2月前
    |
    JSON Java 关系型数据库
    Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
    在Java中,使用mybatis-plus更新实体类对象到mysql,其中一个字段对应数据库中json数据类型,更新时报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
    232 4
    Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
    |
    2月前
    |
    XML 前端开发 JavaScript
    PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑
    本文深入探讨了PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑;Ajax则通过异步请求实现页面无刷新更新。文中详细介绍了两者的工作原理、数据传输格式选择、具体实现方法及实际应用案例,如实时数据更新、表单验证与提交、动态加载内容等。同时,针对跨域问题、数据安全与性能优化提出了建议。总结指出,PHP与Ajax的结合能显著提升Web应用的效率和用户体验。
    70 3
    |
    2月前
    |
    前端开发 API 开发者
    Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
    在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
    68 1
    |
    3月前
    |
    前端开发 API 开发者
    从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
    从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
    52 3
    |
    3月前
    |
    JSON JavaScript 前端开发
    《进阶篇第7章》学习vue中的ajax之后,练习vue案例-github用户搜索案例
    《进阶篇第7章》学习vue中的ajax之后,练习vue案例-github用户搜索案例
    24 0
    |
    8月前
    |
    XML 前端开发 JavaScript
    使用 AJAX 提升网页数据的动态交互
    使用 AJAX 提升网页数据的动态交互
    |
    5月前
    |
    XML 存储 前端开发
    后端程序员的前后端交互核心-Ajax
    后端程序员的前后端交互核心-Ajax
    67 6
    后端程序员的前后端交互核心-Ajax
    |
    5月前
    |
    前端开发 JavaScript Java
    Ajax进行异步交互:提升Java Web应用的用户体验
    Ajax 技术允许在不重载整个页面的情况下与服务器异步交换数据,通过局部更新页面内容,极大提升了 Java Web 应用的响应速度和用户体验。本文介绍 Ajax 的基本原理及其实现方式,包括使用 XMLHttpRequest 对象发送请求、处理响应数据,并在 Java Web 应用中集成 Ajax。此外,还探讨了 Ajax 如何通过减少页面刷新、实时数据更新等功能改善用户体验。
    89 3
    |
    5月前
    |
    XML JSON 前端开发
    JSON与AJAX:网页交互的利器
    JSON与AJAX:网页交互的利器
    46 0

    热门文章

    最新文章

    AI助理

    你好,我是AI助理

    可以解答问题、推荐解决方案等