在什么时候用request.getParameter与request.getAttribute

HttpServletRequest类既有getAttribute()方法,也由getParameter()方法,这两个方法有以下区别:

(1)HttpServletRequest类有setAttribute()方法,而没有setParameter()方法

(2)当两个Web组件之间为链接关系时,被链接的组件通过getParameter()方法来获得请求参数,例如假定welcome.jsp和authenticate.jsp之间为链接关系,welcome.jsp中有以下代码:

<a   href="authenticate.jsp?username=weiqin">authenticate.jsp   </a>

或者:

<form   name="form1"   method="post"   action="authenticate.jsp">
    请输入用户姓名:<input   type="text"   name="username">
    <input   type="submit"   name="Submit"   value="提交">
</form>

在authenticate.jsp中通过request.getParameter("username")方法来获得请求参数username:

<%   String   username=request.getParameter("username");   %>

(3)当两个Web组件之间为转发关系时,转发目标组件通过getAttribute()方法来和转发源组件共享request范围内的数据。假定   authenticate.jsp和hello.jsp之间为转发关系。authenticate.jsp希望向hello.jsp传递当前的用户名字,   如何传递这一数据呢?先在authenticate.jsp中调用setAttribute()方法:

<%
String   username=request.getParameter("username");
request.setAttribute("username",username);
%>

<jsp:forward   page="hello.jsp"   />

在hello.jsp中通过getAttribute()方法获得用户名字:

<%   String   username=(String)request.getAttribute("username");   %>
Hello:   <%=username   %>

从更深的层次考虑,request.getParameter()方法传递的数据,会从Web客户端传到Web服务器端,代表HTTP请求数据。request.getParameter()方法返回String类型的数据。

request.setAttribute()和getAttribute()方法传递的数据只会存在于Web容器内部,在具有转发关系的Web组件之间共享。这两个方法能够设置Object类型的共享数据。

request.getParameter()取得是通过容器的实现来取得通过类似post,get等方式传入的数据,,   request.setAttribute()和getAttribute()只是在web容器内部流转源码天空,仅仅是请求处理阶段,这个的确是正解.

getAttribute是返回对象,getParameter返回字符串


request.getAttribute()方法返回request范围内存在的对象,而request.getParameter()方法是获取http提交过来的数据。

详细请参考:http://www.codesky.net/article/200704/119108.html

 

具体案例:

 
要求:输入搜索条件后跳转的页面也保留搜索条件。
 
代码实现:
    <%
   String name = request.getParameter("name");
   if(name == null){
   		name = "";
   }
   String creatime= request.getParameter("creatime");
   if(creatime == null){
   		creatime = "";
   }
   String deadline= request.getParameter("deadline");
   if(deadline== null){
   		deadline = "";
   }
   %>

 <form action="DataList1.action" method="post">
	   	<select name="choice" style="width:52px;height:35px;">
  				<option value="company">企业</option>
  				<option value="id">id</option>
		</select> 		
		<input name="name" type="text" size="10%" style="height:35px;" value="<%=name%>">  		
		开始时间 	<input name="creatime" type="text" value="<%=creatime%>" class="Wdate" id="d1" onFocus="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss'})" size="20%" style="height:35px;"/>  
		结束时间 	<input name="deadline" type="text" value="<%=deadline%>" class="Wdate" id="d2" onFocus="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss'})" size="20%" style="height:35px;"/>  
 		 状态  <select name="state" style="width:52px;height:35px;">
				<option  value="all">全部</option>
  				<option  value="正常">正常</option>
  				<option  value="禁用" style="color:red;">禁用</option>
  				<option  value="申请扩容">申请扩容</option>
  				<option  value="即将到期">即将到期</option>
		</select>  
	    <input type="image" name="SearchCompany" src="images/main_view/search.png"  border=0 onClick="this.form.submit()" class="search">
	  </form>		

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值