フローで次のコンポーネントを定義しています。
<component doc:name="GraduationService">
<method-entry-point-resolver>
<include-entry-point method="getGraduationDatesWithPidmOrStudentId"/>
</method-entry-point-resolver>
<spring-object bean="graduationService" />
</component>
「graduationService」Bean で定義された「getGraduationDatesWithPidmOrStudentId」メソッドを呼び出そうとしています。メソッドのシグネチャは次のようになります。
public Object getGraduationDatesWithPidmOrStudentId(@Payload Payload payload,
@InboundHeaders("studentId") String studentId,
@InboundHeaders("pidm") String pidm ) { ....... }
次のエラーが表示されます。
Message : Failed to find entry point for component, the following resolvers tried but failed: [
ExplicitMethodEntryPointResolver: Could not find entry point on: "edu.ucdavis.iet.apis.students.graduation.service.GraduationService" with arguments: "{class java.lang.String}"
]
Code : MULE_ERROR-321
--------------------------------------------------------------------------------
Exception stack is:
1. Failed to find entry point for component, the following resolvers tried but failed: [
ExplicitMethodEntryPointResolver: Could not find entry point on: "edu.ucdavis.iet.apis.students.graduation.service.GraduationService" with arguments: "{class java.lang.String}"
] (org.mule.model.resolvers.EntryPointNotFoundException)
org.mule.model.resolvers.DefaultEntryPointResolverSet:49 (http://www.mulesoft.org/docs/site/current3/apidocs/org/mule/model/resolvers/EntryPointNotFoundException.html)
--------------------------------------------------------------------------------
Root Exception stack trace:
org.mule.model.resolvers.EntryPointNotFoundException: Failed to find entry point for component, the following resolvers tried but failed: [
ExplicitMethodEntryPointResolver: Could not find entry point on: "edu.ucdavis.iet.apis.students.graduation.service.GraduationService" with arguments: "{class java.lang.String}"
]
at org.mule.model.resolvers.DefaultEntryPointResolverSet.invoke(DefaultEntryPointResolverSet.java:49)
at org.mule.component.DefaultComponentLifecycleAdapter.invoke(DefaultComponentLifecycleAdapter.java:339)
at org.mule.component.AbstractJavaComponent.invokeComponentInstance(AbstractJavaComponent.java:82)
+ 3 more (set debug level logging or '-Dmule.verbose.exceptions=true' for everything)
********************************************************************************
InboundHeaders の注釈を削除し、'@Payload ペイロード ペイロード' を '@Payload String ペイロード' に変更すると、少なくともこれを取得してメソッドを解決することはできません。@InboundHeader アノテーションがどのように機能するのか理解していないようです。