/* * $Header: /usr/local/cvsroot/3rdParty_sources/commons-httpclient/org/apache/commons/httpclient/StatusLine.java,v 1.1 2012/08/22 17:30:33 marcin Exp $ * $Revision: 1.1 $ * $Date: 2012/08/22 17:30:33 $ * * ==================================================================== * * Copyright 1999-2004 The Apache Software Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation. For more * information on the Apache Software Foundation, please see * . * */ package org.apache.commons.httpclient; /** * Represents a Status-Line as returned from a HTTP server. * * RFC2616 states * the following regarding the Status-Line: *
 * 6.1 Status-Line
 *
 *  The first line of a Response message is the Status-Line, consisting
 *  of the protocol version followed by a numeric status code and its
 *  associated textual phrase, with each element separated by SP
 *  characters. No CR or LF is allowed except in the final CRLF sequence.
 *
 *      Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF
 * 
*

* This class is immutable and is inherently thread safe. * * @see HttpStatus * @author Jeff Dever * @author Mike Bowler * @version $Id: StatusLine.java,v 1.1 2012/08/22 17:30:33 marcin Exp $ * @since 2.0 */ public class StatusLine { // ----------------------------------------------------- Instance Variables /** The original Status-Line. */ private final String statusLine; /** The HTTP-Version. */ private final String httpVersion; /** The Status-Code. */ private final int statusCode; /** The Reason-Phrase. */ private final String reasonPhrase; // ----------------------------------------------------------- Constructors /** * Default constructor. * * @param statusLine the status line returned from the HTTP server * @throws HttpException if the status line is invalid */ public StatusLine(final String statusLine) throws HttpException { int length = statusLine.length(); int at = 0; int start = 0; try { while (Character.isWhitespace(statusLine.charAt(at))) { ++at; ++start; } if (!"HTTP".equals(statusLine.substring(at, at += 4))) { throw new HttpException("Status-Line '" + statusLine + "' does not start with HTTP"); } //handle the HTTP-Version at = statusLine.indexOf(" ", at); if (at <= 0) { throw new ProtocolException( "Unable to parse HTTP-Version from the status line: '" + statusLine + "'"); } this.httpVersion = (statusLine.substring(start, at)).toUpperCase(); //advance through spaces while (statusLine.charAt(at) == ' ') { at++; } //handle the Status-Code int to = statusLine.indexOf(" ", at); if (to < 0) { to = length; } try { this.statusCode = Integer.parseInt(statusLine.substring(at, to)); } catch (NumberFormatException e) { throw new ProtocolException( "Unable to parse status code from status line: '" + statusLine + "'"); } //handle the Reason-Phrase at = to + 1; if (at < length) { this.reasonPhrase = statusLine.substring(at).trim(); } else { this.reasonPhrase = ""; } } catch (StringIndexOutOfBoundsException e) { throw new HttpException("Status-Line '" + statusLine + "' is not valid"); } //save the original Status-Line this.statusLine = statusLine; } // --------------------------------------------------------- Public Methods /** * @return the Status-Code */ public final int getStatusCode() { return statusCode; } /** * @return the HTTP-Version */ public final String getHttpVersion() { return httpVersion; } /** * @return the Reason-Phrase */ public final String getReasonPhrase() { return reasonPhrase; } /** * Return a string representation of this object. * @return a string represenation of this object. */ public final String toString() { return statusLine; } /** * Tests if the string starts with 'HTTP' signature. * @param s string to test * @return true if the line starts with 'HTTP' * signature, false otherwise. */ public static boolean startsWithHTTP(final String s) { try { int at = 0; while (Character.isWhitespace(s.charAt(at))) { ++at; } return ("HTTP".equals(s.substring(at, at + 4))); } catch (StringIndexOutOfBoundsException e) { return false; } } }