Sas*_*ska 42 forms jsp servlets
我有一个带有HTML表单的JSP页面:
<form action="SERVLET">
<input type="text" name="name"/><br>
<input type="text" name="group"/>
<input type="text" name="pass"/>
<input type="submit" value="submit">
</form>
Run Code Online (Sandbox Code Playgroud)
如何在servlet中获取这些数据并将它们添加到数据库中?
Bal*_*usC 78
创建一个扩展HttpServlet
和放置@WebServlet
注释的类,其中包含servlet应该监听的所需URL.
@WebServlet("/yourServletURL")
public class YourServlet extends HttpServlet {}
Run Code Online (Sandbox Code Playgroud)
然后让我们<form action>
指出这个URL.我还建议对非幂等请求使用POST方法.您应该确保您所指定的name
HTML表单输入字段的属性(<input>
,<select>
,<textarea>
和<button>
).这表示HTTP请求参数名称.最后,您还需要确保感兴趣的输入字段包含在所需的表单内,因此不在外部.
以下是各种HTML表单输入字段的一些示例:
<form action="${pageContext.request.contextPath}/yourServletURL" method="post">
<p>Normal text field.
<input type="text" name="name" /></p>
<p>Secret text field.
<input type="password" name="pass" /></p>
<p>Single-selection radiobuttons.
<input type="radio" name="gender" value="M" /> Male
<input type="radio" name="gender" value="F" /> Female</p>
<p>Single-selection checkbox.
<input type="checkbox" name="agree" /> Agree?</p>
<p>Multi-selection checkboxes.
<input type="checkbox" name="role" value="USER" /> User
<input type="checkbox" name="role" value="ADMIN" /> Admin</p>
<p>Single-selection dropdown.
<select name="countryCode">
<option value="NL">Netherlands</option>
<option value="US">United States</option>
</select></p>
<p>Multi-selection listbox.
<select name="animalId" multiple="true" size="2">
<option value="1">Cat</option>
<option value="2">Dog</option>
</select></p>
<p>Text area.
<textarea name="message"></textarea></p>
<p>Submit button.
<input type="submit" name="submit" value="submit" /></p>
</form>
Run Code Online (Sandbox Code Playgroud)
doPost()
在servlet中创建一个方法,该方法将提交的输入值作为输入字段键入的请求参数name
(不是 id
!).您可以使用request.getParameter()
从单值字段request.getParameterValues()
获取提交的值,并从多值字段中获取提交的值.
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String name = request.getParameter("name");
String pass = request.getParameter("pass");
String gender = request.getParameter("gender");
boolean agree = request.getParameter("agree") != null;
String[] roles = request.getParameterValues("role");
String countryCode = request.getParameter("countryCode");
String[] animalIds = request.getParameterValues("animalId");
String message = request.getParameter("message");
boolean submitButtonPressed = request.getParameter("submit") != null;
// ...
}
Run Code Online (Sandbox Code Playgroud)
如果有必要,可以进行一些验证,最后以通常的JDBC/DAO方式将其保存在DB中.
User user = new User(name, pass, roles);
userDAO.save(user);
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
130546 次 |
最近记录: |