Java是否有完整的HTTP响应代码枚举?

Zol*_*gyi 245 java http

我想知道在某个标准Java类库中是否存在枚举类型,它定义了所有有效HTTP响应代码的符号常量.它应该支持转换为/来自相应的整数值.

我正在调试一些使用javax.ws.rs.core.Response.Status的Java代码.它有效,但它只定义了大约一半的有效HTTP响应代码.

Joh*_*lla 263

我不认为标准Java类中有一个完整的; HttpURLConnection缺少相当多的代码,比如HTTP 100/Continue.尽管如此,Apache Commons中有一个完整的列表:org.apache.http.HttpStatus.

更新: Apache Commons HttpClient已经过时.有关状态代码列表,请org.apache.commons.HttpClient.HttpStatus在Apache HttpComponents中使用.

  • @JulianReschke我认为这里的"完整"应理解为"符合标准概述的所有代码". (13认同)
  • 没有"完整列表"这样的东西,因为状态代码可以并且确实得到扩展. (5认同)
  • 约翰:"标准"没有定义"全部"状态代码.这就是为什么有一个注册表. (2认同)
  • http://www.iana.org/assignments/http-status-codes/http-status-codes.xml 有一个很大的列表,包括 code=100 (2认同)
  • @Donal:再次,不是一个好的清单。相关的是 IANA 注册管理机构。 (2认同)

Dav*_*itz 63

