我在JSP页面中有一个HTML表单,并在我有一个JavaScript验证。用户必须输入一个字段:名称或编号或年份,而java文件将按名称或编号或年份在数据库中搜索学生。未填写字段时的JavaScript警报,如果填充了一个字段,则执行操作。在JSP中处理表单元素(s)
<html>
<head>
<title>Student to search into database</title>
<script language="javascript">
function validate2(objForm){
int k = 0;
if(objForm.name.value.length==0){
objForm.name.focus();
k++;
}
if(objForm.year.value.length==0){
objForm.year.focus();
k++;
}
if(objForm.id.value.length==0){
objForm.year.focus();
k++;
}
if(k == 0){
return false;
}
return true;
}
</script>
</head>
<body bgcolor=#ADD8E6><center>
<form action="FoundStudents.jsp" method="post" name="entry2" onSubmit="validate2(this)">
<input type="hidden" value="list" name="seek_stud">
............................................ ................................................
问题是我想处理我在FoundStudents.jsp中收到的参数:如果我收到年份,我会在DB中查看哪些学生在该年份,并显示所有学生的数据(do在一个Java文件中)。我怎么能在FoundStudents.Jsp中做到这一点,而不再检查哪个字段被填充(我已经在JavaScript中完成了这项工作,从SearchStudent.jsp)。我的意思是FoundStudents.jsp在java文件中调用一个用于搜索和显示的方法。
我现在试着用输入隐藏这样的工作,但这是更多的形式。我只有1
FoundStudent.jsp
<%@page import="stud.diploma.students.StudentsManager"%>
<%@page import="stud.diploma.students.Student"%>
<%@page import="java.util.ArrayList"%>
<%@page import="stud.diploma.database.ConnectionsManager"%>
<%@ page language="java" import="java.sql.*, java.lang.*" %>
<%
Student search = null;
if(request.getParameter("seek_stud") != null){
//reading params from the SearchStudent form
String name = request.getParameter("name");
String year_prime = request.getParameter("year");
int year, id;
try{
year = Integer.parseInt(year_prime);
}catch(Exception e1){
year = 0;
}
String id_prime = request.getParameter("id");
try{
id = Integer.parseInt("id");
}catch(Exception e2){
id = 0;
}
if(name.length() != 0){
search = StudentsManager.getInstance().studByName(name);
}
if(year > 0){
search = StudentsManager.getInstance().studByYear(year);
}
if(id > 0){
search = StudentsManager.getInstance().studById(id);
}
if(search != null){
%>
<html>
<body bgcolor=#4AA02C>
<center>
<h2>Student's data</h2>
<table border="1" cellspacing="1" cellpadding="8" bgcolor= #EBDDE2>
<tr>
<td bgcolor= #FF9966><b>ID</b></td>
<td bgcolor= #FF9966><b>Name</b></td>
<td bgcolor= #FF9966><b>Year</b></td>
</tr>
<tr>
<td><%= search.getId()%></td>
<td><%= search.getName()%></td>
<td><%= search.getYear()%></td>
</tr>
</table>
</center>
</body>
</html>
<%}else{%>
<%
String redirectURL = "MainMenu.html";
response.sendRedirect(redirectURL);
%>
<%}%>
<%}%>
这FoundStudent.jsp对于能够工作多种形式(采用隐藏式输入)的版本。 (javascript测试只是有点不同,我输入了它的开头)
它只按名称和年份搜索。没按ID搜索(我有例外,这里<td><%= search.getId()%></td>
我还在努力,看看如何对付它的ID是一个AUTO_INCREMENT PRIMARY KEY)。
线,如:search = StudentsManager.getInstance().studByName(name);
搜索是学生类型的对象。 (对象学生在java文件中被装上)
StudentsManager是一个Java类,它接收来自JSP的调用方法。 getInstance()创建了一个StudentsManager实例。方法studByName(名称)从窗体接收参数名称并在数据库中进行搜索。
可以发布您在“FoundStudent.jsp”中尝试了哪些内容,并且在JSP中编写JAVA代码并不是一个好习惯。 JSP只能用于表示层 –