Ibm mobilefirst 无法初始化MobileFirst V8.0适配器中的AdapterAPI对象,这将导致NullPointerException

Ibm mobilefirst 无法初始化MobileFirst V8.0适配器中的AdapterAPI对象,这将导致NullPointerException,ibm-mobilefirst,mobilefirst-adapters,Ibm Mobilefirst,Mobilefirst Adapters,我正在开发MFP V8中的适配器。下面是我验证用户名和密码的代码: import java.util.HashMap; import java.util.Map; import java.util.logging.Logger; import javax.ws.rs.GET; import javax.ws.rs.Path; import javax.ws.rs.Produces;

我正在开发MFP V8中的适配器。下面是我验证用户名和密码的代码:

        import java.util.HashMap;
        import java.util.Map; 
        import java.util.logging.Logger;

        import javax.ws.rs.GET;
        import javax.ws.rs.Path;
        import javax.ws.rs.Produces;
        import javax.ws.rs.core.Context;
        import javax.ws.rs.core.MediaType;

        import com.ibm.mfp.adapter.api.AdaptersAPI;
        import com.ibm.mfp.adapter.api.ConfigurationAPI;
        import com.ibm.mfp.security.checks.base.UserAuthenticationSecurityCheck;
        import com.ibm.mfp.server.registration.external.model.AuthenticatedUser;

        import io.swagger.annotations.Api;
        import io.swagger.annotations.ApiOperation;
        import io.swagger.annotations.ApiResponse;
        import io.swagger.annotations.ApiResponses;

        @Api(value = "Sample Adapter Resource")
        @Path("/resource")
        public class UserValidationSecurityCheck extends UserAuthenticationSecurityCheck{
            private String displayName;
            private String errorMsg;
            private HashMap<String,Object> adapterReponse = null; 
            @Context
            AdaptersAPI adaptersAPI;

            @Override
            protected AuthenticatedUser createUser() {
                return new AuthenticatedUser(displayName, displayName, this.getName(),adapterReponse);
            }

            @Override
            protected boolean validateCredentials(Map<String, Object> credentials) {
                if(credentials!=null && credentials.containsKey("username") && credentials.containsKey("password")){
                    if (credentials.get("username")!=null && credentials.get("password")!=null) {
                        String username = credentials.get("username").toString();
                        String password = credentials.get("password").toString();
                        if (username.equals(password)) {
                            JSONObject loginParams = new JSONObject();

                            loginParams.put("username", username);
                            loginParams.put("password", password);

                            HttpUriRequest httpUriRequest = adaptersAPI.createJavascriptAdapterRequest("LoginAndWeeklyCertAdapter1", "login", loginParams);
                            try {
                                HttpResponse httpResponse = adaptersAPI.executeAdapterRequest(httpUriRequest);
                                adapterReponse = adaptersAPI.getResponseAsJSON(httpResponse);
                                System.out.println(adapterReponse.toString());
                            } catch (IOException e) {
                                // TODO Auto-generated catch block
                                e.printStackTrace();
                            }
                            return true;
                        } else {
                            errorMsg = "Wrong Credentials";
                        }
                    }
                }
                else{
                    errorMsg = "Credentials not set properly";
                }
                return false;
            }

            public boolean isLoggedIn(){
                return getState().equals(STATE_SUCCESS);
            }

            public AuthenticatedUser getRegisteredUser() {
                return registrationContext.getRegisteredUser();
            }

            @Override
            protected Map<String, Object> createChallenge() {
                Map<String, Object> challenge = new HashMap<String, Object>();
                challenge.put("errorMsg", errorMsg);
                challenge.put("remainingAttempts", getRemainingAttempts());
                return challenge;
            }

        @ApiOperation(value = "Returns 'Hello from resource'", notes = "A basic example of a resource returning a constant string.")
        @ApiResponses(value = { @ApiResponse(code = 200, message = "Hello message returned") })
        @GET
        @Produces(MediaType.TEXT_PLAIN)
        public String getResourceData() {
            // log message to server log
            logger.info("Logging info message...");

            return "Hello from resource";
        }

    }
因为
适配器API
为空。我必须做任何额外的配置才能工作吗?如何初始化
适配器API
对象

注意:登录方法和安全检查都在同一适配器中

更新

我花了更多的时间对其进行了调查,并将代码更新为上面给出的代码,并观察到以下情况:

1。当提交质询响应后调用
validateCredentials()
时,我将在AdapterAPI对象中获得
null


2.其中,当我使用mobilefirst swagger工具调用
getResourceData()
时,我得到了AdapterAPI的对象。

我们
无法将适配器API注入到安全检查对象中
(根据设计-不是错误)。我们唯一能做的就是将适配器中的逻辑提取到Java代码中,而不使用适配器API。

我有一个确切的问题,有什么解决方案吗?请参阅下面的答案。
HttpUriRequest httpUriRequest = adaptersAPI.createJavascriptAdapterRequest("LoginAndWeeklyCertAdapter1", "login");