接口javax.servlet.http.HttpServletResponse从servlet API具有形式的所有响应代码int常量名SC_<description>.请参阅http://docs.oracle.com/javaee/6/api/javax/servlet/http/HttpServletResponse.html

  • HttpServletResponse支持RFC1945和RFC2616标准的一部分,但它缺少所有RFC2518.如果您需要完整列表,请参阅我提到的HttpStatus. (3认同)
  • HttpServletResponse也缺少[RFC 2324](https://tools.ietf.org/html/rfc2324)中定义的418响应代码 (2认同)
  • 在 servlet 外部运行的任何内容中使用 HttpServletResponse 可能会由于不同 servlet 工件中的类重叠而导致钻石依赖性问题。 (2认同)

Mys*_*tic 41

好吧,HttpURLConnection类中存在完全整数值的静态常量

  • 谢谢!这没有任何外部依赖性.`java.net.HttpURLConnection.HTTP_BAD_REQUEST` (4认同)
  • 很好,它是标准库的一部分,但不幸的是它不完整 - 例如在 400 范围内,它在 415 处截止。 (3认同)

Ed *_*d J 17

如果您正在使用Spring,那么3.x版本可以满足您的需求:http: //static.springsource.org/spring/docs/3.0.x/api/org/springframework/http/HttpStatus.html

  • 我想补充一下,Springs org.springframework.http.HttpStatus(https://docs.spring.io/spring/docs/current/javadoc-api/org/springframework/http/HttpStatus.html)枚举是唯一的我可以发现它为Java文档提供了指向状态代码及其在每个枚举中的用法的完整列表的链接。如果您已经在使用Spring,那么它将是要使用的库。 (3认同)
  • 它有100和418。可惜您必须调用`HttpStatus.XXX.value()`来获取整数。 (2认同)

Chr*_* S. 13

这是一个包含状态代码及其描述的枚举(在撰写本文时)对应于HTTP 状态代码注册表

请注意,注册表可能会更新,并且有时会使用非官方状态代码。

public enum HttpStatusCode {

    //1xx: Informational
    CONTINUE(100, "Continue"),
    SWITCHING_PROTOCOLS(101, "Switching Protocols"),
    PROCESSING(102, "Processing"),
    EARLY_HINTS(103, "Early Hints"),

    //2xx: Success
    OK(200, "OK"),
    CREATED(201, "Created"),
    ACCEPTED(202, "Accepted"),
    NON_AUTHORITATIVE_INFORMATION(203, "Non-Authoritative Information"),
    NO_CONTENT(204, "No Content"),
    RESET_CONTENT(205, "Reset Content"),
    PARTIAL_CONTENT(206, "Partial Content"),
    MULTI_STATUS(207, "Multi-Status"),
    ALREADY_REPORTED(208, "Already Reported"),
    IM_USED(226, "IM Used"),

    //3xx: Redirection
    MULTIPLE_CHOICES(300, "Multiple Choice"),
    MOVED_PERMANENTLY(301, "Moved Permanently"),
    FOUND(302, "Found"),
    SEE_OTHER(303, "See Other"),
    NOT_MODIFIED(304, "Not Modified"),
    USE_PROXY(305, "Use Proxy"),
    TEMPORARY_REDIRECT(307, "Temporary Redirect"),
    PERMANENT_REDIRECT(308, "Permanent Redirect"),

    //4xx: Client Error
    BAD_REQUEST(400, "Bad Request"),
    UNAUTHORIZED(401, "Unauthorized"),
    PAYMENT_REQUIRED(402, "Payment Required"),
    FORBIDDEN(403, "Forbidden"),
    NOT_FOUND(404, "Not Found"),
    METHOD_NOT_ALLOWED(405, "Method Not Allowed"),
    NOT_ACCEPTABLE(406, "Not Acceptable"),
    PROXY_AUTHENTICATION_REQUIRED(407, "Proxy Authentication Required"),
    REQUEST_TIMEOUT(408, "Request Timeout"),
    CONFLICT(409, "Conflict"),
    GONE(410, "Gone"),
    LENGTH_REQUIRED(411, "Length Required"),
    PRECONDITION_FAILED(412, "Precondition Failed"),
    REQUEST_TOO_LONG(413, "Payload Too Large"),
    REQUEST_URI_TOO_LONG(414, "URI Too Long"),
    UNSUPPORTED_MEDIA_TYPE(415, "Unsupported Media Type"),
    REQUESTED_RANGE_NOT_SATISFIABLE(416, "Range Not Satisfiable"),
    EXPECTATION_FAILED(417, "Expectation Failed"),
    MISDIRECTED_REQUEST(421, "Misdirected Request"),
    UNPROCESSABLE_ENTITY(422, "Unprocessable Entity"),
    LOCKED(423, "Locked"),
    FAILED_DEPENDENCY(424, "Failed Dependency"),
    TOO_EARLY(425, "Too Early"),
    UPGRADE_REQUIRED(426, "Upgrade Required"),
    PRECONDITION_REQUIRED(428, "Precondition Required"),
    TOO_MANY_REQUESTS(429, "Too Many Requests"),
    REQUEST_HEADER_FIELDS_TOO_LARGE(431, "Request Header Fields Too Large"),
    UNAVAILABLE_FOR_LEGAL_REASONS(451, "Unavailable For Legal Reasons"),

    //5xx: Server Error
    INTERNAL_SERVER_ERROR(500, "Internal Server Error"),
    NOT_IMPLEMENTED(501, "Not Implemented"),
    BAD_GATEWAY(502, "Bad Gateway"),
    SERVICE_UNAVAILABLE(503, "Service Unavailable"),
    GATEWAY_TIMEOUT(504, "Gateway Timeout"),
    HTTP_VERSION_NOT_SUPPORTED(505, "HTTP Version Not Supported"),
    VARIANT_ALSO_NEGOTIATES(506, "Variant Also Negotiates"),
    INSUFFICIENT_STORAGE(507, "Insufficient Storage"),
    LOOP_DETECTED(508, "Loop Detected"),
    NOT_EXTENDED(510, "Not Extended"),
    NETWORK_AUTHENTICATION_REQUIRED(511, "Network Authentication Required");

    private final int value;
    private final String description;

    HttpStatusCode(int value, String description) {
        this.value = value;
        this.description = description;
    }

    public int getValue() {
        return value;
    }

    public String getDescription() {
        return description;
    }

    @Override
    public String toString() {
        return value + " " + description;
    }

    public static HttpStatusCode getByValue(int value) {
        for(HttpStatusCode status : values()) {
            if(status.value == value) return status;
        }
        throw new IllegalArgumentException("Invalid status code: " + value);
    }
}
Run Code Online (Sandbox Code Playgroud)


And*_*ejs 7

如果您使用的是Netty,则可以使用:


And*_*esi 5

使用javax.servlet.http.HttpServletResponse类

例:

javax.servlet.http.HttpServletResponse.SC_UNAUTHORIZED //401
javax.servlet.http.HttpServletResponse.SC_INTERNAL_SERVER_ERROR //500
Run Code Online (Sandbox Code Playgroud)

  • 对于客户端开发,包含整个servlet API只是为了获取这些代码是很麻烦的. (4认同)
  • 一个重复的答案,三年后发布?应该删除. (2认同)

Dav*_*ora 5

每个人似乎都忽略了问题的“枚举类型”部分。

尽管没有HTTP状态代码的规范来源,但是有一种简单的方法可以将所需的任何缺少的Status常量添加到所提供的状态常量中,javax.ws.rs.core.Response.Status而无需在项目中添加任何其他依赖项。

javax.ws.rs.core.Response.Status只是该javax.ws.rs.core.Response.StatusType接口的一种实现。您只需要创建自己的实现枚举以及所需状态代码的定义。

诸如Javax,Jersey等的核心库是写入接口 StatusType而不是实现的 Status(或者应该是)。由于新的Status枚举实现了,StatusType因此可以在任何使用javax.ws.rs.core.Response.Status常量的地方使用它。

只要记住您自己的代码也应该写入StatusType接口即可。这将使您能够同时使用自己的状态代码和“标准”代码。

这是一个具有简单实现方式的要点,该实现带有为“信息1xx”状态码定义的常量:https : //gist.github.com/avendasora/a5ed9acf6b1ee709a14a


Mai*_*Bay 5

1)如果您只有代码,要获取原因文本,您可以使用:

org.apache.http.impl.EnglishReasonPhraseCatalog.INSTANCE.getReason(httpCode,null)
Run Code Online (Sandbox Code Playgroud)

httpCode您从 HTTP 响应中获得的原因代码在哪里。

https://hc.apache.org/httpcomponents-core-ga/httpcore/apidocs/org/apache/http/impl/EnglishReasonPhraseCatalog.html详细信息

2)如果只有文本,要获取原因代码,可以使用BasicHttpResponse.

详情请看这里:https : //hc.apache.org/httpcomponents-core-ga/httpcore/apidocs/org/apache/http/message/BasicHttpResponse.html