Вот соответствующий бит трассировки:
java.net.SocketException MESSAGE: java.security.AccessControlException: доступ запрещен (java.net.SocketPermission [0: 0: 0: 0: 0: 0: 0: 1]: 3307 подключиться, разрешить)
Веб-приложение не имеет разрешения для подключения / разрешения указанного сокета.Вам необходимо настроить его на уровне 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файл.Может быть, вы только начинаете и учитесь, но я бы только отметил, что это не лучшая практика.Соединение с БД должно быть сделано в его собственных классах, которые вы, в свою очередь, используете в классе сервлета, который, в свою очередь, пересылает в JSP, который, в свою очередь, отображает результаты.Вызов сервлета по URL должен затем привести к тем же результатам, но в итоге вы получите более многократно используемый и обслуживаемый код.