httpClient实例(二)

2014-11-24 09:26:31 · 作者: · 浏览: 1
者是在服务器中实现页面的跳转,也就是说应用容器加载了所要跳转的页面的内容并返回给客户端;而前者是返回一个状态码,这些状态码的可能值见下表,然后客户端读取需要跳转到的页面的URL并重新加载新的页面。就是这样一个过程,所以我们编程的时候就要通过HttpMethod.getStatusCode()方法判断返回值是否为下表中的某个值来判断是否需要跳转。如果已经确认需要进行页面跳转了,那么可以通过读取HTTP头中的location属性来获取新的地址。
  状态码
  对应HttpServletResponse的常量
  详细描述
  301
  SC_MOVED_PERMANENTLY
  页面已经永久移到另外一个新地址
  302
  SC_MOVED_TEMPORARILY
  页面暂时移动到另外一个新的地址
  303
  SC_SEE_OTHER
  客户端请求的地址必须通过另外的URL来访问
  307
  SC_TEMPORARY_REDIRECT
  同SC_MOVED_TEMPORARILY
  
  下面的代码片段演示如何处理页面的重定向
  client.executeMethod(post);
   System.out.println(post.getStatusLine().toString());
   post.releaseConnection();
  
   //检查是否重定向
   int statuscode = post.getStatusCode();
   if ((statuscode == HttpStatus.SC_MOVED_TEMPORARILY) ||
   (statuscode == HttpStatus.SC_MOVED_PERMANENTLY) ||
   (statuscode == HttpStatus.SC_SEE_OTHER) ||
  (statuscode == HttpStatus.SC_TEMPORARY_REDIRECT)) {
  //读取新的URL地址
   Header header = post.getResponseHeader("location");
   if (header != null) {
   String newuri = header.getValue();
   if ((newuri == null) || (newuri.equals("")))
   newuri = "/";
   GetMethod redirect = new GetMethod(newuri);
   client.executeMethod(redirect);
   System.out.println("Redirect:"+ redirect.getStatusLine().toString());
   redirect.releaseConnection();
   } else
   System.out.println("Invalid redirect");
   }
  我们可以自行编写两个JSP页面,其中一个页面用response.sendRedirect方法重定向到另外一个页面用来测试上面的例子。
  4. 模拟输入用户名和口令进行登录
  本小节应该说是HTTP客户端编程中最常碰见的问题,很多网站的内容都只是对注册用户可见的,这种情况下就必须要求使用正确的用户名和口令登录成功后,方可浏览到想要的页面。因为HTTP协议是无状态的,也就是连接的有效期只限于当前请求,请求内容结束后连接就关闭了。在这种情况下为了保存用户的登录信息必须使用到Cookie机制。以JSP/Servlet为例,当浏览器请求一个JSP或者是Servlet的页面时,应用服务器会返回一个参数,名为jsessionid(因不同应用服务器而异),值是一个较长的唯一字符串的Cookie,这个字符串值也就是当前访问该站点的会话标识。浏览器在每访问该站点的其他页面时候都要带上jsessionid这样的Cookie信息,应用服务器根据读取这个会话标识来获取对应的会话信息。
  对于需要用户登录的网站,一般在用户登录成功后会将用户资料保存在服务器的会话中,这样当访问到其他的页面时候,应用服务器根据浏览器送上的Cookie中读取当前请求对应的会话标识以获得对应的会话信息,然后就可以判断用户资料是否存在于会话信息中,如果存在则允许访问页面,否则跳转到登录页面中要求用户输入帐号和口令进行登录。这就是一般使用JSP开发网站在处理用户登录的比较通用的方法。
  这样一来,对于HTTP的客户端来讲,如果要访问一个受保护的页面时就必须模拟浏览器所做的工作,首先就是请求登录页面,然后读取Cookie值;再次请求登录页面并加入登录页所需的每个参数;最后就是请求最终所需的页面。当然在除第一次请求外其他的请求都需要附带上Cookie信息以便服务器能判断当前请求是否已经通过验证。说了这么多,可是如果你使用httpclient的话,你甚至连一行代码都无需增加,你只需要先传递登录信息执行登录过程,然后直接访问想要的页面,跟访问一个普通的页面没有任何区别,因为类HttpClient已经帮你做了所有该做的事情了,太棒了!下面的例子实现了这样一个访问的过程。
  /*
  * Created on 2003-12-7 by Liudong
  */
  package http.demo;
  import org.apache.commons.httpclient.*;
  import org.apache.commons.httpclient.cookie.*;
  import org.apache.commons.httpclient.methods.*;
  /**
  * 用来演示登录表单的示例
  * @author Liudong
  */
  public class FormLoginDemo {
   static final String LOGON_SITE = "localhost";
   static final int LOGON_PORT = 8080;
  
   public static void main(String[] args) throws Exception{
   HttpClient client = new HttpClient();
   client.getHostConfiguration().setHost(LOGON_SITE, LOGON_PORT);
  
   //模拟登录页面login.jsp->main.jsp
   PostMethod post = new PostMethod("/main.jsp");
   Nameva luePair name = new Nameva luePair("name", "ld");
   Nameva luePair pass = new Nameva luePair("password", "ld");
   post.setRequestBody(new Nameva luePair[]{name,pass});
   int status = client.executeMethod(post);
   System.out.println(post.getRespons