2013-10-29 2 views
4

누구든지 다음과 같은 문제가 발생하는 이유를 설명 할 수 있습니까? 논리적 AND를 사용할 때 피연산자의 순서가 중요한 이유는 무엇입니까? mule-ce에서 실행 3.3.1.MEL 논리적이고 행동 이상한, 피연산자 순서가 중요합니까?

true 
true 
false 
true 


<?xml version="1.0" encoding="UTF-8"?> 

<mule xmlns:http="http://www.mulesoft.org/schema/mule/http" xmlns="http://www.mulesoft.org/schema/mule/core" xmlns:doc="http://www.mulesoft.org/schema/mule/documentation" xmlns:spring="http://www.springframework.org/schema/beans" version="EE-3.4.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-current.xsd 
http://www.mulesoft.org/schema/mule/core http://www.mulesoft.org/schema/mule/core/current/mule.xsd 
http://www.mulesoft.org/schema/mule/http http://www.mulesoft.org/schema/mule/http/current/mule-http.xsd"> 

    <flow name="testFlow1" doc:name="testFlow1"> 
     <http:inbound-endpoint exchange-pattern="request-response" host="localhost" port="20005" path="test" doc:name="HTTP"/> 

     <message-properties-transformer overwrite="true" scope="session" doc:name="Message Properties"> 
       <add-message-property key="productNumber" value="1" /> 
     </message-properties-transformer> 

     <logger level="INFO" message="#[(sessionVars['productNumber'] == '1' || sessionVars['productNumber'] == '2') and (sessionVars['quantity'] == null)]" doc:name="Logger"/> 
     <!-- true --> 

     <logger level="INFO" message="#[(sessionVars['quantity'] == null) and (sessionVars['productNumber'] == '1' || sessionVars['productNumber'] == '2')]" doc:name="Logger"/> 
     <!-- true --> 

     <message-properties-transformer overwrite="true" scope="session" doc:name="Message Properties"> 
       <add-message-property key="productNumber" value="3" /> 
     </message-properties-transformer> 

     <logger level="INFO" message="#[(sessionVars['productNumber'] == '1' || sessionVars['productNumber'] == '2') and (sessionVars['quantity'] == null)]" doc:name="Logger"/> 
     <!-- false --> 

     <logger level="INFO" message="#[(sessionVars['quantity'] == null) and (sessionVars['productNumber'] == '1' || sessionVars['productNumber'] == '2')]" doc:name="Logger"/> 
     <!-- true? it should not be true! -->   
    </flow> 
</mule> 

답변

0

이런 일이 발생하는 이유는 모르겠지만, 나는 3.4.0 CE에서 같은 경험을 다음과 같이

출력이다. 올바른 결과를 달성하기 위해 한 가지 해결 방법은

#[(sessionVars['quantity'] == null) && (sessionVars['productNumber'] == '1' || sessionVars['productNumber'] == '2')]

1

사용 & ampamp 같이 "& &"를 사용하는 것 같다; 및 대신. 올바른 값을 계산합니다. 업데이트 된 흐름

<logger level="INFO" message="#[(sessionVars['productNumber'] == '1' || sessionVars['productNumber'] == '2') &amp;&amp; (sessionVars['quantity'] == null)]" doc:name="Logger"/> 
    <!-- false --> 


<logger level="INFO" message="#[(sessionVars['quantity'] == null) &amp;&amp; (sessionVars['productNumber'] == '1' || sessionVars['productNumber'] == '1')]" doc:name="Logger"/>