如何使用带有WSO2 ESB 4.9.0和WSO2-IS 4.5.0的OAuth2保护REST服务

ijnw1ujt  于 2022-09-21  发布在  其他
关注(0)|答案(3)|浏览(199)

我在使用WSO2 IS&WSO2 ESB用OAuth2保护REST Web服务时遇到错误。WSO2 ESB验证令牌时发生异常。它显示异常NoSuchMethodError org.wso2.carbon.identity.oauth2.stub.dto.OAuth2TokenValidationRequestDTO;setTokenType(String)

单击此处显示错误Exception Occured in WSO2 ESB

我还将pom.xml:版本的org.wso2.Carbon.inoty.oauth.stub从4.0.7更改为4.2.2,但仍然不起作用。

SimpleOauthHandler.java通过WSO2-ESB验证令牌

import java.util.Map;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;
import org.apache.axis2.context.ConfigurationContext;
import org.apache.axis2.context.ConfigurationContextFactory;
import org.apache.axis2.transport.http.HTTPConstants;
import org.apache.axis2.transport.http.HttpTransportProperties;
import org.apache.http.HttpHeaders;
import org.apache.synapse.ManagedLifecycle;
import org.apache.synapse.MessageContext;
import org.apache.synapse.core.SynapseEnvironment;
import org.apache.synapse.core.axis2.Axis2MessageContext;
import org.apache.synapse.rest.AbstractHandler;
import    
org.wso2.carbon.identity.oauth2.stub.OAuth2TokenValidationServiceStub;
import  
org.wso2.carbon.identity.oauth2.stub.dto.OAuth2TokenValidationRequestDTO;

