Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/65.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用Java(Servlet)的MySQL连接的ClassNotFoundException_Java_Mysql_Eclipse_Servlets - Fatal编程技术网

使用Java(Servlet)的MySQL连接的ClassNotFoundException

使用Java(Servlet)的MySQL连接的ClassNotFoundException,java,mysql,eclipse,servlets,Java,Mysql,Eclipse,Servlets,我有Eclipse作为我的IDE,tomcat服务器9.0,MySQL都在Windows10中运行 我在MySQL中创建了一个简单的项目来连接一个简单的数据库,当我创建一个JAVA项目时,代码运行得非常完美,但是当我在动态Web项目下创建一个servlet时,同样的代码失败了 这是代码,问题是Class.forName protected void doGet(HttpServletRequest request, HttpServletResponse response) throws Ser

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

我在MySQL中创建了一个简单的项目来连接一个简单的数据库,当我创建一个JAVA项目时,代码运行得非常完美,但是当我在动态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>");
    }
受保护的void doGet(HttpServletRequest请求,HttpServletResponse响应)抛出ServletException,IOException{
连接conn=null;
试一试{
Class.forName(“com.mysql.jdbc.Driver”);
conn=DriverManager.getConnection(“jdbc:mysql://localhost/amir“,”根“,”1234”);
}捕获(SQLE异常){
e、 printStackTrace();
}catch(classnotfounde异常){
e、 printStackTrace();
}
response.setContentType(“text/html”);
PrintWriter p=response.getWriter();
p、 println(“Hi”);
}
这是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(未知源)


由于包中的类不存在于WEB-INF/lib文件夹中,因此您会收到“未找到类”异常。

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


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

通过文件系统将jar文件粘贴到WebContent\WEB-INF\lib中。