2011-03-30 57 views
1

5.x的连接错误尝试连接到在Tomcat 6运行JSP web应用一个MySQL数据库5.x中,我得到以下异常:的Tomcat 6和MySQL在Ubuntu

org.apache.jasper.JasperException: javax.servlet.ServletException: com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception: 

** BEGIN NESTED EXCEPTION ** 

java.net.SocketException 
MESSAGE: java.security.AccessControlException: access denied (java.net.SocketPermission [0:0:0:0:0:0:0:1]:3307 connect,resolve) 

STACKTRACE: 

java.net.SocketException: java.security.AccessControlException: access denied (java.net.SocketPermission [0:0:0:0:0:0:0:1]:3307 connect,resolve) 
    at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:151) 
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:280) 
    at com.mysql.jdbc.Connection.createNewIO(Connection.java:1699) 
    at com.mysql.jdbc.Connection.<init>(Connection.java:405) 
    at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:268) 
    at java.sql.DriverManager.getConnection(DriverManager.java:620) 
    at java.sql.DriverManager.getConnection(DriverManager.java:200) 
    at org.apache.jsp.doLogin_jsp._jspService(doLogin_jsp.java:70) 
    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:374) 
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:342) 
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:267) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
    at sun.reflect.GeneratedMethodAccessor32.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:616) 
    at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:244) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at javax.security.auth.Subject.doAsPrivileged(Subject.java:537) 
    at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:276) 
    at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:162) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:283) 
    at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:56) 
    at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:189) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:185) 
    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:128) 
    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:286) 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852) 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583) 
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447) 
    at java.lang.Thread.run(Thread.java:636) 

有什么事情是原因,我该如何解决它?

回答

1

这里是跟踪的相关位:

java.net.SocketException异常消息:java.security.AccessControlException:访问被拒绝(java.net.SocketPermission [0:0:0:0:0 :0:0:1]:3307连接,解析)

该webapp没有连接/解析提及的套接字的权限。您需要在Tomcat级别配置它。打开/conf/catalina.policy并添加以下代码块:如果你想更严格一点,例如

grant { 
    permission java.net.SocketPermission "localhost:3307", "connect,resolve"; 
}; 

授予访问只有特定的JDBC驱动程序,它存在于/lib/filename.jar,然后添加此相反:

grant codeBase "jar:file:${catalina.home}/lib/filename.jar!/-" { 
    permission java.net.SocketPermission "localhost:3307", "connect,resolve"; 
}; 

无关的具体问题,下面几行

at java.sql.DriverManager.getConnection(DriverManager.java:200) 
at org.apache.jsp.doLogin_jsp._jspService(doLogin_jsp.java:70) 

表明您'重新连接JSP文件中的数据库。也许你只是开始学习,但我只提到这不是最好的做法。数据库连接应该在它自己的类中完成,然后在一个servlet类中使用它,这个类继而转发给JSP,并转而显示结果。通过URL调用servlet应该会得到相同的结果,但最终会得到更好的可重用和可维护的代码。

+1

BalusC:非常感谢您的回复..它的工作!并感谢您对数据库连接的建议。非常感谢。 – Maheshcck 2011-04-01 06:33:29

+0

有同样的问题,好q/a - 谢谢 – slex 2012-02-01 09:29:52