这是我获取oauth令牌并为vimeo授权我的应用程序的代码。这很好用:
WebView webview = new WebView(this);
webview.getSettings().setJavaScriptEnabled(true);
webview.setVisibility(View.VISIBLE);
setContentView(webview);
Log.i(TAG, "Retrieving request token from Vimeo servers");
try {
final OAuthHmacSigner signer = new OAuthHmacSigner();
signer.clientSharedSecret = Constants.CONSUMER_SECRET_VIMEO;
OAuthGetTemporaryToken temporaryToken = new OAuthGetTemporaryToken(Constants.REQUEST_URL_VIMEO);
temporaryToken.transport = new ApacheHttpTransport();
temporaryToken.signer = signer;
temporaryToken.consumerKey = Constants.CONSUMER_KEY_VIMEO;
temporaryToken.callback = Constants.OAUTH_CALLBACK_URL;
OAuthCredentialsResponse tempCredentials = temporaryToken.execute();
signer.tokenSharedSecret = tempCredentials.tokenSecret;
OAuthAuthorizeTemporaryTokenUrl authorizeUrl = new OAuthAuthorizeTemporaryTokenUrl(Constants.AUTHORIZE_URL_VIMEO);
authorizeUrl.temporaryToken = tempCredentials.token;
String authorizationUrl = authorizeUrl.build();
Log.d("urlop", authorizationUrl);
/* WebViewClient must be set BEFORE calling loadUrl! */
webview.setWebViewClient(new WebViewClient() {
@Override
public void onPageStarted(WebView view, String url,Bitmap bitmap) {
System.out.println("onPageStarted : " + url);
}
@Override
public void onPageFinished(WebView view, String url)
{
Log.d("url", url);
if (url.startsWith(Constants.OAUTH_CALLBACK_URL)) {
try {
if (url.indexOf("oauth_token=")!=-1) {
String requestToken = extractParamFromUrl(url,"oauth_token");
String verifier= extractParamFromUrl(url,"oauth_verifier");
signer.clientSharedSecret = Constants.CONSUMER_SECRET;
OAuthGetAccessToken accessToken = new OAuthGetAccessToken(Constants.ACCESS_URL);
accessToken.transport = new ApacheHttpTransport();
Log.d("abc", "");
accessToken.temporaryToken = requestToken;
Log.d("abc", accessToken.temporaryToken);
accessToken.signer = signer;
accessToken.consumerKey = Constants.CONSUMER_KEY;
accessToken.verifier = verifier;
Log.d("abc", accessToken.verifier);
OAuthCredentialsResponse credentials = accessToken.execute();
signer.tokenSharedSecret = credentials.tokenSecret;
Log.d("abc", signer.tokenSharedSecret);
CredentialStore credentialStore = new SharedPreferencesCredentialStore(prefs);
credentialStore.write(new String[] {credentials.token,credentials.tokenSecret});
view.setVisibility(View.INVISIBLE);
performApiCall();
// startActivity(new Intent(OAuthAccessTokenActivityVimeo.this,Vimeo.class));
}
else if (url.indexOf("error=")!=-1)
{
view.setVisibility(View.INVISIBLE);
new SharedPreferencesCredentialStore(prefs).clearCredentials();
startActivity(new Intent(OAuthAccessTokenActivityVimeo.this,MainMenu.class));
}
} catch (IOException e) {
e.printStackTrace();
}
}
System.out.println("onPageFinished : " + url);
}
private String extractParamFromUrl(String url,String paramName)
{
String queryString = url.substring(url.indexOf("?", 0)+1,url.length());
QueryStringParser queryStringParser = new QueryStringParser(queryString);
return queryStringParser.getQueryParamValue(paramName);
}
});
webview.loadUrl(authorizationUrl);
} catch (Exception ex) {
ex.printStackTrace();
}
}
但是,在performApiCall()
我需要这样做:
String url = String.format("http://vimeo.com/api/rest/v2&format=json&full_response=1&method=vimeo.videos.search&oauth_consumer_key=%s&oauth_nonce=fb86e833df995307290763917343ae19&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1350908218&oauth_version=1.0&per_page=20&query=umar&sort=newest&summary_response=1",
Constants.CONSUMER_KEY
);
如何获得oauth_nonce
,oauth_timestamp
和oauth_signature
?
答案 0 :(得分:2)
1)重新oauth_timestamp
:AFAIK,您自己设置时间戳到当前时间戳。如果遇到问题(vimeo期望时间戳在它认为是当前时间戳之前或之后的几秒钟内没有差异,参见the vimeo forum thread here),请尝试摆弄您使用的系统时间(例如,服务器)时间)。
2)重新oauth_nonce
:nonce值是“随机字符串,由客户端唯一生成,以允许服务器验证之前从未做过请求”({ {3}})。
3)重新oath_signature
:客户端生成自己的签名。来自The OAuth 1.0 Protocol:
客户端声明通过使用哪种签名方法 “oauth_signature_method”参数。然后它生成一个签名(或 一个等价值的字符串)并将其包含在 “oauth_signature”参数。服务器将签名验证为 为每种方法指定。
简而言之:您不会从某个地方“获取”这些值,您必须创建它们。
我真的很想再次推荐你The OAuth 1.0 Protocol,它很容易阅读,并且可以让你对你可能拥有的大多数查询进行排序:)。
希望这有帮助。
答案 1 :(得分:0)
来自http://developer.vimeo.com/apis/advanced
如果您对OAuth完全不熟悉,我们建议您阅读 在继续之前hueniverse’s OAuth 1.0 Guide。 OAuth是 很复杂,他在解释这个过程方面做得很好。 Twitter’s guide也非常好。
另请注意以下资源(可能对您有所帮助)