获取mule中每个请求的客户端IP地址

时间:2013-03-09 07:28:51

标签: wsdl cxf mule callable

我在mule中启动了一个带有cxf服务的wsdl。我将客户端IP地址作为变量传递给xml mule config中的java类。 我实现了一个可调用的类来获取IP地址并在数据库中插入ip。 为了测试,我使用wsdl of mule创建了一个Web服务。 在这个过程的持续时间,就在我创建wsdl类时,客户端Ip插入数据库中。 不幸的是,当我使用Web服务并且我发送了请求时,没有在数据库中插入IP。 我的目标:我想在每次请求后将客户端Ip插入数据库。

我使用Mule 3.3.0 CE。我的代码如下:

<mule xmlns:http="http://www.mulesoft.org/schema/mule/http"
xmlns:cxf="http://www.mulesoft.org/schema/mule/cxf" xmlns:scripting="http://www.mulesoft.org/schema/mule/scripting"
xmlns="http://www.mulesoft.org/schema/mule/core" xmlns:doc="http://www.mulesoft.org/schema/mule/documentation"
xmlns:mule-ss="http://www.mulesoft.org/schema/mule/spring-security"
xmlns:ss="http://www.springframework.org/schema/security"
xmlns:spring="http://www.springframework.org/schema/beans" version="CE-3.3.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.mulesoft.org/schema/mule/http http://www.mulesoft.org/schema/mule/http/current/mule-http.xsd 
http://www.mulesoft.org/schema/mule/cxf http://www.mulesoft.org/schema/mule/cxf/current/mule-cxf.xsd 
http://www.mulesoft.org/schema/mule/spring-security http://www.mulesoft.org/schema/mule/spring-security/3.3/mule-spring-security.xsd 
http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.1.xsd 
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/scripting http://www.mulesoft.org/schema/mule/scripting/current/mule-scripting.xsd ">

<global-property name="allowed" value="192.168.3.76,192.168.3.74,192.168.3.75" />

<configuration>
    <expression-language>
        <global-functions>
            def parseIp(fullIp) {
            return fullIp.substring(fullIp.indexOf('/') + 1, fullIp.indexOf(':'))
            }
        </global-functions>
    </expression-language>
</configuration>

<http:connector name="httpConnector" doc:name="HTTP\HTTPS">
    <service-overrides sessionHandler="org.mule.session.NullSessionHandler" />
</http:connector>

<mule-ss:security-manager>
    <mule-ss:delegate-security-provider
        name="memory-dao" delegate-ref="authenticationManager" />
</mule-ss:security-manager>
<spring:beans>
    <ss:authentication-manager
        xmlns:ss="http://www.springframework.org/schema/security" alias="authenticationManager">
        <ss:authentication-provider>
            <ss:user-service id="userService">
                <ss:user name="weather" password="weather" authorities="ROLE_ADMIN" />
            </ss:user-service>
        </ss:authentication-provider>
    </ss:authentication-manager>
</spring:beans>

<flow name="Weather" doc:name="Weather">
    <http:inbound-endpoint host="localhost" port="9091"
        path="/web-service/weather" exchange-pattern="request-response" doc:name="HTTP">
    <mule-ss:http-security-filter realm="mule-realm" />
    </http:inbound-endpoint>
    <expression-filter
        expression="#['${allowed}'.contains(parseIp(message.inboundProperties['MULE_REMOTE_CLIENT_ADDRESS']))]"
        doc:name="Expression" />

    <set-variable variableName="remoteClientAddress"
        value="#[parseIp(message.inboundProperties['MULE_REMOTE_CLIENT_ADDRESS'])]" />
    <message-properties-transformer doc:name="myproperty"
        scope="session">
        <add-message-property key="message.payload.remoteClientAddress"
            value="#[parseIp(message.inboundProperties['MULE_REMOTE_CLIENT_ADDRESS'])]" />
    </message-properties-transformer>

    <component doc:name="classTest" class="org.mule.example.scripting.IpClient" />      

    <cxf:proxy-service 
        service="Weather"
        wsdlLocation="http://wsf.cdyne.com/WeatherWS/Weather.asmx?wsdl"
        namespace="http://ws.cdyne.com/WeatherWS/"
        validationEnabled="true" doc:name="SOAP">
    </cxf:proxy-service>

    <copy-properties propertyName="SOAPAction" doc:name="Property" />

    <cxf:proxy-client doc:name="SOAP" />

    <outbound-endpoint 
        address="http://wsf.cdyne.com/WeatherWS/Weather.asmx"
        exchange-pattern="request-response" doc:name="Generic">
    </outbound-endpoint>

</flow>

和我的java类:

public class IpClient  implements Callable {

  @Override
  public Object onCall(MuleEventContext eventContext) throws Exception {

  MuleMessage msg = eventContext.getMessage();

String remClient = msg.getProperty("remoteClientAddress", PropertyScope.INVOCATION);

DateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
Date date = new Date();

ConnectDB c = new ConnectDB("localhost:3306", "report", "root", "123456");

String sql = " INSERT INTO oml_news (ip, date) VALUES (?,?) ";

PreparedStatement ps = c.getConnnection().prepareStatement(sql);

ps.setString(1, remClient);

ps.setString(2, dateFormat.format(date).toString());

  ps.executeUpdate();

  c.close();

  return true;

  }

1 个答案:

答案 0 :(得分:2)

您遇到的问题当然是因为您没有将SOAP请求发送到Mule服务。

检查SOAPui中的端点URL。