Как предварительно заполнить текстовые поля в форме информацией из базы данных в формате .jsp? - PullRequest
1 голос
/ 13 июля 2011

Я пытаюсь создать форму, которая обновляет запись в базе данных MySQL. Таблица представляет собой таблицу пользователей, которая содержит различные поля, связанные с пользователем. Мне нужно, чтобы эта страница работала как форма обновления, которая берет имя пользователя, которое передается ей через предыдущую страницу, и предварительно заполняет текстовые поля существующими данными. Это приложение модели один, которое использует уровень представления, транспорта и данных. Транспортный уровень - User.java, а уровень данных (который взаимодействует с базой данных) - UserDB.java.

Вот код, все работает, кроме предварительной заливки.

ОБНОВЛЕНИЕ: я изменил, чтобы отразить изменения от ответов ниже, я также хочу отметить, что "UserDB.getUsers ()" возвращает ArrayList.

<%@ page language="java" contentType="text/html; charset=iso-8859-1"
pageEncoding="ISO-8859-1" import="java.util.ArrayList,beans.*,data.*"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
//get parameters from the request
String userName = request.getParameter("userName");

ArrayList userList = UserDB.getUsers(userName);
    User user = userList.get(0);
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<link rel="stylesheet" href="styles/style.css" type="text/css" />
<title>User Admin</title>

</head>
<body>


<div id="main">
  <h1>Update  User</h1>
  <h3>User Info</h3>
  <hr>
    <div id="content">
    <form action="updateUser.jsp" method="get">
      <p>User Name<br>
        <input type="text" name="userName" size="20" value="<%=userName%>"/>
      </p>
      <p>Password<br>
        <input type="text" name="password" size="20" value="<%=user.getPassword()%>"/>
      </p>
      <p>First Name<br>
        <input type="text" name="firstName" size="20" value="<%=user.getFirstName()%>"/>
      </p>
      <p>Last Name<br>
        <input type="text" name="lastName" size="20" value="<%=user.getLastName()%>"/>
      </p>
      <p>Email Address<br>
       <input type="text" name="email" size="20" value="<%=user.getEmail()%>"/>
      </p>
      <p>
        <input type="submit" value="Commit Update">
      </p>
  </form>
</div>
</div>
</body>
</html>

Я знаю, что что-то не так с объектом "пользователь", но я его пропускаю.

Ответы [ 2 ]

3 голосов
/ 13 июля 2011

вы передаете имя пользователя в виде строки

<%
//get parameters from the request
String userName = request.getParameter("userName");

user = UserDB.getUsers("userName");
//it should be (with out the quotes
user = UserDB.getUsers(userName);

%>
0 голосов
/ 13 июля 2011

В «username» должны быть удалены кавычки.Кроме того, где вы объявляете тип пользователя?т.е..

Пользователь пользователя = .... getUser ..

...