2016-07-12 3 views
1

以前はアダプタが動作していましたが、アダプタは動作しません。 モバイルFoundation 8.0ベータ版をローカルマシンにインストールし、MobileFirst Foundation 8.0 GAリリースに移行しました。javascript adapterを使用して画像をサーバーに投稿し、xml結果を取得する方法?

の.javaサーバー錬金術に画像を送信し、ちょうどMobileFirstアダプタに錬金術 XML結果を返します。

AndroidとiOSのデバッグ情報が異なるため、両方を一覧表示します。

A)IOSのMobileClient:

iOSの情報は、Androidと異なっています。 XMLアダプタのコルドバのMFP-pluging実装でバグがあるかもしれないようだ:

それはアダプタが応答JSON構造に「responseJSON」を見込んでいるようだので、これは私が何を考えていますデバッグ情報に基づいています。 レスポンスは、xCodeデバッガによって自動的に表示されますが、 "responseJSON"は含まれませんが、錬金術の結果からのすべての有効な値が含まれています。

だけXcodeのデバッグ出力にここを見て:

理由を、それをsames

016-07-14 11:37:54.021 Check[5996:5470887] >>> Image to get Tags formParams : [object Object] 
2016-07-14 11:37:54.021 Check[5996:5470887] >>> Image to get Tags formParams : [object Object] 
2016-07-14 11:37:54.810 Check[5996:5470887] >>> Failure, getTags is : [object Object] 
2016-07-14 11:37:54.810 Check[5996:5470887] >>> Failure, getTags is : {"responseHeaders":{"Connection":"Keep-Alive","Content-Type":"application/json","X-Powered-By":"Servlet/3.1","X-Backside-Transport":"FAIL FAIL","X-Global-Transaction-ID":"610291743","Date":"Thu, 14 Jul 2016 09:37:54 GMT","Transfer-Encoding":"Identity"},"status":500,"responseText":"{\"statusReason\":\"Internal Server Error\",\"responseHeaders\":{\"Transfer-Encoding\":\"chunked\",\"X-Backside-Transport\":\"FAIL FAIL\",\"Connection\":\"Keep-Alive\",\"X-Global-Transaction-ID\":\"78953555\",\"Content-Language\":\"en-US\",\"Date\":\"Thu, 14 Jul 2016 09:37:54 GMT\",\"Content-Type\":\"text/html;charset=UTF-8\",\"X-Powered-By\":\"Servlet/3.1\"},\"isSuccessful\":false,\"responseTime\":164,\"totalTime\":174,\"warnings\":[],\"errors\":[\"org.xml.sax.SAXParseException: The element type \\\"meta\\\" must be terminated by the matching end-tag \\\"</meta>\\\".\",\"Failed to parse the payload from backend (procedure: getTagsForPicture)\"],\"info\":[],\"statusCode\":500}","responseJSON":{"statusReason":"Internal Server Error","responseHeaders":{"Transfer-Encoding":"chunked","X-Backside-Transport":"FAIL FAIL","Connection":"Keep-Alive","X-Global-Transaction-ID":"78953555","Content-Language":"en-US","Date":"Thu, 14 Jul 2016 09:37:54 GMT","Content-Type":"text/html;charset=UTF-8","X-Powered-By":"Servlet/3.1"},"isSuccessful":false,"responseTime":164,"totalTime":174,"warnings":[],"errors":["org.xml.sax.SAXParseException: The element type \"meta\" must be terminated by the matching end-tag \"</meta>\".","Failed to parse the payload from backend (procedure: getTagsForPicture)"],"info":[],"statusCode":500},"errorCode":500,"errorMsg":"Request failed: internal server error (500)","invocationContext":null} 
2016-07-14 11:37:54.814 Check[5996:5470887] ERROR GET TAGS***** [object Object] 
2016-07-14 11:38:09.341 Check[5996:5470887] Response Content : {"statusReason":"OK","responseHeaders":{"Transfer-Encoding":"chunked","X-Backside-Transport":"OK OK","Connection":"Keep-Alive","X-Global-Transaction-ID":"336117367","Content-Language":"en-US","Date":"Thu, 14 Jul 2016 09:38:09 GMT","Content-Type":"text/xml;charset=ISO-8859-1","X-Powered-By":"Servlet/3.1"},"isSuccessful":true,"responseTime":2055,"totalTime":2057,"warnings":[],"results":{"totalTransactions":"4","NOTICE":"THIS API FUNCTIONALITY IS DEPRECATED AND HAS BEEN MIGRATED TO WATSON VISUAL RECOGNITION. THIS API WILL BE DISABLED ON MAY 19, 2017.","usage":"By accessing AlchemyAPI or using information generated by AlchemyAPI, you are agreeing to be bound by the AlchemyAPI Terms of Use: http://www.alchemyapi.com/company/terms.html","imageKeywords":{"keyword":[{"score":"0.574443","text":"large"},{"score":"0.5","text":"building"}]},"url":"","status":"OK"},"errors":[],"info":[],"statusCode":200} 

