Stai visualizzando la documentazione di Apigee e Apigee hybrid.
Visualizza la documentazione di
Apigee Edge.
XSLSourceMessageNotAvailable
Codice di errore
steps.xsl.XSLSourceMessageNotAvailable
Corpo della risposta di errore
{ "fault": { "faultstring": "response message is not available for XSL: policy_name", "detail": { "errorcode": "steps.xsl.XSLSourceMessageNotAvailable" } } }
Esempio di messaggio di errore
{
"fault": {
"faultstring": "response message is not available for XSL: xslt",
"detail": {
"errorcode": "steps.xsl.XSLSourceMessageNotAvailable"
}
}
}
Causa
Questo errore si verifica se la variabile di stringa message
o di stringa specificata nell'elemento <Source>
del criterio XSLTransform è:
- Fuori ambito (non disponibile nel flusso specifico in cui viene eseguita la norma)
- Non può essere risolto (non è definito)
Ad esempio, questo errore si verifica se il criterio XSLTransform deve essere eseguito nel flusso di richiesta, ma l'elemento <Source>
è impostato sulla variabile di risposta, che non esiste nel flusso di richiesta.
Diagnosi
Identifica il criterio XSLTransform in cui si è verificato l'errore e il nome della variabile che non è disponibile. Puoi trovare entrambi gli elementi nell'elemento
faultstring
della risposta di errore. Ad esempio, infaultstring
seguente, il nome del criterio èxslt
e la variabile èresponse
:faultstring": "response message is not available for XSL: xslt
Nel file XML del criterio XSLTransform non riuscito, verifica che il nome del set di variabili nell'elemento
<Source>
corrisponda al nome della variabile identificato nella stringa di errore (passaggio 1 sopra). Ad esempio, il seguente criterio XSLTransform specifica una variabile denominataresponse
nell'elemento<Source>
, che corrisponde al contenuto della stringa di errore:<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <XSL async="false" continueOnError="false" enabled="true" name="xslt"> <DisplayName>xslt</DisplayName> <Properties/> <ResourceURL>xsl://XSL-Transform.xsl</ResourceURL> <Source>response</Source> <Parameters ignoreUnresolvedVariables="false"/> <OutputVariable/> </XSL>
Determina se la variabile utilizzata nell'elemento
<Source>
è definita e disponibile nel flusso in cui viene eseguito il criterio XSLTransform.Se la variabile è:
- Fuori ambito (non disponibile nel flusso specifico in cui il criterio viene applicato) o
- Non può essere risolto (non è definito)
questa è la causa dell'errore.
Ad esempio, supponiamo che la norma XSLTransform mostrata sopra deve essere eseguita nel flusso di richiesta. Ricorda che la variabile
response
viene utilizzata nell'elemento<Source>
del criterio di esempio. La variabileresponse
è disponibile solo nel flusso di risposta.Poiché la variabile
response
non esiste nel flusso di richiesta, riceverai il codice di errore:steps.xsl.XSLSourceMessageNotAvailable
Risoluzione
Assicurati che la variabile impostata nell'elemento <Source>
del criterio XSLTransform non riuscito sia definita e esistente nel flusso in cui viene eseguito il criterio.
Per correggere il criterio XSLTransform di esempio mostrato sopra, puoi modificare l'elemento <Source>
in modo da utilizzare la variabile request
, perché esiste nel flusso di richiesta:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<XSL async="false" continueOnError="false" enabled="true" name="xslt">
<DisplayName>xslt</DisplayName>
<Properties/>
<ResourceURL>xsl://XSL-Transform.xsl</ResourceURL>
<Source>request</Source>
<Parameters ignoreUnresolvedVariables="false"/>
<OutputVariable/>
</XSL>
XSLEvaluationFailed
Codice di errore
steps.xsl.XSLEvaluationFailed
Corpo della risposta di errore
{
"fault": {
"faultstring": "Evaluation of XSL <var>XSL_file_name</var> failed with reason: \"<var>reason_for_failure</var>",
"detail": {
"errorcode": "steps.xsl.XSLEvaluationFailed"
}
}
}
Esempio di messaggio di errore
{
"fault": {
"faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Premature end of document while parsing at line 1(possibly around char 0)\"",
"detail": {
"errorcode": "steps.xsl.XSLEvaluationFailed"
}
}
}
Cause possibili
Questo errore si verifica se:
- Il payload XML di input non è disponibile/è in un formato errato.
- Il criterio XSLTransform ha esito negativo/non è in grado di trasformare il file XML di input in base alle regole di trasformazione fornite nel file XSL. La mancata riuscita del criterio XSLTransform può avere molte cause diverse. Il motivo dell'errore nel messaggio di errore fornirà ulteriori informazioni sulla causa. La seguente tabella elenca una di queste cause di questo errore, Prefisso non valido, ed è spiegata con un esempio.
Causa | Descrizione |
---|---|
Payload XML di input non disponibile | Il payload XML di input non viene trasmesso o vuoto. |
XML di input non corretto | Il payload XML di input non è valido o è in un formato non valido. |
Prefisso non valido | Il payload XML di input ha un prefisso che non è definito nel file XSL. |
Causa: il payload XML di input non è disponibile
Questo errore si verifica se il payload XML di input non viene trasmesso o se il payload XML viene trasmesso come parte della richiesta API al proxy API con il criterio XSLTransform vuoto.
Esempio di messaggio di errore
{
"fault": {
"faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Premature end of document while parsing at line 1(possibly around char 0)\"",
"detail": {
"errorcode": "steps.xsl.XSLEvaluationFailed"
}
}
}
Diagnosi
Identifica il file XSL che non è stato possibile valutare dal criterio XML Transform e il motivo dell'errore. Se il payload XML di input non viene passato o è vuoto, il motivo dell'errore indicherebbe che la fine del documento è prematuro durante l'analisi. Puoi trovare tutte queste informazioni nell'elemento
faultstring
della risposta di errore. Ad esempio, nelfaultstring
seguente, il file XLL èXSL-Transform.xsl
e il motivo dell'errore èPremature end of document while parsing at line 1 (possibly around char 0)
. Questo errore significa che il payload XML non viene passato o è vuoto."faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Premature end of document while parsing at line 1(possibly around char 0)\""
Determina se il payload XML di input che è stato trasmesso come parte della richiesta di è vuoto. Se il payload di input non viene passato o è vuoto, è questa la causa dell'errore.
Nella richiesta di esempio riportata di seguito, il payload (ossia il corpo della richiesta) inviato dall'utente era vuoto.
Ad esempio:
curl -v "http://your_host_alias/v1/xsltransform" -H "Content-Type: application/xml"
Dove your_host_alias è un dominio visibile al pubblico utilizzato per accedere alle tue API, come configurato nella proprietà
virtualhosts.hostAliases
nel file di override. Consulta Specificare gli override della configurazione.Poiché il payload di input XML è vuoto, viene visualizzato l'errore:
"faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Premature end of document while parsing at line 1(possibly around char 0)\""
Risoluzione
Assicurati che l'input passato al criterio XSLTransform sia un payload XML valido e non vuoto.
Per risolvere il problema con il criterio XSLTransform di esempio, trasmetti un payload XML valido. Ad esempio:
Crea un file denominato
city.xml
con il seguente contenuto:<?xml version="1.0" encoding="UTF-8"?> <root> <City>Bengaluru</City> <Name>Apigee</Name> <Pincode>560016</Pincode> </root>
Effettua la chiamata API utilizzando un comando curl come segue:
curl -v "http://your_host_alias/v1/xsltransform" -H "Content-Type: application/xml" -X POST -d @city.xml
Dove your_host_alias è un dominio visibile al pubblico utilizzato per accedere alle tue API, come configurato nella proprietà
virtualhosts.hostAliases
nel file di override. Consulta Specificare gli override della configurazione.
Causa: formato XML di input non corretto
Il payload XML di input passato come parte della richiesta API al criterio XSLTransform non è valido o è in un formato non valido.
Esempio di messaggio di errore
{
"fault": {
"faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Unexpected char while looking for open tag ('<') character\"",
"detail": {
"errorcode": "steps.xsl.XSLEvaluationFailed"
}
}
}
Diagnosi
Identifica il file XSL che non è stato possibile valutare dal criterio XML Transform e il motivo dell'errore. Se il payload XML di input non è corretto, il motivo dell'errore indicherebbe la presenza di un carattere imprevisto. Puoi trovare tutte queste informazioni nell'elemento
faultstring
della risposta di errore. Ad esempio, nel seguentefaultstring
, il file XSL èXSL-Transform.xsl
e il motivo dell'errore èUnexpected char while looking for open tag ('<') character
. Vale a dire che "<
" non è presente nel payload XML."faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Unexpected char while looking for open tag ('<') character\""
Esamina il payload XML di input trasmesso al criterio XSLTransform e verifica se presenta o meno contenuti XML validi. Se il payload di input non è un file XML valido, è questa la causa dell'errore.
Nella richiesta di esempio riportata di seguito, il payload di input (ovvero il corpo della richiesta) inviato dall'utente non è valido.
Ad esempio:
curl -v "http://your_host_alias/v1/xsltransform" -H "Content-Type: application/xml" -X POST -d @city.xml
Dove your_host_alias è un dominio visibile al pubblico utilizzato per accedere alle tue API, come configurato nella proprietà
virtualhosts.hostAliases
nel file di override. Consulta Specificare gli override della configurazione.In questo esempio,
city.xml
è definito come:{ "City": "Bengaluru", "Name": "Apigee", "Pincode": "560016" }
Poiché il payload di input è JSON e non è XML valido, viene visualizzato l'errore:
"faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Unexpected char while looking for open tag ('<') character\""
Risoluzione
Assicurati che l'input passato al criterio XSLTransform sia un payload XML valido e non vuoto.
Per risolvere il problema con il criterio XSLTransform di esempio, trasmetti un payload XML valido. Ad esempio:
Modifica il file
city.xml
in modo che i contenuti siano in XML, come mostrato di seguito:<?xml version="1.0" encoding="UTF-8"?> <root> <City>Bengaluru</City> <Name>Apigee</Name> <Pincode>560016</Pincode> </root>
Effettua la chiamata API utilizzando il comando curl come segue:
curl -v "http://your_host_alias/v1/xsltransform" -H "Content-Type: application/xml" -X POST -d @city.xml
Dove your_host_alias è un dominio visibile al pubblico utilizzato per accedere alle tue API, come configurato nella proprietà
virtualhosts.hostAliases
nel file di override. Consulta Specificare gli override della configurazione.
Causa: prefisso non valido
Il payload XML di input passato al criterio XSLTransform contiene un elemento che non è definito come prefisso nel file XSL specificato nel criterio.
Esempio di messaggio di errore
{
"fault": {
"faultstring": "Evaluation of XSL XSL-Transform.xsl failed with reason: \"Unresolved Prefix at line 1(possibly around char 270)\"",
"detail": {
"errorcode": "steps.xsl.XSLEvaluationFailed"
}
}
}
Diagnosi
Identifica il file XSL che non è stato possibile valutare dal criterio XML Transform e il motivo dell'errore. In questo caso, il motivo dell'errore indicherebbe la presenza di un prefisso non risolto in corrispondenza di un numero di riga specifico nel payload XML di input. Puoi trovare tutte queste informazioni nell'elemento
faultstring
della risposta di errore. Ad esempio, nell'faultstring
seguente, il file XSL èXSL-Transform.xsl
, il motivo dell'errore èUnresolved Prefix
e il numero di riga è1
."faultstring":"Evaluation of XSL XSL-Transform.xsl failed with reason: \"Unresolved Prefix at line 1(possibly around char 270)\""
Esamina il contenuto del file XSL (identificato nel passaggio 1 precedente) e il payload XML di input. Se il prefisso utilizzato nel numero di riga (identificato nel passaggio n. 1 sopra) del payload XML di input non esiste nel file XSL, è questa la causa dell'errore.
Di seguito sono riportati l'XSL di esempio e il payload XML corrispondente che generano l'errore:
XSL-Transform.xsl <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"> <xsl:output method="text"/> <xsl:variable name="newline"> <xsl:text> </xsl:text> </xsl:variable> <xsl:template match="/"> <xsl:text><Life></xsl:text> <xsl:value-of select="$newline"/> <xsl:text>Here are the odd-numbered items from the list:</xsl:text> <xsl:value-of select="$newline"/> <xsl:for-each select="list/listitem"> <xsl:if test="(position() mod 2) = 1"> <xsl:number format="1. "/> <xsl:value-of select="."/> <xsl:value-of select="$newline"/> </xsl:if> </xsl:for-each> <xsl:text></Life></xsl:text> </xsl:template> </xsl:stylesheet>
Payload XML di input
<?xml version="1.0"?> <Life:Books> <title>A few of my favorite albums</title> <listitem>Beat Crazy</listitem> <listitem>Here Come the Warm Jets</listitem> <listitem>Kind of Blue</listitem> <listitem>London Calling</listitem> </Life:Books>
Il payload XML di esempio mostrato sopra contiene un elemento
<Life:Books>
. Nota che l'XSL non ha questo prefisso. Il prefisso è<xsl:text><Life></xsl:text>
. Ricevi quindi l'errore:"faultstring":"Evaluation of XSL XSL-Transform.xsl failed with reason: \"Unresolved Prefix at line 1(possibly around char 270)\""
Risoluzione
Assicurati che il payload XML di input passato al criterio XSLTransform abbia tutti i formati degli elementi definiti come prefissi nel file XSL utilizzato nel criterio.
Per correggere il file XML di esempio mostrato sopra, puoi modificare il file come mostrato di seguito:
Payload XML di input aggiornato
<?xml version="1.0"?>
<Life>
<title>A few of my favorite albums</title>
<listitem>Beat Crazy</listitem>
<listitem>Here Come the Warm Jets</listitem>
<listitem>Kind of Blue</listitem>
<listitem>London Calling</listitem>
</Life>