我有一个REST和WCF服务,并希望根据操作发送自定义状态代码。
当某些验证失败然后我想发送HTTP 444并且授权失败时我想发送HTTP 455
问题是我们如何对SOAP和REST Web服务进行验证。
在客户端上,错误代码如何起作用,因为当您从WCF服务(使用SOAP)发送HTTP 400/500时,会在显示状态代码的客户端上抛出异常。
现在,如果我发送一个新的自定义状态代码,客户端如何处理这个?
答案 0 :(得分:86)
是的,只要您尊重该类 - 即2xx表示成功,4xx表示客户端错误等。因此,您可以为自己的应用程序的错误条件返回自定义4XX错误代码(最好是未分配的错误代码)。
引用[RFC 2616] [1]:
“HTTP状态代码是可扩展的。不需要HTTP应用程序 了解所有已注册状态代码的含义,尽管如此 理解显然是可取的。但是,申请必须 了解任何状态代码的类,如第一个所示 数字,并将任何未被识别的响应视为等同于 x00该类的状态代码,但有一个例外 无法识别的响应绝不能被缓存。例如,如果是 客户端收到无法识别的状态代码431,它可以 安全地假设它的请求有问题 将响应视为已收到400状态代码。“
类
1xx:信息 - 收到请求,继续流程
2xx:成功 - 行动已成功收到, 理解并接受
3xx:重定向 - 必须采取进一步行动 完成请求
4xx:客户端错误 - 请求包含错误的语法或不能 实现
5xx:服务器错误 - 服务器无法完成 有效请求[1]:
答案 1 :(得分:28)
我建议您在applicable codes already exist中针对您要在示例中执行的操作创建自己的HTTP状态代码。
来自https://tools.ietf.org/html/rfc4918#section-11.2:
422 [Unprocessable Entity]状态代码表示服务器理解请求实体的内容类型(因此415 [Unsupported Media Type]状态代码不合适),并且请求实体的语法正确(因此400 [错误请求]状态代码不合适)但无法处理包含的指令。例如,如果XML请求主体包含格式正确(即语法正确)但语义错误的XML指令,则可能会出现此错误情况。
可以说“无法处理”可能是由于验证错误。
答案 2 :(得分:17)
是的,您可以添加自定义错误代码。如果可能的话,使用已经存在的代码,如果要声明新代码,请小心避免冲突。
您应该知道某些代理会过滤未知代码。我遇到了用户问题,其中代理将5XX映射到500,而4XX映射到404.这使我的ajax调用检查状态代码失败。
答案 3 :(得分:9)
某些应用程序在600-799范围内添加自定义响应代码。检查例如响应代码列表from KeyNote here
Keynote Defined Error Codes(600-799)
600: CONNECTION ERROR - This indicates a general connection error
601: INCOMPLETE ERROR - This indicates sever sends an incomplete page/object (as indicated by Content-Length header)
602: UNEXPECTED CLOSE ERROR - This indicates socket connection has been closed unexpectedly
603: REFUSED ERROR - This indicates a request to connect to the server is refused
604: TIMEOUT ERROR - This indicates there is no activity in socket connection in 3 minutes
605: REDIRECT ERROR - This indicates an error in redirect HTTP header
606: SSL ERROR - This indicates a general error in SSL
607: HEADER ERROR - This indicates a malformed HTTP header
608: EMPTY RESPONSE ERROR - This indicates server doesn't send any response after a request is sent
609: UNKNOWN HOST ERROR - This indicates socket receives an unknown host error from DNS
610: NO ROUTE TO HOST ERROR - This indicates a no route to host error was received while attempting to open a socket
611: SOCKET ERROR - This indicates a general socket error
612: FRAME LOOP ERROR - This indicates a page has a frame loop (frame A includes Frame B that includes Frame A)
613: REDIRECT LOOP ERROR - This indicates a page has a redirect loop (page A redirects to page B that redirects to page A)
614: CONNECTION RESET ERROR - This indicates socket receive a reset signal from the server
615: SOCKET PROTOCOL ERROR - This indicates an error in socket protocol
616: SOCKET BIND ERROR - This indicates an error in binding the socket
617: CONNECTION ERROR - This indicates a general socket connection error
618: CHUNK ERROR - This indicates an error in chunked encoding
619: SSL TIMEOUT - This indicates a timeout during SSL handshake (2 minutes)
620: SSL END OF INPUT - This indicates an end-of-file is received during SSL handshake
621: SSL HANDSHAKE ERROR - This indicates a general error during SSL handshake
622: SSL CERTIFICATE ERROR - This indicates an error in SSL certificate verification
623: SSL AUTHENTICATION ERROR - This indicates an authentication error during SSL handshake
624: SSL BAD MAC ERROR - This indicates a bad MAC during SSL handshake
625: SSL CIPHER ERROR - This indicates a cipher error during SSL handshake
701: ERROR TEXT FOUND - This code is returned if any error text (such as, "Service Unavailable") are found in the main page (frame HTML contents included). Note that the error text must be defined in advance of the test. Error text means if the text is found, this session should be considered a failure.
702: REQUIRED TEXT NOT FOUND - This code is returned If not all required texts are found in the main page. Note that required text must be defined in advance of the test. Required text means if the text is not found, this session should be considered a failure.
703: HTML BODY EMPTY - This code is returned if the HTML body of the page is empty (only if error text or required text has been defined).
这是不是很好的做法,我不敢说,但至少这是一个有趣的参考。
答案 4 :(得分:6)
这是所有可用/不可用的HTTP
代码的完整列表。
https://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml
例如,在4XX
系列中可以使用以下箭头箭头(因为它们未分配)。
我希望这对某人有帮助。
谢谢
答案 5 :(得分:-11)
不,您只能使用rfc文档要求代码,请参阅RFC1945
中的详细信息