Опубликовать сообщение в LinkedIn, когда Scribe не работает на Android

Ниже приведен код для отправки почтового сообщения. На моем экране у меня есть раздел EditText, позволяющий пользователю вводить текст, и когда они нажимают сообщение, вызывается функция sendMessage. Я продолжаю получать это в ответ. Я также пробовал URLEncode.encode(полезная нагрузка, «UTF-8»), чтобы получить закодированную строку для добавления в тело, но это не сработало. Любое понимание будет полезно.

04-19 18:24:50.570: D/response(693): <error>
04-19 18:24:50.570: D/response(693):   <status>400</status>
04-19 18:24:50.570: D/response(693):   <timestamp>1334859891007</timestamp>
04-19 18:24:50.570: D/response(693):   <request-id>WJPI8VXQME</request-id>
04-19 18:24:50.570: D/response(693):   <error-code>0</error-code>
04-19 18:24:50.570: D/response(693):   <message>Couldn't parse share document: error: Unexpected end of file after null</message>
04-19 18:24:50.570: D/response(693): </error>

Вот код:

private static final String SendMessage = "https://api.linkedin.com/v1/people/~/shares";

public void sendMessage(View view)
{
    //Get works just fine
    //OAuthRequest req = new OAuthRequest(Verb.GET, "http://api.linkedin.com/v1/people/~/connections:(id,last-name)");
    //service.signRequest(accessToken, req);
    //Response res = req.send();
    //Log.e("get", res.getBody());

    OAuthRequest post = new OAuthRequest(Verb.POST, SendMessage);

    //Have also  tried adding <?xml version=\"1.0\" encoding=\"UTF-8\"?>" to the beginning of the payload string        
    String payload = "<share>" +
                        "<comment>testing</comment>" +
                        "<visibility><code>anyone</code></visibility>" +
                     "</share>";

    post.addBodyParameter("body", payload);
    post.addHeader("Content-Type", "text/xml;charset=UTF-8");

    service.signRequest(accessToken, post);
    try
    {
        Response response = post.send();
        Log.d("response",response.getBody());
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }
    LinkedInActivity.this.finish();
}

и моя служба определяется как:

service = new ServiceBuilder()
                .provider(LinkedInApi.class)
                .apiKey(API_KEY)
                .apiSecret(API_SEC)
                .callback(CALLBACK)
                .debug()
                .build();

final Token requestToken = service.getRequestToken();
final String authURL = service.getAuthorizationUrl(requestToken);

Я использую веб-просмотр, чтобы поймать обратный вызов, чтобы сохранить верификатор/токен. Пример ниже:

webView.setWebViewClient(new WebViewClient()
    {
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {

            if(url.startsWith("oauth")){
                webView.setVisibility(View.GONE);

                Uri uri = Uri.parse(url);
                String verifier = uri.getQueryParameter("oauth_verifier");
                Verifier v = new Verifier(verifier);

                //save token
                accessToken = service.getAccessToken(requestToken, v);

                if(uri.getHost().equals("linkedIn")){
                    editText.setText(appState.socialMediaMessage);
                    //place the cursor at the end of the predefined text
                    editText.setSelection(editText.getText().length());

                    textLimit = textLimit - editText.length();
                    textView.setText(String.valueOf(textLimit));

                }

                return true;
            }

            return super.shouldOverrideUrlLoading(view, url);
        }
    });

    //send user to authorization page
    webView.loadUrl(authURL);

person Damien Mosier    schedule 20.04.2012    source источник


Ответы (1)


использовать:

post.addPayload(payload);

вместо:

post.addBodyParameter("body", payload);
person Pablo Fernandez    schedule 21.04.2012