我用Java和sql创建了一个用户管理(创建,读取,更新,删除)。 这是我的道:
private static final String UPDATE = "UPDATE user set login_user=?, pwd_user=?, id_role=? where id_user=? ";
@Override
public void update_user(User user) throws DAOException {
Connection connexion = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connexion = (Connection) dao_factory.getConnection();
preparedStatement = connexion.prepareStatement(UPDATE);
preparedStatement.setString(1, user.getLogin());
preparedStatement.setString(2, user.getPwd());
preparedStatement.setInt(3, user.getRole());
preparedStatement.setLong(4, user.getId_user());
preparedStatement.executeUpdate();
} catch (SQLException e) {
throw new DAOException(e);
}
}
我的jsp for update用户:
<%
if(action.equalsIgnoreCase("edit")){
%>
<form method="get" action="client">
<div class="form-group">
<input type="text" class="form-control" id="login" name="login" placeholder="login">
<a href="client?action=update&id=${ user_edit.id_user }" class="btn btn-primary">Update</a>
</div>
</form>
<% } %>
我的servlet:
String action = request.getParameter("action");
if (request.getParameter("action") != null && action.equalsIgnoreCase("view")) {
request.setAttribute("client", user_dao.find_all());
}
if (action.equalsIgnoreCase("delete")) {
int id = Integer.parseInt(request.getParameter("id"));
user_dao.delete_user(id);
request.setAttribute("client", user_dao.find_all());
}
if (action.equalsIgnoreCase("edit")) {
int id = Integer.parseInt(request.getParameter("id"));
User user = user_dao.getById(id);
session.setAttribute("user_edit", user);
}
if (action.equalsIgnoreCase("update")) {
Long id = Long.parseLong(request.getParameter("id"));
String login = request.getParameter("login");
User user = new User();
user.setLogin("test_login");
user.setPwd("test_pwd");
user.setRole(1);
user.setId_user(id);
user_dao.update_user(user);
}
else {
request.setAttribute("client", user_dao.find_all());
}
this.getServletContext().getRequestDispatcher(VUE).forward(request, response);
我的第一个问题是,当我点击“更新”按钮时,它可以工作。但是,如果我按回车键,我有一个空指针异常
第二个问题是,如果我想恢复具有String login = request.getParameter("login");
和user.setLogin(login);
的登录用户,则db中的登录值为null。
非常感谢
编辑: 这是堆栈跟踪:
Avertissement: StandardWrapperValve[client]: Servlet.service() for servlet `client threw exception`
java.lang.NullPointerException
at egame.servlets.admin.client.processRequest(client.java:53)
at egame.servlets.admin.client.doGet(client.java:94)
if (action.equalsIgnoreCase("delete"))
。 答案 0 :(得分:0)
ResultSet resultSet = null; 调用update user后它仍为null。
无论如何你都试图访问
servlet将始终调用request.setAttribute(&#34; client&#34;,user_dao.find_all());
除非您希望仅在非更新案例中发生,否则请使用else。
答案 1 :(得分:0)
您的HTML / JSP错误。你创建一个HTML表单,但你说的是一个&#34;按钮&#34;实际上只是一个 独立的 链接。这就是你提到这两个问题的原因:
您需要将其更改为
<%
if(action.equalsIgnoreCase("edit")){
%>
<form method="post" action="client">
<div class="form-group">
<input type="text" class="form-control" id="login" name="login" placeholder="login">
<input type="hidden" id="action" value="update" >
<input type="hidden" id="id" value="${ user_edit.id_user }" >
<button type="submit" class="btn btn-primary">Update</a>
</div>
</form>
<% } %>
侧节点: 从不 使用HTTP GET向服务器提交任何更改。如果您更改服务器上的数据,它应该是POST(或DELETE,或PUT但不是GET)。