0

多分これは本当に些細なことですが、どういうわけか、これが機能しない理由を見つけることができませんでした!

cxf の jaxrs:server ディレクティブを介して公開されるサービスがあります

<jaxrs:server id="specialServiceRS"
    address="http://localhost:8080/specialServiceRS">
    <jaxrs:serviceBeans>
        <ref bean="specialService" />
    </jaxrs:serviceBeans>
    <jaxrs:providers>
        <bean id="jaxbProvider"
            class="org.apache.cxf.jaxrs.provider.JAXBElementProvider">
            <property name="marshallAsJaxbElement" value="true" />
            <property name="unmarshallAsJaxbElement" value="true" />
        </bean>
        <bean class="org.codehaus.jackson.jaxrs.JacksonJsonProvider">
            <property name="mapper" ref="jacksonMapper" />
        </bean>
        <bean class="com.kilo.ProgressiveDateHandler" />
    </jaxrs:providers>
</jaxrs:server>
<bean id="jacksonMapper" class="org.codehaus.jackson.map.ObjectMapper">
    <property name="serializationConfig.dateFormat">
        <bean class="java.text.SimpleDateFormat">
            <constructor-arg value="yyyyMMddHH:mm:ss.S" />
        </bean>
    </property>
    <property name="deserializationConfig.dateFormat">
        <bean class="java.text.SimpleDateFormat">
            <constructor-arg value="yyyyMMddHH:mm:ss.S" />
        </bean>
    </property>
</bean>

日付を正しく処理できるようにするために、日付ハンドラー ( ProgressiveDateHandler ) を追加しました。これは ParameterHandler と ParamConverter です。これは、ブラウザー経由で呼び出すと正常に動作するように見えますが、cxf の jaxrs:client ディレクティブで構成された Java ベースのクライアント経由で呼び出すと、

<jaxrs:client id="specialServiceClient" serviceClass="com.kilo.SpecialServiceImpl"
    address="http://localhost:8080/specialServiceRS">
    <jaxrs:providers>
        <bean class="org.codehaus.jackson.jaxrs.JacksonJsonProvider">
            <property name="mapper" ref="jacksonMapper" />
        </bean>
        <bean class="com.kilo.ProgressiveDateHandler" />
    </jaxrs:providers>
</jaxrs:client>
<bean id="jacksonMapper" class="org.codehaus.jackson.map.ObjectMapper">
</bean>

次のエラーが表示されます。

java.lang.IllegalArgumentException: Null value on 0 position
at org.apache.cxf.jaxrs.impl.UriBuilderImpl.toStringList(UriBuilderImpl.java:767)
at org.apache.cxf.jaxrs.impl.UriBuilderImpl.queryParam(UriBuilderImpl.java:660)
at org.apache.cxf.jaxrs.client.AbstractClient.addMatrixOrQueryToBuilder(AbstractClient.java:671)
at org.apache.cxf.jaxrs.client.AbstractClient.convertMatrixOrQueryToBuilder(AbstractClient.java:661)
at org.apache.cxf.jaxrs.client.AbstractClient.addMatrixQueryParamsToBuilder(AbstractClient.java:638)
at org.apache.cxf.jaxrs.client.ClientProxyImpl.handleQueries(ClientProxyImpl.java:432)
at org.apache.cxf.jaxrs.client.ClientProxyImpl.invoke(ClientProxyImpl.java:162)
at org.apache.cxf.common.util.CglibProxyHelper$1.intercept(CglibProxyHelper.java:67)
at com.kilo.SpecialServiceImpl$$EnhancerByCGLIB$$f5c4ae3f.getSomeStringsWithDateInput(<generated>)
at com.kilo.SpecialServiceJaxRSTest.testGetSomeStringsWithDateInput(SpecialServiceJaxRSTest.java:57)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:231)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:88)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71)
at org.junit.runners.ParentRunner.run(ParentRunner.java:292)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:174)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

さらにデバッグすると、ParamConverter viz の代わりに org.apache.cxf.jaxrs.provider.ProviderFactory$LegacyParamConverter を使用しているように見えます。ProgressiveDateHandler。何がうまくいかないのか誰かが指摘してくれたら本当にありがたいです - ほとんどは私が間違って設定したものです。

前もって感謝します!

PS:誰かが実際に動作するのを見たい場合は、テスト用のセットアップがあります。

4

1 に答える 1

1

ここに示されているように、インターフェイスParamConverterを実装することも正しい使用方法のようです。ParamConverterProvider

@SuppressWarnings("unchecked")
@Override
public <T> ParamConverter<T> getConverter(Class<T> rawType,
        Type genericType, Annotation[] annotations) {
    if (rawType == Date.class) {
        return (ParamConverter<T>) this;
    }
    return null;
}

Sergey が jsr-339 メーリング リストで述べたのと同じことを達成するのに役立つ 2 つのインターフェイスの概念に慣れていませんが、仕様に従う必要があります。:)

これでエラーが解消されたようです-これが他の人にも役立つことを願っています. また、間違ったルートを使用している場合は、遠慮なく修正してください。ありがとう!

于 2013-05-02T17:35:50.963 に答える