我已经构建了一个使用session维护的应用程序.它使用JDBC MySQL的.当应用程序部署在服务器上时(Apache Tomcat 6).我可以登录并退出会话.工作完全没问题.现在我让服务器继续运行24小时.现在第二天我在输入凭据后尝试...
我已经构建了一个使用session维护的应用程序.
它使用JDBC& MySQL的.
当应用程序部署在服务器上时(Apache Tomcat 6).我可以登录并退出会话.工作完全没问题.
现在我让服务器继续运行24小时.现在第二天我在输入凭据后尝试登录系统,单击“登录”按钮我在网页上收到错误,如下所示:
(这是什么原因?)
Http状态500
例外
org.apache.jasper.JasperException:在第11行处理JSP页面/login.jsp时发生异常
9: Connection con =ConnectionProvider.getConnection();
10: System.out.println("con "+con);
11: con.setAutoCommit(false);
12: Statement st = con.createStatement();
13: ResultSet rs;
14: rs = st.executeQuery("select * from ejduge_login where uname='" + userid + "' and pass='" + pwd +"'");
Stacktrace:
org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:524)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:417)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
root cause
javax.servlet.ServletException: java.sql.SQLException: No operations allowed after connection closed.
org.apache.jasper.runtime.PageContextImpl.doHandlePageException(PageContextImpl.java:850)
org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:779)
org.apache.jsp.login_jsp._jspService(login_jsp.java:97)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
root cause
java.sql.SQLException: No operations allowed after connection closed.
com.mysql.jdbc.Connection.checkClosed(Connection.java:2726)
com.mysql.jdbc.Connection.setAutoCommit(Connection.java:498)
org.apache.jsp.login_jsp._jspService(login_jsp.java:65)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
提前致谢!
解决方法:
我发现,关闭连接的默认时间,如果它已经非活动太长,则MYSQL为28800秒(8小时)(&不是34,247,052毫秒).
show global variables;
在MYSQL中,我将该值重置为172800秒(根据我的要求,48小时)
set global wait_timeout=172800;
它工作得很好.
非常感谢您的帮助!
沃梦达教程
本文标题为:java.sql.SQLException:连接关闭后不允许任何操作
基础教程推荐
猜你喜欢
- 使用SpringBoot根据配置注入接口的不同实现类(代码演示) 2023-02-10
- Java代码实现简单酒店管理系统 2022-12-16
- GraphQL入门总体创建教程 2023-03-31
- Java SpringBoot整合shiro-spring-boot-starterqi项目报错解决 2023-04-12
- 详解Thymeleaf的三种循环遍历方式 2023-02-10
- springboot vue组件开发实现接口断言功能 2022-11-12
- maven多模块依赖版本不一致问题解决 2023-07-14
- Java中@Pattern注解常用的校验正则表达式学习笔记 2023-02-19
- SpringCloud Eureka服务治理之服务注册服务发现 2023-03-22
- JSP静态导入与动态导入使用详解 2023-07-30