การแก้ปัญหาข้อผิดพลาดเกี่ยวกับรันไทม์ของนโยบาย JavaScript

คุณกำลังดูเอกสารประกอบสำหรับ Apigee Edge
ไปที่เอกสารประกอบของ Apigee X
info

ExecutionError

รหัสข้อผิดพลาด

steps.javacallout.ExecutionError

เนื้อหาการตอบกลับข้อผิดพลาด

{
  "fault": {
    "faultstring": "Execution returned an error result",
    "detail": {
      "errorcode": "flow.execution.ExecutionReturnedFailure"
    }
  }
}

สาเหตุ

ข้อผิดพลาดนี้เกิดขึ้นหากโค้ด Java ส่งข้อยกเว้นหรือแสดงผล null ในระหว่างการเรียกใช้นโยบาย Javacallout

การวินิจฉัย

  1. เริ่มเซสชันการติดตามเพื่อบันทึกข้อผิดพลาดและระบุนโยบาย JavaScript ที่ล้มเหลว

  2. ตรวจสอบนโยบาย JavaCallout และทรัพยากรที่ใช้ ในตัวอย่างข้างต้น นโยบาย JavaCallout ใช้ทรัพยากรชื่อ hello.jar ดังที่แสดงด้านล่าง

    <JavaCallout name="hello-java">
       <ClassName>com.apigeesample.HelloJava</ClassName>
       <ResourceURL>java://hello.jar</ResourceURL>
    </JavaCallout>
    
    
  3. บันทึกและจัดเก็บข้อยกเว้น Java ไว้ในตัวแปรการไหลโดยแก้ไขซอร์สโค้ด ตามที่อธิบายไว้ในการจัดการข้อผิดพลาดในข้อความไฮไลต์ Java

  4. คอมไพล์และแทนที่ทรัพยากรที่ได้รับผลกระทบ (ไฟล์ JAR) ด้วยอาร์ติแฟกต์ Java ที่อัปเดตแล้ว

  5. ทำให้พร็อกซี API ใช้งานได้เป็นเวอร์ชันใหม่และเรียก API

  6. เริ่มเซสชันการติดตามอื่น

  7. โปรดทราบว่าสแต็กเทรซมีอยู่ในตัวแปร JAVA_STACKTRACE สแต็กเทรซจะแสดงข้อยกเว้นจริง รวมถึงไฟล์ต้นฉบับของ Java และหมายเลขบรรทัดที่แสดงข้อผิดพลาด

  8. ใช้ข้อมูลนี้เพื่อแก้ไขปัญหาในโค้ด Java

  9. ในตัวอย่างนี้ นโยบาย JavaCallout ดำเนินการไม่สำเร็จเนื่องจาก ArithmeticException (หารด้วย 0) ในไฟล์ JavaError.java ที่บรรทัด #25

ความละเอียด

  1. แก้ไขปัญหาในไฟล์ซอร์สของ Java ที่เกี่ยวข้องโดยขึ้นอยู่กับข้อยกเว้นที่ส่ง ในตัวอย่างที่แสดงด้านบน ปัญหาเกิดจากข้อผิดพลาดทางคณิตศาสตร์ (การหารด้วย 0) ไปที่ไฟล์ต้นฉบับและหมายเลขบรรทัดที่ระบุโดยสแต็กเทรซ

    ข. เนื่องจากคุณไม่สามารถดำเนินการหารด้วย 0 ให้นำบล็อก else ทั้งหมดที่มีบรรทัดโค้ดที่ไม่ถูกต้องออกเพื่อแก้ไขปัญหา

  2. แทนที่ไฟล์ JAR ที่เกี่ยวข้องซึ่งมีไฟล์ที่แก้ไขแล้วในระดับที่เหมาะสม (พร็อกซี API, สภาพแวดล้อม หรือองค์กร) ที่เคยมีมาก่อน

  3. บันทึกและทำให้พร็อกซี API ใช้งานได้เป็นเวอร์ชันใหม่