คุณกำลังดูเอกสารประกอบสำหรับ Apigee Edge
ไปที่เอกสารประกอบของ Apigee X info
ExecutionError
รหัสข้อผิดพลาด
steps.javacallout.ExecutionError
เนื้อหาการตอบกลับข้อผิดพลาด
{
"fault": {
"faultstring": "Execution returned an error result",
"detail": {
"errorcode": "flow.execution.ExecutionReturnedFailure"
}
}
}
สาเหตุ
ข้อผิดพลาดนี้เกิดขึ้นหากโค้ด Java ส่งข้อยกเว้นหรือแสดงผล null ในระหว่างการเรียกใช้นโยบาย Javacallout
การวินิจฉัย
เริ่มเซสชันการติดตามเพื่อบันทึกข้อผิดพลาดและระบุนโยบาย JavaScript ที่ล้มเหลว
ตรวจสอบนโยบาย JavaCallout และทรัพยากรที่ใช้ ในตัวอย่างข้างต้น นโยบาย JavaCallout ใช้ทรัพยากรชื่อ
hello.jar
ดังที่แสดงด้านล่าง<JavaCallout name="hello-java"> <ClassName>com.apigeesample.HelloJava</ClassName> <ResourceURL>java://hello.jar</ResourceURL> </JavaCallout>
บันทึกและจัดเก็บข้อยกเว้น Java ไว้ในตัวแปรการไหลโดยแก้ไขซอร์สโค้ด ตามที่อธิบายไว้ในการจัดการข้อผิดพลาดในข้อความไฮไลต์ Java
คอมไพล์และแทนที่ทรัพยากรที่ได้รับผลกระทบ (ไฟล์ JAR) ด้วยอาร์ติแฟกต์ Java ที่อัปเดตแล้ว
ทำให้พร็อกซี API ใช้งานได้เป็นเวอร์ชันใหม่และเรียก API
เริ่มเซสชันการติดตามอื่น
โปรดทราบว่าสแต็กเทรซมีอยู่ในตัวแปร
JAVA_STACKTRACE
สแต็กเทรซจะแสดงข้อยกเว้นจริง รวมถึงไฟล์ต้นฉบับของ Java และหมายเลขบรรทัดที่แสดงข้อผิดพลาดใช้ข้อมูลนี้เพื่อแก้ไขปัญหาในโค้ด Java
ในตัวอย่างนี้ นโยบาย JavaCallout ดำเนินการไม่สำเร็จเนื่องจาก ArithmeticException (หารด้วย 0) ในไฟล์
JavaError.java
ที่บรรทัด #25
ความละเอียด
แก้ไขปัญหาในไฟล์ซอร์สของ Java ที่เกี่ยวข้องโดยขึ้นอยู่กับข้อยกเว้นที่ส่ง ในตัวอย่างที่แสดงด้านบน ปัญหาเกิดจากข้อผิดพลาดทางคณิตศาสตร์ (การหารด้วย 0) ไปที่ไฟล์ต้นฉบับและหมายเลขบรรทัดที่ระบุโดยสแต็กเทรซ
ข. เนื่องจากคุณไม่สามารถดำเนินการหารด้วย 0 ให้นำบล็อก else ทั้งหมดที่มีบรรทัดโค้ดที่ไม่ถูกต้องออกเพื่อแก้ไขปัญหา
แทนที่ไฟล์ JAR ที่เกี่ยวข้องซึ่งมีไฟล์ที่แก้ไขแล้วในระดับที่เหมาะสม (พร็อกซี API, สภาพแวดล้อม หรือองค์กร) ที่เคยมีมาก่อน
บันทึกและทำให้พร็อกซี API ใช้งานได้เป็นเวอร์ชันใหม่