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

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日

悬赏问题

  • ¥30 关于#opencv#的问题:使用大疆无人机拍摄水稻田间图像,拼接成tif图片,用什么方法可以识别并框选出水稻作物行
  • ¥15 Python卡尔曼滤波融合
  • ¥20 iOS绕地区网络检测
  • ¥15 python验证码滑块图像识别
  • ¥15 根据背景及设计要求撰写设计报告
  • ¥20 能提供一下思路或者代码吗
  • ¥15 用twincat控制!
  • ¥15 请问一下这个运行结果是怎么来的
  • ¥15 单通道放大电路的工作原理
  • ¥30 YOLO检测微调结果p为1