- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
大家好,我在 JSP 中使用这个 createUser 方法时遇到了麻烦。
当我将它部署到我的学校服务器上时,它在我的 glassfish 服务器上本地运行。除了这个方法之外,一切都运行良好。我不知道为什么,我尝试在本地调试它, boolean 值 createUser 返回 true。但似乎部署后它返回 false,并被重定向到 test.jsp 站点。我的问题是其他人也遇到同样的问题吗?有没有办法在浏览器中的文件中显示来自服务器的异常。当您不知道去哪里寻找时,很难解决问题。我真的希望有人能提供帮助,感谢所有帮助。
提前致谢
public static boolean createUser(String fname, String lname, String email, String user, String pwd) throws SQLException {
PreparedStatement pst = null;
Connection connection = ConnectionProvider.getConnection();
try {
String Query = "INSERT INTO members (first_name, last_name, email, uname, pass) values (?, ?, ?, ?, ?)";
pst = connection.prepareStatement(Query);
pst.setString(1, fname);
pst.setString(2, lname);
pst.setString(3, email);
pst.setString(4, user);
pst.setString(5, pwd);
pst.executeUpdate();
//connection.commit();
} catch (SQLException ex) {
System.out.println("createUser failed " + ex.getMessage());
return false;
} finally {
try {
if (pst != null) {
pst.close();
}
if (connection != null) {
connection.close();
}
} catch (SQLException ex) {
System.out.println("createUser - finally failed " + ex.getMessage());
}
}
return true;
}
//registration.jsp
<%
String fname = request.getParameter("fname");
String lname = request.getParameter("lname");
String email = request.getParameter("email");
String user = request.getParameter("uname");
String pwd = request.getParameter("pass");
session.setAttribute("userid", user);
//MemberProvider.createUser(fname, lname, email, user, pwd);
//response.sendRedirect("index.jsp");
boolean createUser = MemberProvider.createUser(fname, lname, email, user, pwd);
//if (MemberProvider.createUser(fname, lname, email, user, pwd))
if (createUser){
response.sendRedirect("index.jsp");
} else {
response.sendRedirect("test.jsp");
}
%>
我终于在服务器上找到了堆栈跟踪,安静了一段时间。
2015-01-04 14:49:54.332:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 14:49:54.332:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@3b970fb6{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 14:49:54.400:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@48197a77{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 14:49:56.352:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 14:49:56.352:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@48197a77{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 14:49:56.430:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@42270653{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 14:50:05.445:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 14:50:05.445:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@42270653{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 14:50:05.548:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@104ddfcd{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
createUser failed Field 'admin' doesn't have a default value
Fejl i createuser
createUser failed Field 'admin' doesn't have a default value
Fejl i createuser
2015-01-04 15:08:20.911:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 15:08:20.911:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@104ddfcd{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 15:08:20.967:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@35852e05{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 15:08:31.011:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 15:08:31.011:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@35852e05{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 15:08:31.101:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@3c2c57ec{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
createUser failed Field 'admin' doesn't have a default value
2015-01-04 15:50:39.448:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 15:50:39.449:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@3c2c57ec{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 15:50:39.506:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@490ce325{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 15:50:51.571:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 15:50:51.572:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@490ce325{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 15:50:51.656:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@79ee9e62{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
createUser failed Field 'admin' doesn't have a default value
2015-01-04 16:02:37.184:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 16:02:37.184:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@79ee9e62{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 16:02:37.341:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@43bff0e1{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 16:02:38.353:INFO:oejsl.ELContextCleaner:Scanner-0: javax.el.BeanELResolver purged
2015-01-04 16:02:38.353:INFO:oejsh.ContextHandler:Scanner-0: Stopped o.e.j.w.WebAppContext@43bff0e1{/kristian3e14,file:/home/kristian3e14/kristian3e14/,UNAVAILABLE}{/home/kristian3e14/kristian3e14}
2015-01-04 16:02:38.446:INFO:oejsh.ContextHandler:Scanner-0: Started o.e.j.w.WebAppContext@223afbaa{/kristian3e14,file:/home/kristian3e14/kristian3e14/,AVAILABLE}{/home/kristian3e14/kristian3e14}
createUser failed Field 'admin' doesn't have a default value
Jan 04, 2015 4:02:58 PM org.apache.jasper.compiler.Compiler generateClass
SEVERE: Error compiling file: /tmp/jetty-0.0.0.0-8090-kristian3e14-_kristian3e14-any-/jsp/org/apache/jsp/test_jsp.java
2015-01-04 16:02:58.521:WARN:oejs.ServletHandler:qtp1561907217-22:
org.apache.jasper.JasperException: PWC6033: Error in Javac compilation for JSP||PWC6197: An error occurred at line: 9 in the jsp file: /test.jsp|PWC6199: Generated servlet error:|inconvertible types| required: boolean| found: java.lang.Object||
at org.apache.jasper.compiler.DefaultErrorHandler.javacError(DefaultErrorHandler.java:129)
at org.apache.jasper.compiler.ErrorDispatcher.javacError(ErrorDispatcher.java:299)
at org.apache.jasper.compiler.Compiler.generateClass(Compiler.java:392)
at org.apache.jasper.compiler.Compiler.compile(Compiler.java:453)
at org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:625)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:374)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:492)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:378)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:698)
at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:505)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:138)
at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:564)
at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:213)
at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1096)
at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:432)
at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:175)
at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1030)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:136)
at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:201)
at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:109)
at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
at org.eclipse.jetty.server.Server.handle(Server.java:445)
at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:268)
at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:229)
at org.eclipse.jetty.io.AbstractConnection$ReadCallback.run(AbstractConnection.java:358)
at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:601)
at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:532)
at java.lang.Thread.run(Thread.java:722)
最佳答案
问题是这是因为我将隐式 null 作为我的管理员,当我查找我的管理员时,如果您是管理员,则其值为 1。所以它需要一个 f 值。
所以我只是将其更改为下面的内容并且成功了。非常感谢您的帮助:)
public static boolean createUser(String fname, String lname, String email, String user, String pwd) {
PreparedStatement pst = null;
Connection connection = ConnectionProvider.getConnection();
try {
String Query = "INSERT INTO members (first_name, last_name, email, uname, pass, admin) values (?, ?, ?, ?, ?, ?)";
pst = connection.prepareStatement(Query);
pst.setString(1, fname);
pst.setString(2, lname);
pst.setString(3, email);
pst.setString(4, user);
pst.setString(5, pwd);
pst.setString(6, "0");
pst.executeUpdate();
//connection.commit();
} catch (SQLException ex) {
ex.printStackTrace();
return false;
} finally {
try {
if (pst != null) {
pst.close();
}
if (connection != null) {
connection.close();
}
} catch (SQLException ex) {
ex.printStackTrace();
}
}
return true;
}
这有效:)
关于java - JSP 准备插入语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27767360/
我一直在试图找出为什么这会给我一个错误: PREPARE test FROM 'SELECT t.blah FROM (SELECT ? AS blah) t;'; ERROR 1054 (42S22
我想了解 Go 中的 channel 。我读过默认情况下发送和接收 block ,直到发送方和接收方都准备好。但是我们如何确定发送方和接收方的准备情况。 例如在下面的代码中 package main
大部分的pytorch入门教程,都是使用torchvision里面的数据进行训练和测试。如果我们是自己的图片数据,又该怎么做呢? 1、我的数据 我在学习的时候,使用的是fashion-mnis
在我的 Storyboard中,controller1 有 natigationController 和 segues 到 controller 2。奇怪的是 Segue 工作正常但是 overrid
我正在尝试使用Openshift在线从我的仓库中放入一些代码。 我的构建编译正常,但是部署失败: error: update acceptor rejected nodejs-mongo-persis
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是无关紧要的,
我有一个每晚运行的存储过程。 它从链接服务器中提取一些数据并将其插入到运行 sql 代理作业的服务器上的表中。在运行 INSERT 语句之前,该过程检查链接服务器上的数据库是否联机 (STATE =
我对 PDO 准备好的语句比较陌生。 我忍不住觉得必须有一种更简单、更整洁的方法来执行以下操作:我无论如何都将所有内容加载到一个数组中,然后必须将整个内容重写为一组 ':blah '=>$found[
我正在准备一个 pandas 数据框,用于在 R 的 ggplot2 中绘制带有误差条的图,这需要计算列的统计数据。误差条需要最小值(平均值 - 标准偏差)和最大值(平均值+标准差)。我使用 grou
我的 prepareForSegue 方法没有将数据传递到目标 View Controller 。 var buttonsDictionary = [Int: UIButton]() func cre
需要帮助来完成这个简单的任务。该 sp 应该提供一个结果集,并将从 MS-Access-Database 报告目的中调用。 表名可变,但以数字 (lsid) 结尾。使用串联。max_prepared_
我正在为我工作的小型企业创建销售订单表单。我有一个表单连接到数据库以获取下拉菜单,然后连接到文本框以在需要时添加新数据。如果前面的部分中的所有数据框均已填写,还会出现另外四个部分。 链接到数据库的
以下代码: class Database { (...) public function query($query){ $this->stmt = $this->dbh
我正在开展一个学校项目,涉及一个具有数据库集成的网站。目前正致力于通过它向网站添加新内容(文本、标题、图像)。我已经可以通过网站向数据库添加新用户,但由于某种原因,相同的代码和逻辑不适用于内容。 我注
我如何mysqli::stmt->bind_param在mysql中被视为NULL的东西? 我目前正在使用 $stmt->bind_param('s', 'NULL'); 最佳答案 bind_para
我在此处运行准备 stmt 时遇到语法错误。我尝试手动执行 @c 中的查询并且它有效。不知道为什么 stmt 会给出这个错误。这是我正在使用的代码。 SET @i=24; SET @Bill_mont
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我想知道准备好的查询是否与未准备的查询一样安全。下面是两个示例,一个用于 SELECT,一个用于 UPDATE。第一行是未准备的查询,第二行是准备好的查询。 选择示例: $userDetails =
我是 ios 开发的新手,在我尝试做的事情上遇到了障碍。 我的方法中有这段代码,旨在将特定的 NSObject 从这个 View 传递到下一个 View ,但是它总是让我的应用程序崩溃。 -(void
自上次调用 segue 以来,我的 UIButton 类的 statValue 属性已更新,但 segue 仍发送旧的原始值。有没有办法刷新 prepare 函数(如下),以便它发送新值? overr
我是一名优秀的程序员,十分优秀!