B)アンドロイドMobileClientを:

を私はエラーときに、次の取得私はコードバモバイルからjavacriptアダプタXMLを実行しますandroidクライアント。

1. Array[2] 
1. 0:"org.xml.sax.SAXParseException: The element type "meta" must be terminated by the matching end-tag "</meta>"." 
2. 1:"Failed to parse the payload from backend (procedure: getTagsForPicture)" 

Androidアプリ用クロームコンソールで完全なエラー情報:

enter image description here

私は、サーバーのログやポスターにXMLを検査するとき、私は表示されません任意の情報。

a)のポスターXML結果:

enter image description here

B)。bluemixのJavaサーバーのログ:

enter image description here

ApdaterとMobileClientの実装:

A)アダプターコード:

function getTagsForPicture(urlimage) { 
var value = "image=" + urlimage; 

var requestStructure = { 
    method : 'post', 
    returnedContentType : 'xml', 
    path : 'GetImageKeywords', 
    parameters: {'image': urlimage }, 
    headers: {"Accept":"application\/plain"} 
}; 
MFP.Logger.warn("Preparing request structure " + JSON.stringify(requestStructure)); 
return MFP.Server.invokeHttp(requestStructure); 
} 

B)コルドバクライアントコード:

var formParams = {"params":"['"+ image + "']"}; 
var getTagsRequest = new WLResourceRequest(
      "/adapters/UploadPic/getTagsForPicture", 
      WLResourceRequest.POST); 
      console.log('>>> Image to get Tags formParams : ', formParams); 

      getTagsRequest.sendFormParameters(formParams); 
      getTagsRequest.send().then(
       getTagsSuccess, 
       getTagsFailure 
     ); 
+1

JSONを使用することをお勧めします。 JSにはより自然なので、メタタグなどについて心配する必要はありません.AlchemyAPIでは、戻り値の型を制御するオプションがあります。 – Ishai

+0

@Ishai私は同意しますが、Bluemixの_.javaサーバー_上のWebsphereのリバティー・プロファイルでサーバー・プログラミングを行っていませんでした。 私はXMLを処理しなければならないと私は言ったように、それは以前働いた。 このXMLがなぜ表示されるのかわかりません。 私は独自のnode.jsサーバーを使用してAlchemy接続を実装しようとしましたが、ここではイメージストリームに問題があり、正しい_binary_形式で変換することができます。 –

+0

@Ishai:ここでnode.jsの投稿に関連する質問を作成します。 http://stackoverflow.com/questions/38325741/how-to-post-a-image-correctly-to-alchemy-node-js-server –

答えて

1

私はこの問題は、クライアントのコードに関連していると思う:

var formParams = {"params":"['"+ image + "']"}; 
var getTagsRequest = new WLResourceRequest(
     "/adapters/UploadPic/getTagsForPicture", 
     WLResourceRequest.POST); 
     console.log('>>> Image to get Tags formParams : ', formParams); 

     getTagsRequest.sendFormParameters(formParams); 
     getTagsRequest.send().then(
      getTagsSuccess, 
      getTagsFailure 
    ); 

getTagsRequest.sendFormParameters(formParams)ので、getTagsRequest.send()と同じですし、と同じです。 Iはコードでこの結果とgetTagsRequest.send()除去:

getTagsRequest.sendFormParameters(formParams); 
    getTagsRequest.send().then(

Iは

sendRequest.sendFormParameters(formParams).send().then(
//sendRequest.send().then(
     sendSuccess, 
     sendFailure 
); 

のコードを変更した後、それが働きました。

@Thanks:フィードバックをしたすべての人に。 @イダン・アダラー特集

関連する問題