异常:Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception 已解决

异常:Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception 已解决既然和DispatcherServlet有关,那无非就是MVC的映射出了问题

大家好,又见面了,我是你们的朋友全栈君。

原创博文,欢迎转载,转载时请务必附上博文链接,感谢您的尊重。

前言

急于现在、立刻、马上解决问题的同学,请直接拉到最下面【解决办法】!!!希望可以帮到你。

小编最近再做一个工作,就是将公司一套老项目移植到新框架,所谓“新三年,旧三年,缝缝补补再三年”,重新装修一下,方便公司涨价再卖嘛。然后,就遇到了这个 “dispatcherServlet” 的异常问题。

起初还以为是 SpringBoot 底层框架的问题,毕竟涉及到了 DispatcherServlet 嘛,知道真相的我却眼泪掉下来,呃呃呃 …

阅读本篇,你可能会需要的博文:

异常:Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception 已解决


问题描述

ERROR http-nio-8080-exec-1 (DirectJDKLog.java:175) – Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is java.lang.NullPointerException] with root cause  
java.lang.NullPointerException: null

异常截图:

异常:Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception 已解决

原因分析

我总结了下,既然和 DispatcherServlet 有关,那无非就是MVC的映射出了问题,通俗的理解,就是:JVM编译期有个 servlet 加载/调用失败了。

我画了一张图,和大家一起复习下 DispatcherServlet :

异常:Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception 已解决

整个流程可以被大致描述为:

  1. 一个http请求到达服务器,被DispatcherServlet接收。
  2. DispatcherServlet将请求委派给合适的处理器Controller,此时处理控制权到达Controller对象。
  3. Controller内部完成请求的数据模型的创建和业务逻辑的处理,然后再将填充了数据后的模型即model和控制权一并交还给DispatcherServlet,委派DispatcherServlet来渲染响应。
  4. DispatcherServlet再将这些数据和适当的数据模版视图结合,向Response输出响应。

解决办法

解决问题以后我又认真的研究了下,结合众多前辈的经验教训做出如下总结,算是很全面了:

1.  编译出错

原因分析:未知原因,JVM没有编译新创建的类,需要强制重构一下项目(可以理解为电脑的关机重启)

解决办法:(IDEA为例)导航栏 –> Build –> ReBuild Project

2. Controllor 层引入的 Service 接口上面忘记写 @Resource 或 @Autowired 注解

原因分析:原因同【1】,区别在于这是人为造成的项目编译期找不到某个类

解决办法:仔细检查程序,在引入的Service层实现类上添加注解 @Autowired 或 @Resource 注解

3. Controllor 层调用的方法是 private 私有的,导致分发失败

原因分析:老框架为什么可以我没研究,所以不敢乱讲,但是MVC,SpringBoot,SpringBootCloud框架都要求是 public

解决办法:找到出错方法,将接口类的方法改成 public,如下图所示 ↓↓↓

异常:Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception 已解决

4. 其他,如:SpringBoot注解没有正确使用

具体问题要具体分析,问题的描述在异常里写的很清楚,比如我的异常是“… java.lang.NullPointerException: null ”,这很明显是少了东西嘛,所以才有上面 “1~3 ” 的可能性。

小编还见到,有人出现 DispatcherServlet 异常的描述为 “ …  java.lang.IllegalArgumentException:Unknown return value type: java.lang.Integer”。

类似这种问题,就是我们使用的注解出了问题,如:在 Controllor 层的某个接口上忘加了 @ResponseBody 注解

@responseBody 注解的作用:

将 controller 的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到 response 对象的 body 区,通常用来返回 JSON 数据或者是 XML 数据,

需要注意的是,在使用此注解之后不会再走试图处理器,而是直接将数据写入到输入流中,他的效果等同于通过response对象输出指定格式的数据。

总结下来,就是没有正确使用注解,才造成了前后端数据格式不一致的嘛,这个还是需要多多注意。

对 SpringBoot 注解感兴趣的,可以看看我的另一篇博文,链接见【前言】详情。


总结

  • 具体问题要具体分析,问题的描述在异常里写的很清楚,不要只关注 DispatcherServlet ,后面的描述才是定位问题的关键。
  • 小编遇到的是第【3】种问题,因为是移植的一个老项目,眼拙,没看到,也没想到,找了半天才发现!!ε=(´ο`*)))唉 ~~~

我是IT无知君,您的点赞、评论和关注,是我不懈创作最大的动力。
学无止境,气有浩然,让我们一起加油,乘风破浪,江湖有缘再见!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/149463.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Idea激活码最新教程2023.2.4版本,永久有效激活码,亲测可用,记得收藏

    Idea激活码最新教程2023.2.4版本,永久有效激活码,亲测可用,记得收藏Idea 激活码教程永久有效 2023 2 4 激活码教程 Windows 版永久激活 持续更新 Idea 激活码 2023 2 4 成功激活

    2025年5月27日
    4
  • Mac Tensorflow Pycharm安装

    Mac Tensorflow Pycharm安装Python3.6,PyCharm2020.3.3anaconda旧版本下载地址及与python各版本对应关系anaconda旧版本下载地址及与python各版本对应关系_heivy的博客-CSDN博客_anaconda旧版本anaconda老版本下载的方法anaconda老版本下载的方法_weixin_33759269的博客-CSDN博客安装参考:基于mac系统的TensorFlow安装以及pycharm配置-简书参考上述链接安装完毕后:…

    2022年8月26日
    5
  • zencart 引用模板语句「建议收藏」

    zencart 引用模板语句「建议收藏」例如引用:head模板:<?php/***preparesanddisplaysheaderoutput**/if(CUSTOMERS_APPROVAL_AUTHORIZATION==1&&CUSTOMERS_AUTHORIZATION_HEADER_OFF==’true…

    2022年7月27日
    4
  • Python,PyCharm,Anaconda三者间的关系[通俗易懂]

    Python,PyCharm,Anaconda三者间的关系[通俗易懂]1.Python:解释性脚本语言,提供人机对话的解释工作。2.PyCharm:用来写Python代码的工具,是一种集成开发环境(IDE)。在这种环境下可进行可视化地代码程序编写工作。3.Anaconda:Python自身缺少一些包(如:NumPy,Scipy),需要在cmd终端输入pipinstallnumpy安装包。Anaconda内置了许多第三方库,是一个基于Python的数据处理和科学计算平台。…

    2022年8月27日
    5
  • websocket 在线工具_websocket添加请求头

    websocket 在线工具_websocket添加请求头Websocket在线模拟请求工具:支持内网和外网Websocket测试连接格式为ws://IP或域名:端口(示例ws://127.0.0.1:8080)

    2022年8月3日
    6
  • lvs常用命令

    lvs常用命令lvs命令(具体参数的意思可以参看其他文章)1,查看配置ipvsadm-ln2,清空所有配置ipvsadm-Clistener添加:ipvsadm-A-t192.168.11.60:80-srr修改:ipvsadm-E-t192.168.11.60:80-swrr删除:ipvsadm-D-t192.168.11.60:80realserv…

    2022年7月23日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号