Ich habe WSO2 API Manager auf einem eigenständigen Rechner. Ich habe einen Java-Client (PSVM) mit der notwendigen Client-ID und dem geheimen Passwort der registrierten Anwendung auf APIM. Können wir das Träger-Token nur mit der Client-ID und dem geheimen Schlüssel in Java erhalten?Bearer Token erhalten, nur mit Client ID und Secret. Ist es möglich
Hilfe bitte, bitte.
Ich habe folgenden Code, aber es erfordert Benutzername und Passwort.
öffentlichen Token getToken (String username, String password, String Tive) {
String submitUrl = GenarateAccessTokenConfiguration.getInstance().getLoginURL();
String consumerKey = GenarateAccessTokenConfiguration.getInstance().getConsumerKey();
String consumerSecret = GenarateAccessTokenConfiguration.getInstance().getConsumerSecret();
try {
String applicationToken = consumerKey + ":" + consumerSecret;
BASE64Encoder base64Encoder = new BASE64Encoder();
applicationToken = "Basic " + base64Encoder.encode(applicationToken.getBytes()).trim();
String payload = "grant_type=password&username="+username+"&password="+password+"&scope="+scopes;
HttpResponse httpResponse = httpClient.doPost(submitUrl,applicationToken,
payload,"application/x-www-form-urlencoded");
if (httpResponse.getStatusLine().getStatusCode() != 200) {
return null;
}
String response = httpClient.getResponsePayload(httpResponse);
System.out.println("JSON Response : "+response);
return JSONClient.getAccessToken(response);
} catch (IOException e) {
e.printStackTrace();
return null;
}
}
public Token getTokenWithScopes(String username, String password, String scopes){
String submitUrl = GenarateAccessTokenConfiguration.getInstance().getLoginURL();
String consumerKey = GenarateAccessTokenConfiguration.getInstance().getConsumerKey();
String consumerSecret = GenarateAccessTokenConfiguration.getInstance().getConsumerSecret();
try {
String applicationToken = consumerKey + ":" + consumerSecret;
BASE64Encoder base64Encoder = new BASE64Encoder();
applicationToken = "Basic " + base64Encoder.encode(applicationToken.getBytes()).trim();
String payload = "grant_type=password&username="+username+"&password="+password+"&scope="+scopes;
HttpResponse httpResponse = httpClient.doPost(submitUrl,applicationToken,
payload,"application/x-www-form-urlencoded");
if (httpResponse.getStatusLine().getStatusCode() != 200) {
return null;
}
String response = httpClient.getResponsePayload(httpResponse);
return JSONClient.getAccessToken(response);
} catch (IOException e) {
e.printStackTrace();
return null;
}
}