Estás viendo la documentación de Apigee Edge.
Ve a la
Documentación de Apigee X. información
En este tema, se describe la estructura de los errores de políticas y los tipos de variables de flujo que se establecen cuando se produce un error de políticas. Esta información es esencial si estás diseñando y, luego, implementando el control de errores para tus proxies.
En este tema, se supone que tienes conocimientos generales de cómo funciona el manejo de errores en Edge. saber qué son las reglas de errores. Si necesitas una revisión, consulta Maneja las fallas. Esta información También te servirán para navegar y usar la referencia de Errores de política.
Acerca de la respuesta de error de la política predeterminada
Cuando se produce un error en una política, Edge ingresa de inmediato al flujo de errores y genera un error mensaje. Este mensaje generado por el sistema es un objeto JSON que incluye dos bits de información: un errorcode y una faultstring.
Por ejemplo:
{ "fault":{ "detail":{ "errorcode":"steps.extractvariables.SourceMessageNotAvailable" }, "faultstring":"foo message is not available for ExtractVariable: ParseJsonResponse" } }
Vamos a deconstruir rápidamente este mensaje de error:
errorcode consta de un prefijo y un error
name de la siguiente manera: [prefix].[error_name]
. En el ejemplo anterior
“steps.extractvariables
” es el prefijo, y SourceMessageNotAvailable
es
el nombre del error. El prefijo te indica qué tipo de política generó el error. En el ejemplo anterior
ejemplo, puedes saber que una política de extracción de variables generó el error y que su nombre es
SourceMessageNotAvailable
La faultstring contiene una descripción del error. Cadena con errores
normalmente incluye pistas para ayudarte a encontrar el problema específico que causó el error, como el
nombre de la política, el nombre de una variable sin resolver o cualquier cosa que haya contribuido al error. Para
Por ejemplo, en el mensaje de error anterior, "foo
" resulta ser el nombre de un proyecto sin resolver
variable de mensaje a la que se hace referencia en la política y en "ParseJsonResponse
" es el nombre del
política que activó el error.
Variables específicas para errores de la política
Cuando se activa un error de política, se propagan ciertas variables de flujo específicas del error. Estas variables son muy útiles en el manejo de errores. Como se explica en el tema Manejo de fallas, una práctica común es para capturar los errores de la política generados por el sistema y realizar una acción posterior, como crear respuesta de error personalizada. Por ejemplo, por motivos de seguridad, es posible que desee evitar que los clientes ver los errores y códigos de estado reales que devuelve Edge.
La variable fault.name
Cuando una política muestra un error, establece la variable de flujo fault.name
como la parte error_name
del código de error (como se describió en la sección anterior). Es muy común evaluar esta variable para ejecutar reglas de errores de forma condicional.
Esta es una regla de error de ejemplo que prueba el valor de fault.name
:
<faultrule name="VariableOfNonMsgType"<>/faultrule><FaultRule name="Source Message Not Available Fault"> <Step> <Name>AM-CustomErrorMessage</Name> <Condition>(fault.name Matches "SourceMessageNotAvailable") </Condition> </Step> </FaultRule>
Lo que debes recordar es que cuando una política activa un error, la variable fault.name
siempre se configura como el nombre del error.
La variable [prefix].[policy_name].failed
Además de fault.name
, otra variable que los desarrolladores suelen verificar es la marca [prefix].[policy_name].failed
, que se establece como verdadera o falsa cuando se ejecuta una política. En las reglas de errores, querrás comprobar si es verdadero.
es decir, para verificar
si se produjo un error. A continuación, se explica cómo construir una condicional que verifique la marca [prefix].[policy_name].failed
. Para verificar esta variable de forma correcta, debes saber dos cosas:
- El nombre de la política que estás verificando. Este es el valor del atributo de nombre de la política, no el nombre visible. Este atributo siempre se incluye en el XML de la definición de la política.
- Un prefijo que es específico del tipo de política que verificas. (Explicaremos cómo encontrar el prefijo a continuación).
A modo de ejemplo, este es otro ejemplo de regla de error. Observa en la condición externa cómo se forma el nombre de la variable [prefix].[policy_name].failed
. En este caso, el prefijo es extractvariables
y el nombre de la política es ParseJsonResponse
. En este caso, la regla de error solo se ejecutará si esta variable es verdadera. Esta es una sugerencia: dado que las reglas de errores pueden contener varios pasos, este patrón es una buena manera de organizarlas en bloques.
<faultrule name="VariableOfNonMsgType"></faultrule><FaultRule name="Extract Variable Faults"> <Step> <Name>AM-CustomErrorMessage</Name> <Condition>(fault.name Matches "SourceMessageNotAvailable") </Condition> </Step> <Condition>(extractvariables.ParseJsonResponse.failed = true) </Condition> </FaultRule>
Acerca de las variables error
y message
La variable error
solo está disponible en el flujo de error de un
proxy. Puedes obtener información útil de la variable de error, como el mensaje de error, el estado
código, frase de motivo, etc. El patrón de formato para la variable de error es el siguiente:
error.[error_component] = [value]
Por ejemplo:
error.message
= "request message is not available for ExtractVariable:
ParseJsonResponse
"
Yerror.status.code = "500"
La variable message
también está disponible en el flujo de error y se puede usar para propósitos similares a los de la variable error
. La variable de mensaje es especial porque es contextual. En un flujo de solicitudes, se comporta como una variable de solicitud y, en un flujo de respuesta, se puede usar para obtener o establecer valores de respuesta. Para obtener más información, consulta Usa
para las variables de mensaje.
Consulta la Referencia de variables
para obtener información sobre todas las variables de Edge, incluidas error
y
message