2012-06-28 38 views
0

我在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(名称)从窗体接收参数名称并在数据库中进行搜索。

+0

可以发布您在“FoundStudent.jsp”中尝试了哪些内容,并且在JSP中编写JAVA代码并不是一个好习惯。 JSP只能用于表示层 –

回答

0

因此,我改变的(Java)的脚本:

<script language="javascript"> 
      function validateSea(){ 
       if(document.entry2.name.value != ''){ 
        return true; 
       } 

       else 
        if(document.entry2.year.value != ''){ 
         return true; 
        } 

       alert('Please fill one field.'); 
       return false; 
      } 
      </script> 

     </head> 

其是用于1种形式。我不知道如果我做了正确的事情,但在FoundStudents.jsp,在那里我得到了形式的参数,我考:

if((request.getParameter("year") != null)||(request.getParameter("name") != null)){ 

     //reading params from the SearchStudent form 
................} 

是这样工作的。