以前はアダプタが動作していましたが、アダプタは動作しません。 モバイル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アプリ用クロームコンソールで完全なエラー情報:
私は、サーバーのログやポスターにXMLを検査するとき、私は表示されません任意の情報。
a)のポスターXML結果:
B)。bluemixのJavaサーバーのログ:
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
);
JSONを使用することをお勧めします。 JSにはより自然なので、メタタグなどについて心配する必要はありません.AlchemyAPIでは、戻り値の型を制御するオプションがあります。 – Ishai
@Ishai私は同意しますが、Bluemixの_.javaサーバー_上のWebsphereのリバティー・プロファイルでサーバー・プログラミングを行っていませんでした。 私はXMLを処理しなければならないと私は言ったように、それは以前働いた。 このXMLがなぜ表示されるのかわかりません。 私は独自のnode.jsサーバーを使用してAlchemy接続を実装しようとしましたが、ここではイメージストリームに問題があり、正しい_binary_形式で変換することができます。 –
@Ishai:ここでnode.jsの投稿に関連する質問を作成します。 http://stackoverflow.com/questions/38325741/how-to-post-a-image-correctly-to-alchemy-node-js-server –