0
private void login() {
            androidID = Secure.getString(MainActivity.this.getContentResolver(), Secure.ANDROID_ID);
            String uP = androidID.concat(":ClientTrustedSecret");
            byte[] authByteAry = null;
            try {
                    authByteAry = uP.getBytes("UTF-8");
            } catch (UnsupportedEncodingException e1) {
                    e1.printStackTrace();
            }
            String base64 = Base64.encodeToString(authByteAry, Base64.DEFAULT).trim();
            client.addHeader("Authorization", "Basic ".concat(base64));
            // Following format is required to post to OAuth
            JSONObject jsonObject = new JSONObject();
            try {
                    jsonObject.put("grant_type", "password");
                    jsonObject.put("username", "abc");
                    jsonObject.put("password", "abc");
            } catch (JSONException e1) {
                    e1.printStackTrace();
            }
            String contentType = "application/json; charset=UTF-8";
            StringEntity data = null;
            try {
                    // Send the json to the server
                    data = new StringEntity(jsonObject.toString());
                    client.post(MainActivity.this, baseURL.concat("/tokens"), data, contentType, new AsyncHttpResponseHandler() {
                            @Override
                            public void onSuccess(String response) {
                                    try {
                                            JSONObject jsonObject = new JSONObject(response);
                                            oauthAccessTokenString = jsonObject.get("access_token").toString();
                                    } catch (JSONException e) {
                                            e.printStackTrace();
                                    }
                            }
                            @Override
                            public void onFailure(Throwable t, String err) {
                                    System.out.println("login failed");
                            }
                    });
            } catch (UnsupportedEncodingException e) {
                    e.printStackTrace();
            }
    }

以上がログイン方法です。そして、別のWebサービス呼び出しを行うと、許可されなくなります。ロック解除メソッドには、次のヘッダーが必要です。

http://i.imgur.com/EaWDO.png

private void unlock()
    {
            AsyncHttpClient asyncHttpClient = new AsyncHttpClient();
            asyncHttpClient.addHeader("Locale", "en_US");
            asyncHttpClient.addHeader("X-Originator-Type", "app");
            asyncHttpClient.addHeader("Content-Type", "application/json");
//              asyncHttpClient.addHeader("Connection", "Keep-Alive");
//              asyncHttpClient.addHeader("X-Device-Id", androidID);
//              asyncHttpClient.addHeader("X-via", deviceId);
//              asyncHttpClient.addHeader("ClientID", "abc@abc.com");
            asyncHttpClient.addHeader("Authorization", "Bearer ".concat(oauthAccessTokenString));
            asyncHttpClient.get("host/users?loginName=abc@abc.com", new AsyncHttpResponseHandler() {
                @Override
                public void onSuccess(String response) {
                    System.out.println(response);
                }
                @Override
                    public void onFailure(Throwable t, String err) {
                            System.out.println("Unlock server call failed");
                            Log.d("printing error: ", err);
                    }
            });
    }

上記のコードは401の無許可の例外をスローします。私が持っているドキュメントには、URLをコールバックするための参照はありません。私はoauthアクセストークンを問題なく提供していますが、それでも401を取得するのはなぜですか?その秘密は2回目の電話と関係がありますか?ヘッダーをそのように設定する必要があると言われています。また、「httpsの場合、クライアントは証明書の検証を処理できる必要があります。誰かがそれを解決する方法を知っていますか?

4

1 に答える 1

0

間違ったWebサービスアドレスでした:(証明書の検証を処理する必要はありませんでした。URLのコールバックについては何もありませんでした。秘密は何の関係もありませんでした。しかし、私が持っているドキュメントは、ある場所では非常に不十分に書かれています。彼らはヘッダーだけに言及し、別の場所では本文が必要であると言っています。したがって、ドキュメントを適切に確認するようにしてください。

于 2012-10-30T13:45:05.603 に答える