0

こんにちは、私はscribe-javaライブラリを使用して、http.code を介して REST API にアクセスしようとしています。

package org.scribe.examples;
import java.util.*;
import org.scribe.builder.*;
import org.scribe.builder.api.*;
import org.scribe.model.*;
import org.scribe.oauth.*;
public class WooCommerceOauth1Example {

private static final String RESOURCE_URL = "http://WEBSITE.COM/wc-api/v1/orders";

public static void main(String[] args) {
    OAuthService service = new ServiceBuilder().provider(OneLeggedApi10.class)
            .apiKey("ck_SOME_NUMBER")
            .apiSecret("cs_SOME_NUMBER")
            .build();


    // Now let's go and ask for a protected resource!
    System.out.println("Now we're going to access a protected resource...");
    OAuthRequest request = new OAuthRequest(Verb.GET, RESOURCE_URL);
    //Since it is a one legged protocol, access token is empty.Right?      
    service.signRequest(new Token("", ""), request);

    Response response = request.send();
    System.out.println("Got it! Lets see what we found...");
    System.out.println();
    System.out.println(response.getCode());
    System.out.println(response.getBody());

    System.out.println();
    System.out.println("Thats it man! Go and build something awesome   with Scribe! :)");

   }
}

次のエラー {"errors":[{"code":"woocommerce_api_authentication_error","message":"oauth_consumer_key parameter is missing"}]} をスローします。私のコードが上記のエラーをスローしている理由はありますか? http で v1 エンドポイントを確認したところ、適切なメッセージが返されることに注意してください。したがって、基本的には機能しています。

4

1 に答える 1

2

https://github.com/fernandezpablo85/scribe-java/blob/master/src/main/java/org/scribe/services/HMACSha1SignatureService.java#L32から '&' + OAuthEncoder.encode(tokenSecret) を削除し、署名タイプを QueryString に変更し、現在は機能しています。

クリーニング後にPRを提案します.Thank Pablo. 以下は完全なコードです

package org.scribe.builder.api;

import org.scribe.model.Token;
import org.scribe.model.Verb;

public class OneLeggedApi10 extends DefaultApi10a {

@Override
public String getAccessTokenEndpoint() {
    return null;
}

@Override
public String getRequestTokenEndpoint() {
    return null;
}

@Override
public String getAuthorizationUrl(Token requestToken) {
    return null;
}

@Override
public Verb getAccessTokenVerb() {
    return Verb.GET;
}

@Override
public Verb getRequestTokenVerb() {
    return Verb.GET;
}

}

そしてサンプルクラス

package org.scribe.examples;


import org.scribe.builder.*;
import org.scribe.builder.api.*;
import org.scribe.model.*;
import org.scribe.oauth.*;

 public class WooCommerceOauth1Example {

private static final String NETWORK_NAME = "Woocommerce";
private static final String RESOURCE_URL = "http://YOUR_DOMAIN/wc-api/v1/orders/count";
private static final String SCOPE = "*"; //all permissions

public static void main(String[] args) {
    OAuthService service = new ServiceBuilder().provider(OneLeggedApi10.class)
            .apiKey("API_KEY")                
            .apiSecret("SECRET_KEY") 
            .debugStream(System.out)
            .signatureType(SignatureType.QueryString)
            /*.scope(SCOPE).*/
            .build();

    System.out.println("=== " + NETWORK_NAME + "'s OAuth Workflow ===");
    System.out.println();

    // Now let's go and ask for a protected resource!
    System.out.println("Now we're going to access a protected         resource...");
    OAuthRequest request = new OAuthRequest(Verb.GET, RESOURCE_URL);

    service.signRequest(new Token("", ""), request);
    Response response = request.send();
    System.out.println("Got it! Lets see what we found...");
    System.out.println();
    System.out.println(response.getCode());
    System.out.println(response.getBody());

    System.out.println();
    System.out.println("Thats it man! Go and build something awesome with Scribe! :)");

}

}

于 2015-08-10T14:47:32.977 に答える