public class SimpleOauthHandler extends AbstractHandler implements ManagedLifecycle {

private String securityHeader = HttpHeaders.AUTHORIZATION;
private String consumerKeyHeaderSegment = "Bearer";
private String oauthHeaderSplitter = ",";
private String consumerKeySegmentDelimiter = " ";
private String oauth2TokenValidationService = "oauth2TokenValidationService";
private String identityServerUserName = "identityServerUserName";
private String identityServerPw = "identityServerPw";

public boolean handleRequest(MessageContext messageContext) {
    try{
        ConfigurationContext configCtx = ConfigurationContextFactory.createConfigurationContextFromFileSystem(null, null);
        //Read parameters from axis2.xml
        String identityServerUrl = messageContext.getConfiguration().getAxisConfiguration().getParameter(oauth2TokenValidationService).getValue().toString();
        String username = messageContext.getConfiguration().getAxisConfiguration().getParameter(identityServerUserName).getValue().toString();
        String password = messageContext.getConfiguration().getAxisConfiguration().getParameter(identityServerPw).getValue().toString();

        OAuth2TokenValidationServiceStub stub = new OAuth2TokenValidationServiceStub(configCtx,identityServerUrl);
        ServiceClient client = stub._getServiceClient();
        Options options = client.getOptions();
        HttpTransportProperties.Authenticator authenticator = new HttpTransportProperties.Authenticator();
        authenticator.setUsername(username);
        authenticator.setPassword(password);
        authenticator.setPreemptiveAuthentication(true);

        options.setProperty(HTTPConstants.AUTHENTICATE, authenticator);
        client.setOptions(options);
        OAuth2TokenValidationRequestDTO dto = new OAuth2TokenValidationRequestDTO();
        dto.setTokenType("bearer");
        Map headers = (Map) ((Axis2MessageContext) messageContext).getAxis2MessageContext().
                getProperty(org.apache.axis2.context.MessageContext.TRANSPORT_HEADERS);
        String apiKey = null;
        if (headers != null) {
            apiKey = extractCustomerKeyFromAuthHeader(headers);
        }
        dto.setAccessToken(apiKey);
        //validate passed apiKey(token)
        if(stub.validate(dto).getValid()){
            return true;
        }else{
            return false;
        }
    }catch(Exception e){
        e.printStackTrace();
        return false;
    }
}

public String extractCustomerKeyFromAuthHeader(Map headersMap) {

    //From 1.0.7 version of this component onwards remove the OAuth authorization header from
    // the message is configurable. So we dont need to remove headers at this point.
    String authHeader = (String) headersMap.get(securityHeader);
    if (authHeader == null) {
        return null;
    }

    if (authHeader.startsWith("OAuth ") || authHeader.startsWith("oauth ")) {
        authHeader = authHeader.substring(authHeader.indexOf("o"));
    }

    String[] headers = authHeader.split(oauthHeaderSplitter);
    if (headers != null) {
        for (int i = 0; i < headers.length; i++) {
            String[] elements = headers[i].split(consumerKeySegmentDelimiter);
            if (elements != null && elements.length > 1) {
                int j = 0;
                boolean isConsumerKeyHeaderAvailable = false;
                for (String element : elements) {
                    if (!"".equals(element.trim())) {
                        if (consumerKeyHeaderSegment.equals(elements[j].trim())) {
                            isConsumerKeyHeaderAvailable = true;
                        } else if (isConsumerKeyHeaderAvailable) {
                            return removeLeadingAndTrailing(elements[j].trim());
                        }
                    }
                    j++;
                }
            }
        }
    }
    return null;
}

private String removeLeadingAndTrailing(String base) {
    String result = base;

    if (base.startsWith(""") || base.endsWith(""")) {
        result = base.replace(""", "");
    }
    return result.trim();
}

public boolean handleResponse(MessageContext messageContext) {
  return true;
}

public void init(SynapseEnvironment synapseEnvironment) {
    //To change body of implemented methods use File | Settings | File Templates.
}

public void destroy() {
    //To change body of implemented methods use File | Settings | File Templates.
}

}

WSO2-ESB服务器中出现异常:NoSuchMethodError:setTokenType(字符串)]Exception Screen Shot

Maven pom.xml此处

<project xmlns="http://maven.apache.org/POM/4.0.0"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0     
 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 <modelVersion>4.0.0</modelVersion>

<groupId>handler</groupId>
<artifactId>handler</artifactId>
<version>1.0</version>
<repositories>
<repository>
<id>wso2-nexus</id>
<name>WSO2 internal Repository</name>
<url>http://maven.wso2.org/nexus/content/groups/wso2-public/</url>
<releases>
<enabled>true</enabled>
<updatePolicy>daily</updatePolicy>
<checksumPolicy>ignore</checksumPolicy>
</releases>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>org.apache.synapse</groupId>
<artifactId>synapse-core</artifactId>
<version>2.1.1-wso2v1</version>
</dependency>
<dependency>
   <groupId>org.apache.axis2.wso2</groupId>
   <artifactId>axis2</artifactId>
   <version>1.6.1.wso2v7</version>
</dependency>
<dependency>
   <groupId>org.wso2.carbon</groupId>
   <artifactId>org.wso2.carbon.identity.oauth.stub</artifactId>
   <version>4.0.7</version>
</dependency>
</dependencies>
</project>
nxagd54h

nxagd54h1#

正如您在this class中看到的,OAuth2TokenValidationRequestDTO没有方法setTokenType。但它是内部类OAuth2AccessToken拥有的。

nfg76nw0

nfg76nw02#

谢谢Bhathiya

我找到了正确的代码。

OAuth2TokenValidationRequestDTO oauthReq = new    
                                   OAuth2TokenValidationRequestDTO();
 OAuth2TokenValidationRequestDTO_OAuth2AccessToken accessToken= new 
                     OAuth2TokenValidationRequestDTO_OAuth2AccessToken();
 accessToken.setTokenType(BEARER_TOKEN_TYPE);
 accessToken.setIdentifier(apiKey);
 oauthReq.setAccessToken(accessToken);
 try {
            return stub.validate(oauthReq).getValid();
     } 
 catch (RemoteException e) {
            throw new Exception("Error while validating OAuth2 request", e);
     }

现在它在运行..。再次感谢Bhathiya

t3psigkw

t3psigkw3#

有没有办法通过调用REST API而不是存根来执行此检查?类似于下面的说明:https://docs.wso2.com/display/IS570/Invoke+the+OAuth+Introspection+Endpoint

相关问题