【问题标题】:ClassNotFoundException for MySQL connection with Java (Servlet) [duplicate]MySQL与Java(Servlet)连接的ClassNotFoundException [重复]
【发布时间】:2017-09-28 19:37:53
【问题描述】:

我有 Eclipse 作为我的 IDE,tomcat 服务器 9.0,MySQL 都在 Windows 10 中运行。

我在 MySQL 中创建了一个简单的项目来连接一个简单的数据库,当我创建一个 JAVA PROJECT 时代码运行完美,但是当我在 Dynamic Web 下创建一个 servlet 时,相同的代码失败了项目

这是代码,问题是Class.forName

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        Connection conn = null;

        try {
            Class.forName("com.mysql.jdbc.Driver");
            conn = DriverManager.getConnection("jdbc:mysql://localhost/amir","root","1234");
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        response.setContentType("text/html");
        PrintWriter p = response.getWriter();
        p.println ("<html><body><h3>Hi</h3></body></html>");
    }

这是 StackTrace

java.lang.ClassNotFoundException: com.mysql.jdbc.Driver 在 org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1275) 在 org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1109) 在 java.lang.Class.forName0(本机方法) 在 java.lang.Class.forName(未知来源) 在 myServlet.DynamicWeb.doGet(DynamicWeb.java:36) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:635) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:742) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) 在 org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) 在 org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199) 在 org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) 在 org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:475) 在 org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140) 在 org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80) 在 org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:624) 在 org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) 在 org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342) 在 org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:498) 在 org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) 在 org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:796) 在 org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1368) 在 org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(未知来源) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(未知来源) 在 org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) 在 java.lang.Thread.run(Unknown Source)

【问题讨论】:

    标签: java mysql eclipse servlets


    【解决方案1】:

    您得到类未找到异常,因为包中的这些类不在 WEB-INF/lib 文件夹中。

    您必须手动将项目中使用/包含的所有库或 jar 复制到 WEB-INF/lib 文件夹。

    在这种情况下,将连接db所需的所有jar或库文件复制到动态Web项目的WEB-INF/lib文件夹中,它必须可以正常工作。

    【讨论】:

    • 通过文件系统将jar文件粘贴到WebContent\WEB-INF\lib中。
    猜你喜欢
    • 2017-12-30
    • 1970-01-01
    • 2020-05-08
    • 2015-09-05
    • 2016-09-02
    • 2014-06-20
    • 2012-10-20
    • 2016-01-16
    相关资源
    最近更新 更多