ведение журнала ввода/вывода xml в клиенте apache xmlrpc

Я создаю клиент xmlrpc с Java, используя Apache xmlrpc, но не могу понять, как регистрировать ввод/вывод xml (полученные и отправленные необработанные данные). Как мне это сделать?

Спасибо


person ndriks    schedule 13.03.2012    source источник
comment
Какую структуру ведения журнала вы используете?   -  person Rostislav Matl    schedule 13.03.2012
comment
нет фреймворка, мне просто нужно что-то простое, чтобы иметь возможность читать входящий и исходящий xml   -  person ndriks    schedule 13.03.2012


Ответы (2)


Мой обходной путь заключался в использовании пользовательского транспорта следующим образом. Возможно, есть более изящные способы сделать это.

import java.io.BufferedReader;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.logging.Level;
import java.util.logging.Logger;

import org.apache.xmlrpc.XmlRpcException;
import org.apache.xmlrpc.client.XmlRpcClient;
import org.apache.xmlrpc.client.XmlRpcStreamTransport;
import org.apache.xmlrpc.client.XmlRpcSunHttpTransport;
import org.apache.xmlrpc.common.XmlRpcStreamRequestConfig;
import org.xml.sax.SAXException;


/**
 * This is a custom XML-RPC transport which logs the outgoing and incoming
 * XML-RPC messages.
 */
public class MessageLoggingTransport extends XmlRpcSunHttpTransport
{
    private static final Logger log = Logger.getLogger(MessageLoggingTransport.class.getName());


    /**
     * Default constructor
     * 
     * @see XmlRpcSunHttpTransport#XmlRpcSunHttpTransport(XmlRpcClient)
     * @param pClient
     */
    public CookieHandlingTransport(final XmlRpcClient pClient)
    {
        super(pClient);
    }


    /**
     * Dumps outgoing XML-RPC requests to the log
     */
    @Override
    protected void writeRequest(final XmlRpcStreamTransport.ReqWriter pWriter) throws IOException, XmlRpcException, SAXException
    {
        final ByteArrayOutputStream baos = new ByteArrayOutputStream();
        pWriter.write(baos);
        log.info(baos.toString());
        super.writeRequest(pWriter);
    }


    /**
     * Dumps incoming XML-RPC responses to the log
     */
    @Override
    protected Object readResponse(XmlRpcStreamRequestConfig pConfig, InputStream pStream) throws XmlRpcException
    {
        final StringBuffer sb = new StringBuffer();

        try
        {
            final BufferedReader reader = new BufferedReader(new InputStreamReader(pStream));
            String line = reader.readLine();
            while(line != null)
            {
                sb.append(line);
                line = reader.readLine();
            }
        }
        catch(final IOException e)
        {
            log.log(Level.SEVERE, "While reading server response", e);
        }

        log.info(sb.toString());

        final ByteArrayInputStream bais = new ByteArrayInputStream(sb.toString().getBytes());
        return super.readResponse(pConfig, bais);
    }
}

А затем в коде, который создает ваш клиент XML-RPC:

final XmlRpcClientConfigImpl config = new XmlRpcClientConfigImpl();
config.setServerURL(new URL(url));

final XmlRpcTransportFactory transportFactory = new XmlRpcTransportFactory()
{
    public XmlRpcTransport getTransport()
    {
        return new MessageLoggingTransport(client);
    }
};

client = new XmlRpcClient();
client.setTransportFactory(transportFactory);
client.setConfig(config);
person Adam    schedule 08.08.2012

Попробуйте использовать регистратор для org.apache.xmlrpc.client; Бьюсь об заклад, он выплюнет xml где-нибудь в этом пакете. Попробуйте что-то вроде этого:

<appender name="LOG_FILE" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="Threshold" value="DEBUG"/>
    <param name="File" value="C:\xmlrpc_client.log"/>
    <param name="datePattern" value="'.'yyyy-ww" />
    <param name="Append" value="true"/>
            <layout class="org.apache.log4j.PatternLayout">
               <param name="ConversionPattern" value="[%p] %t %d{DATE} %M - %m%n"/>
            </layout>
    </appender>

    <logger name="org.apache.xmlrpc.client">
    <level value="DEBUG"/>
</logger>
    <root>
       <level value="INFO" />
       <appender-ref ref="LOG_FILE"/>
    </root>
person Carlos Jaime C. De Leon    schedule 13.03.2012
comment
Извините, но я не понимаю. Что это за xml? простите за новичок :D - person ndriks; 13.03.2012
comment
Привет, не беспокойтесь, но когда вы сказали «журнал», я подумал, что вы уже используете log4j. В этом случае, если вы начнете использовать log4j, очень простой в настройке, используйте приведенную выше конфигурацию для log4j.xml, и все классы в этом пакете org.apache.xmlrpc.client будут регистрировать свои данные, я уверен, что один из классов там, вероятно, XmlRpcClient будет регистрировать отправляемый xml и получаемый xml - person Carlos Jaime C. De Leon; 14.03.2012
comment
@CarlosJaimeC.DeLeon, я пробовал это, но, похоже, в этом регистраторе ничего не регистрируется. - person W. Goeman; 09.04.2012