spring 集成上下文配置中的 Bean 引用
Bean references in spring integration context configuration
我试图确定当我在 Spring 集成存储过程出站网关的存储过程参数中使用我的 bean 引用时无法识别它的原因。我已经能够在两者之间放置一个服务激活器,并使用 bean 作为有效负载创建一条新消息,它工作正常。但为什么我不能使用实际的 bean?
这是一段代码:
<bean id="updateDataContentsMapper" class="org.companyname.connector.support.UpdateDataContentsMapper" depends-on="updateDataContents">
<property name="updateDataContents" ref="updateDataContents"/>
</bean>
<bean id="updateDataContents" class="org.companyname.connector.model.UpdateDataContents"/>
<int:channel id="update-sp-channel"/>
<int:channel id="operation-completion-channel"/>
<int-jdbc:stored-proc-outbound-gateway
id="01-update-data-contents-sp-gateway"
request-channel="update-sp-channel"
reply-channel="operation-completion-channel"
data-source="dataSource"
stored-procedure-name="usp_UpdateDataContents" >
<int-jdbc:sql-parameter-definition name="@vKeyValue"
direction="IN"
type="VARCHAR"
scale="100"/>
<int-jdbc:sql-parameter-definition name="@nSeqNum"
direction="IN"
type="NUMERIC"
scale="20"/>
<int-jdbc:sql-parameter-definition name="@vMessageLog"
direction="IN"
type="VARCHAR"
scale="100"/>
<int-jdbc:sql-parameter-definition name="@vRC"
direction="OUT"
type="VARCHAR"
scale="30"/>
<int-jdbc:parameter name="@vKeyValue" value="#{updateDataContents.vKeyValue}"/>
<int-jdbc:parameter name="@nSeqNum" value="#{updateDataContents.nSeqNum}"/>
<int-jdbc:parameter name="@vMessageLog" value="#{updateDataContents.vMessageLog}"/>
<int-jdbc:parameter name="@vRC" type="java.lang.String" value="new java.lang.String"/>
<int-jdbc:returning-resultset name="updateDataContents" row-mapper="org.companyname.connector.support.UpdateDataContentsMapper" />
</int-jdbc:stored-proc-outbound-gateway>
我发现这很难确定我需要什么。
<int-jdbc:parameter name="@vKeyValue" value="#{updateDataContents.vKeyValue}"/>
或
<int-jdbc:parameter name="@vKeyValue" value="#{updateDataContents.getVKeyValue()}"/>
或
<int-jdbc:parameter name="@vKeyValue" value="updateDataContents.getVKeyValue()"/>
我知道如果我使用消息有效负载,这有效:
<int-jdbc:parameter name="@vKeyValue" expression="payload.getVKeyValue()"/>
如果有人有 link 或者可以给我一些见解,我将不胜感激。我想我的语法是正确的。它必须是与实际集成组件有关的东西或我缺少的东西。
谢谢,
戴夫
我们需要在这里确定您的目标:如果您只需要使用预定义值或每次存储过程适配器收到消息时计算它。
value="#{updateDataContents.getVKeyValue()}
是一个 Bean 定义表达式,它只在启动时计算一次。
<int-jdbc:parameter>
中有一个 expression
替代属性,可以这样指定:
<int-jdbc:parameter name="@vKeyValue" expression="@updateDataContents.getVKeyValue()"/>
在这种情况下,将为每个存储过程执行计算 vKeyValue
。
我试图确定当我在 Spring 集成存储过程出站网关的存储过程参数中使用我的 bean 引用时无法识别它的原因。我已经能够在两者之间放置一个服务激活器,并使用 bean 作为有效负载创建一条新消息,它工作正常。但为什么我不能使用实际的 bean?
这是一段代码:
<bean id="updateDataContentsMapper" class="org.companyname.connector.support.UpdateDataContentsMapper" depends-on="updateDataContents">
<property name="updateDataContents" ref="updateDataContents"/>
</bean>
<bean id="updateDataContents" class="org.companyname.connector.model.UpdateDataContents"/>
<int:channel id="update-sp-channel"/>
<int:channel id="operation-completion-channel"/>
<int-jdbc:stored-proc-outbound-gateway
id="01-update-data-contents-sp-gateway"
request-channel="update-sp-channel"
reply-channel="operation-completion-channel"
data-source="dataSource"
stored-procedure-name="usp_UpdateDataContents" >
<int-jdbc:sql-parameter-definition name="@vKeyValue"
direction="IN"
type="VARCHAR"
scale="100"/>
<int-jdbc:sql-parameter-definition name="@nSeqNum"
direction="IN"
type="NUMERIC"
scale="20"/>
<int-jdbc:sql-parameter-definition name="@vMessageLog"
direction="IN"
type="VARCHAR"
scale="100"/>
<int-jdbc:sql-parameter-definition name="@vRC"
direction="OUT"
type="VARCHAR"
scale="30"/>
<int-jdbc:parameter name="@vKeyValue" value="#{updateDataContents.vKeyValue}"/>
<int-jdbc:parameter name="@nSeqNum" value="#{updateDataContents.nSeqNum}"/>
<int-jdbc:parameter name="@vMessageLog" value="#{updateDataContents.vMessageLog}"/>
<int-jdbc:parameter name="@vRC" type="java.lang.String" value="new java.lang.String"/>
<int-jdbc:returning-resultset name="updateDataContents" row-mapper="org.companyname.connector.support.UpdateDataContentsMapper" />
</int-jdbc:stored-proc-outbound-gateway>
我发现这很难确定我需要什么。
<int-jdbc:parameter name="@vKeyValue" value="#{updateDataContents.vKeyValue}"/>
或
<int-jdbc:parameter name="@vKeyValue" value="#{updateDataContents.getVKeyValue()}"/>
或
<int-jdbc:parameter name="@vKeyValue" value="updateDataContents.getVKeyValue()"/>
我知道如果我使用消息有效负载,这有效:
<int-jdbc:parameter name="@vKeyValue" expression="payload.getVKeyValue()"/>
如果有人有 link 或者可以给我一些见解,我将不胜感激。我想我的语法是正确的。它必须是与实际集成组件有关的东西或我缺少的东西。
谢谢,
戴夫
我们需要在这里确定您的目标:如果您只需要使用预定义值或每次存储过程适配器收到消息时计算它。
value="#{updateDataContents.getVKeyValue()}
是一个 Bean 定义表达式,它只在启动时计算一次。
<int-jdbc:parameter>
中有一个 expression
替代属性,可以这样指定:
<int-jdbc:parameter name="@vKeyValue" expression="@updateDataContents.getVKeyValue()"/>
在这种情况下,将为每个存储过程执行计算 vKeyValue
。