菜鸟在线求助! 2022-10-22 22:32 采纳率: 46.2%
浏览 48
已结题

servlet连接jdbc显示500,jar包也导了就是不知道为什么

servlet连接jdbc显示500,jar包也导了就是不知道为什么
Java代码
import javax.servlet.*;

import java.io.IOException;

import java.sql.*;

public class jdbc implements Servlet {

@Override
public void init(ServletConfig servletConfig) throws ServletException {

}

@Override
public ServletConfig getServletConfig() {
    return null;
}

@Override
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
    try {
        Driver d = new com.mysql.cj.jdbc.Driver();
        DriverManager.registerDriver(d);
        Connection con = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/servlet","root","xionghui");
        Statement sta = con.createStatement();
        ResultSet res ;
        res=sta.executeQuery("select * from class");
        if( res!=null){System.out.println("i");
            res.next();
        String s=res.getString("name");
        System.out.println(s);}
        else{
            res.close();
        }
    } catch (Exception e) {

    }
}

@Override
public String getServletInfo() {
    return null;
}

@Override
public void destroy() {

}

错误信息
HTTP Status 500 – Internal Server Error
Type 异常报告

消息 Servlet execution threw an exception

描述 服务器遇到一个意外的情况,阻止它完成请求。

Exception

javax.servlet.ServletException: Servlet execution threw an exception
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
Root Cause

java.lang.NoClassDefFoundError: com/mysql/cj/jdbc/Driver
jdbc.service(jdbc.java:23)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
Root Cause

java.lang.ClassNotFoundException: com.mysql.cj.jdbc.Driver
org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1363)
org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1186)
jdbc.service(jdbc.java:23)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
Note 主要问题的全部 stack 信息可以在 server logs 里查看

img

img

img

  • 写回答

4条回答 默认 最新

  • 莪是男神 2022-10-22 23:05
    关注

    在 Class.forName(Driver)出错了,报错信息java.lang.ClassNotFoundException: com.mysql.cj.jdbc.Driver
    造成此问题的原因有:

    • 驱动名错误,没有和mysql版本对应。

    • idea没有导入connector的jar包

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 10月31日
  • 已采纳回答 10月23日
  • 创建了问题 10月22日

悬赏问题

  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真