Java 无法在jsp文件中建立jdbc连接

Java 无法在jsp文件中建立jdbc连接,java,eclipse,jsp,jdbc,ubuntu,Java,Eclipse,Jsp,Jdbc,Ubuntu,嘿,我正在尝试在我的jsp文件中建立简单的jdbc连接。该文件如下所示: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <%

嘿,我正在尝试在我的jsp文件中建立简单的jdbc连接。该文件如下所示:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<%@page import="java.sql.DriverManager"%><html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
hello world.
<% 

try{
    Class.forName("com.mysql.jdbc.Driver");
    DriverManager.getConnection("jdbc:mysql://localhost:3306/saurabh","root","");
    System.out.println("Connection successful");
}catch(Exception e){
    e.printStackTrace();
}

%>
</body>
</html>
最后一件事是,当我试图从一个简单的java文件中获得相同类型的连接时,这是可行的。那么jsp文件有什么问题呢

PS:我正在使用Ubuntu10.10发行版和Eclipse3.5。我还将jar文件添加到项目的java构建路径中。这在windows上运行得很好

那怎么办


提前感谢:)

您需要将mysql驱动程序部署到servlet容器(Tomcat/Jetty)中,以便JSP能够找到它们


但正如@crafstman在评论中所说的,在显示代码中加入与DB相关的内容是非常糟糕的做法。出于安全考虑,出于性能考虑。

您需要将mysql驱动程序部署到servlet容器(Tomcat/Jetty)中,以便JSP能够找到它们


但正如@crafstman在评论中所说的,在显示代码中加入与DB相关的内容是非常糟糕的做法。不管是出于安全原因,为了性能。

在将mysql驱动程序JAR部署到服务器之前,您的mysql驱动程序JAR应该放在项目的
WEB-INF/lib
目录中。

在将其部署到服务器之前,您的mysql驱动程序JAR应该放在项目的
WEB-INF/lib
目录中。

将您的
mysql驱动程序放到
tomcat/lib
或者您可以将MySQL驱动程序放到
yourapplicationproject/WebContent/WEB-INF/lib

将数据库连接放入
jsp
不是一种好的做法。
如果您将数据库连接放到
Servlet code

中,将
MySQL驱动程序放到
tomcat/lib
中,或者您可以将MySQL驱动程序放到
yourapplicationproject/WebContent/WEB-INF/lib

将数据库连接放入
jsp
不是一种好的做法。
如果您将数据库连接放在
Servlet code

中,我会更好。在JSP中建立连接是一个非常糟糕的主意。您应该只将代码放在
.java
文件中,而只将表示放在
.JSP
文件中。混合使用它们会导致以后的维护噩梦。@用户:JSP中不应存在任何业务逻辑。它们应该只用于生产产出。任何业务逻辑(包括DB连接)都应该在servlet/Actions中完成(取决于您对任何web框架的使用)。或者更好:在从servlet/Actions调用的专用类中。问题是JSP应该只是视图层,并且不应该包含任何业务逻辑。关于MVC的链接:您还应该检查一下:在JSP中建立连接是个非常糟糕的主意。您应该只在
.java
文件中放置代码,只在
.JSP
文件中放置演示文稿。混合使用它们会导致以后的维护噩梦。@用户:JSP中不应存在任何业务逻辑。它们应该只用于生产产出。任何业务逻辑(包括DB连接)都应该在servlet/Actions中完成(取决于您对任何web框架的使用)。或者更好:在从servlet/Actions调用的专用类中。问题是JSP应该只是视图层,不应该包含任何业务逻辑。关于MVC的链接:您也应该检查一下:我是JSP和servlet的新手,请详细说明一下。仍然感谢您的回复。即使从JSP中提取逻辑,也有必要将JDBC驱动程序添加到webapp中,第一行仍然适用。我对JSP和servlets不熟悉,请您详细说明一下。仍然感谢您的响应。即使从JSP中提取了逻辑,也有必要将JDBC驱动程序添加到webapp中,第一行仍然适用。
java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)
    at org.apache.jasper.servlet.JasperLoader.loadClass(JasperLoader.java:128)
    at org.apache.jasper.servlet.JasperLoader.loadClass(JasperLoader.java:66)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:169)
    at org.apache.jsp.myJspDemo_jsp._jspService(myJspDemo_jsp.java:68)
    at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:386)
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    at java.lang.Thread.run(Thread.java:619)