Java Servlet无法识别JSON?

Java Servlet无法识别JSON?,java,json,servlets,Java,Json,Servlets,我得到了以下strack痕迹,但不确定原因: SEVERE: Servlet.service() for servlet [BuddyController] in context with path [/gbserver] threw exception [Servlet execution threw an exception] with root cause java.lang.ClassNotFoundException: org.apache.commons.lang.exception

我得到了以下strack痕迹,但不确定原因:

SEVERE: Servlet.service() for servlet [BuddyController] in context with path [/gbserver] threw exception [Servlet execution threw an exception] with root cause
java.lang.ClassNotFoundException: org.apache.commons.lang.exception.NestableRuntimeException
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1714)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559)
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
    at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2904)
    at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1173)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1681)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559)
    at com.mathanv.gb.dao.BuddyDao.registerBuddy(BuddyDao.java:50)
    at com.mathanv.gb.controller.BuddyController.doPost(BuddyController.java:53)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:647)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
    at java.lang.Thread.run(Thread.java:680)
上述strack跟踪由以下代码生成:

JSONObject response = new JSONObject();
我的结构如下:


你知道我为什么会出错吗?

你需要在你的库中加入Commons Lang;显然,您的JSON库依赖于它。(具体来说,您看到的异常是因为
org.apache.commons.lang.exception.NestableRuntimeException
-see-不在您的类路径中。)

考虑(从中长期来看)学习一些类似于为您的项目处理第三方库的知识。这有点吓人,但是IDE基本上是在依赖关系管理上下赌注。多亏了很多朋友,这方面的东西还很新,依赖关系是我最近遇到的一个新问题。始终努力学习最佳实践!有什么好地方可以让我开始阅读Maven的基础知识吗?官方网站就是其中之一。这是一种工具,它通常有助于有一个已经可以工作的项目来戳和调查。幸运的是,这正是Maven“原型”所做的,本教程从一个原型开始。因此,创建一个简单的webapp原型,然后运行
mvntomcat:run
,看看这是否有效,然后以此作为基础。像mvnrepository.com这样的网站可以帮助您了解向项目中添加库所需的内容。