-2

wso2 esb を使用するための概念実証をまとめようとしています。概念実証は、ESB がフォルダにドロップされた csv ファイルを取得し、詳細を xml に変換し、それらをサード パーティの Web サービスに投稿してから、pdf のバイナリを含むはずの応答をpdf をフォルダにドロップします。

これに関する現在の問題は、wso2 esb 4.5.0 でフォルダーをエンドポイントとして構成すると、そのエンドポイントに送信するすべてのファイルでエラーが発生することです。私の構成の簡素化されたバージョンは以下のように定義されています: -

<proxy name="PDFPoller"
      transports="vfs"
      startOnLoad="true"
      trace="enable"
      statistics="enable">
  <description/>
  <target>
     <inSequence>
        <log level="custom">
           <property name="status" value="PDF Receieved"/>
        </log>
        <log level="full"/>
        <property name="transport.vfs.ReplyFileName"
                  expression="test1.pdf"
                  scope="transport"/>
        <property name="OUT_ONLY" value="true"/>
        <send>
           <endpoint name="FileEpr">
              <address uri="vfs:file:///c:/wso2/processed"/>
           </endpoint>
        </send>
     </inSequence>
  </target>
  <parameter name="transport.vfs.ActionAfterProcess">MOVE</parameter>
  <parameter name="transport.PollInterval">15</parameter>
  <parameter name="transport.vfs.MoveAfterProcess">file:///C:/wso2/output</parameter>
  <parameter name="transport.vfs.FileURI">file:///C:/wso2/PollFolder</parameter>
  <parameter name="transport.vfs.MoveAfterFailure">file:///C:/wso2/Failed</parameter>
  <parameter name="transport.vfs.FileNamePattern">.*.pdf</parameter>
  <parameter name="transport.vfs.ContentType">application/pdf</parameter>
  <parameter name="transport.vfs.ActionAfterFailure">MOVE</parameter>

ESB から取得したエラーは次のとおりです。

2012-10-29 09:46:00,642 [-] [Axis2 Task] ERROR VFSTransportSender IO Error while 
org.apache.commons.vfs2.FileSystemException: Could not write to "file:///c:/wso2/processed".
    at org.apache.commons.vfs2.provider.AbstractFileObject.getOutputStream(AbstractFileObject.java:1440)
    at org.apache.commons.vfs2.provider.DefaultFileContent.getOutputStream(DefaultFileContent.java:462)
    at org.apache.synapse.transport.vfs.VFSTransportSender.populateResponseFile(VFSTransportSender.java:232)
    at org.apache.synapse.transport.vfs.VFSTransportSender.sendMessage(VFSTransportSender.java:173)
    at org.apache.axis2.transport.base.AbstractTransportSender.invoke(AbstractTransportSender.java:112)
    at org.apache.axis2.engine.AxisEngine$TransportNonBlockingInvocationWorker.run(AxisEngine.java:627)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:662)
Caused by: java.io.FileNotFoundException: c:\wso2\processed (Access is denied)
    at java.io.FileOutputStream.open(Native Method)
    at java.io.FileOutputStream.<init>(FileOutputStream.java:194)
    at java.io.FileOutputStream.<init>(FileOutputStream.java:116)
    at org.apache.commons.vfs2.provider.local.LocalFile.doGetOutputStream(LocalFile.java:220)
    at org.apache.commons.vfs2.provider.AbstractFileObject.getOutputStream(AbstractFileObject.java:1432)
    ... 8 more

問題がローカル フォルダーのアクセス許可の問題であるとは思いません。なぜなら、a) フォルダーのアクセス許可を手動で確認し、b) ESB は、'pollfolder' に配置したファイルを 'Output' またはtransport.vfs.MoveAfterProcess プロパティをその値に設定すると「処理済み」になるため、これらの両方のフォルダーに書き込むことができます。

どんな助けでも大歓迎です。

4

1 に答える 1

0

あなたの設定は問題ないようです。しかし、私は次のセクションを疑っています。

<property name="transport.vfs.ReplyFileName"
                  expression="test1.pdf"
                  scope="transport"/>

そのプロパティなしで試すことができます。次に、「処理済み」フォルダー内に入力されたファイル名と同じファイルを作成します。動作する場合は、上記のプロパティを次のように試してください。

<property name="transport.vfs.ReplyFileName"
                  value="test1.pdf"
                  scope="transport"/>

ご覧のとおり、「式」属性を「値」に置き換えました。式は、何かを実行する場合に使用する必要があります。たとえば、2 つの文字列を連結して応答ファイル名を作成する場合などです。

于 2012-10-29T13:47:49.690 に答える