All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.json.HTTP Maven / Gradle / Ivy

package org.json;

import java.util.Iterator;

/**
 * Convert an HTTP header to a JSONObject and back.
 * @author JSON.org
 * @version 2009-02-11
 * @deprecated Use javax.json or other other json libraries instead
 */
@Deprecated
public class HTTP {

    /** Carriage return/line feed. */
    public static final String CRLF = "\r\n";

    /**
     * Convert an HTTP header string into a JSONObject. It can be a request
     * header or a response header. A request header will contain
     * 
{
     *    Method: "POST" (for example),
     *    "Request-URI": "/" (for example),
     *    "HTTP-Version": "HTTP/1.1" (for example)
     * }
* A response header will contain *
{
     *    "HTTP-Version": "HTTP/1.1" (for example),
     *    "Status-Code": "200" (for example),
     *    "Reason-Phrase": "OK" (for example)
     * }
* In addition, the other parameters in the header will be captured, using * the HTTP field names as JSON names, so that
     *    Date: Sun, 26 May 2002 18:06:04 GMT
     *    Cookie: Q=q2=PPEAsg--; B=677gi6ouf29bn&b=2&f=s
     *    Cache-Control: no-cache
* become *
{...
     *    Date: "Sun, 26 May 2002 18:06:04 GMT",
     *    Cookie: "Q=q2=PPEAsg--; B=677gi6ouf29bn&b=2&f=s",
     *    "Cache-Control": "no-cache",
     * ...}
* It does no further checking or conversion. It does not parse dates. * It does not do '%' transforms on URLs. * @param string An HTTP header string. * @return A JSONObject containing the elements and attributes * of the XML string. * @throws JSONException */ public static JSONObject toJSONObject(String string) throws JSONException { JSONObject jo = new JSONObject(); HTTPTokener x = new HTTPTokener(string); String token = x.nextToken(); if (token.toUpperCase().startsWith("HTTP")) { jo.put("HTTP-Version", token); jo.put("Status-Code", x.nextToken()); jo.put("Reason-Phrase", x.nextTo('\000')); x.next(); } else { jo.put("Method", token); jo.put("Request-URI", x.nextToken()); jo.put("HTTP-Version", x.nextToken()); } while (x.more()) { String name = x.nextTo(':'); x.next(':'); jo.put(name, x.nextTo('\000')); x.next(); } return jo; } /** * Convert a JSONObject into an HTTP header. A request header must contain *
{
     *    Method: "POST" (for example),
     *    "Request-URI": "/" (for example),
     *    "HTTP-Version": "HTTP/1.1" (for example)
     * }
* A response header must contain *
{
     *    "HTTP-Version": "HTTP/1.1" (for example),
     *    "Status-Code": "200" (for example),
     *    "Reason-Phrase": "OK" (for example)
     * }
* Any other members of the JSONObject will be output as HTTP fields. * The result will end with two CRLF pairs. * @param jo A JSONObject * @return An HTTP header string. * @throws JSONException if the object does not contain enough * information. */ public static String toString(JSONObject jo) throws JSONException { Iterator keys = jo.keys(); StringBuffer sb = new StringBuffer(); if ((jo.has("Status-Code")) && (jo.has("Reason-Phrase"))) { sb.append(jo.getString("HTTP-Version")); sb.append(' '); sb.append(jo.getString("Status-Code")); sb.append(' '); sb.append(jo.getString("Reason-Phrase")); } else if ((jo.has("Method")) && (jo.has("Request-URI"))) { sb.append(jo.getString("Method")); sb.append(' '); sb.append('"'); sb.append(jo.getString("Request-URI")); sb.append('"'); sb.append(' '); sb.append(jo.getString("HTTP-Version")); } else { throw new JSONException("Not enough material for an HTTP header."); } sb.append("\r\n"); while (keys.hasNext()) { String string = keys.next().toString(); if ((!string.equals("HTTP-Version")) && (!string.equals("Status-Code")) && (!string.equals("Reason-Phrase")) && (!string.equals("Method")) && (!string.equals("Request-URI")) && (!jo.isNull(string))) { sb.append(string); sb.append(": "); sb.append(jo.getString(string)); sb.append("\r\n"); } } sb.append("\r\n"); return sb.toString(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy