当前位置: 首页 > 知识库问答 >
问题:

试图让Android annotations spring REST客户端api工作,有几个问题

高运诚
2023-03-14

我似乎不知道如何让android注释rest客户端工作,我有两个主要问题。

A)如何解析通用json响应并获取有意义的密钥

B)如何增加参数

对于第一个问题,所有响应都返回为一个json字符串,如下所示

{"success":,"message":"","data":{}}

成功的地方是boolean消息是一个字符串,而data将是我想要解析的主要数据,它可能是一个boolean、一个数组、一个字符串或一个int

我很确定我需要截取响应并处理代码,但我不确定如何做到这一点

让我们使用如下所示的真实响应

{"success":true,"message":"random message","data":{"profile":{"id":"44","user_id":"44","name":"Matt","username":"mitch","icon":"b1da7ae15027b7d6421c158d644f3220.png","med":"2a3df53fb39d1d8b5edbd0b93688fe4a.png","map":"b7bfed1f456ca4bc8ca748ba34ceeb47.png","background":null,"mobile_background":null}}

首先,在我的拦截器中,我想看看布尔键“success”是否为true,然后返回数据值

@EBean
public class RestInterceptor implements ClientHttpRequestInterceptor {

    final String TAG = "rest";

    @Bean
    AuthStore authStore;

    @Override
    public ClientHttpResponse intercept(HttpRequest request, byte[] data, ClientHttpRequestExecution execution)
            throws IOException{

        //Need to set the api key here but nothing happens code quits
//        Log.d("Rest",authStore.getApiKey());

         HttpHeaders headers = request.getHeaders();

         headers.set("api_key","");

         ClientHttpResponse resp = execution.execute(request, data);

         HttpStatus code = resp.getStatusCode();


         if(code.value() == 200){
            Log.d(TAG,"success code 200"); 

            //valid http request but is it a valid API request?
                //perform some logic of if success == true in root json object
                //if true cast return data key 



         }
         else{
             Log.d(TAG,"fail code" + code.toString());
         }


         return resp;
    }

}

第二个问题是发送带有api密钥和会话密钥的http请求的参数,我这样定义application类

@EApplication
public class MyApp extends Application {

    final String TAG = "app";

    @Bean
    AuthStore authStore;

    @RestService
    RestClient restClient;


    public void onCreate() {
        super.onCreate();
        init();
    }

    @AfterInject
    public void init() {

        authStore.setApiKey("dummy_key");
        Log.d(TAG, "api key set to " + authStore.getApiKey());

    }
}

使用如下所示的AuthStore类

@EBean(scope = Scope.Singleton)
public class AuthStore {

    public String apiKey,sessionKey;

    public String getApiKey() {
        return apiKey;
    }

    public void setApiKey(String apiKey) {
        this.apiKey = apiKey;
    }

    public String getSessionKey() {
        return sessionKey;
    }

    public void setSessionKey(String sessionKey) {
        this.sessionKey = sessionKey;
    }
}

基本上,我在一个单例中在应用程序级别设置了一个虚拟api键,我应该能够在rest拦截器接口中访问它,但是代码没有错误地退出。我基本上遵循了本指南https://github.com/excilys/androidannotations/wiki/authenticated-rest-client

最后,我有一个activity类,它注入了应用程序依赖关系,它引用了rest http类和authstore类

@EActivity(R.layout.activity_login)
public class LoginActivity extends Activity {

    @App
    MyApp app;
    @ViewById
    TextView email;
    @ViewById
    TextView password;
    @ViewById
    Button loginButton;


    @AfterInject
    public void init() {
        Log.d(app.TAG, "api in login key set to " + app.authStore.getApiKey());

    }

    @Click
    @Trace
    void loginButton() {

        login(email.toString(), password.toString());

    }

    @Background
    void login(String email, String password) {
         app.restClient.forceLogin();


    }
}

对不起,如果这是一个很多的信息,我已经搜索了一段时间,不能弄清楚这一点!

提前致谢

共有2个答案

董光霁
2023-03-14

这是我用来递归解析任何JSON对象的方法。

private void parseJson(JSONObject data) {

        if (data != null) {
            Iterator<String> it = data.keys();
            while (it.hasNext()) {
                String key = it.next();

                try {
                    if (data.get(key) instanceof JSONArray) {
                        JSONArray arry = data.getJSONArray(key);
                        int size = arry.length();
                        for (int i = 0; i < size; i++) {
                            parseJson(arry.getJSONObject(i));
                        }
                    } else if (data.get(key) instanceof JSONObject) {
                        parseJson(data.getJSONObject(key));
                    } else {
                        System.out.println("" + key + " : " + data.optString(key));
                    }
                } catch (Throwable e) {
                    System.out.println("" + key + " : " + data.optString(key));
                    e.printStackTrace();

                }
            }
        }
    }
梁丘赞
2023-03-14

我不了解您使用的库(注释,spring),但在我看来,您似乎正在为解析success=true而苦苦挣扎,因为JSON中不应该有这个库。

JSON最好表示应用程序1on1中的类,这样您就可以轻松地将其映射到一个对象中。应用程序和webservice之间关于请求状态的通信应该进入报头。

像这样,您可以在解析JSON之前检查请求的头。

 类似资料:
  • 我使用的是kafka-clients-0.10.1.1(单节点单代理) auto.create.topics.enable的默认值为true。 1.我正在使用以下方式向主题发送消息: 用于消费:

  • 1、MVC、MVP、MVVM的区别 MVC 模式将程序分为三个部分:模型 、视图(xml文件)、控制器(activity)。目的:将业务逻辑放在控制器里,把业务逻辑和视图层分离;缺点:Activity变得臃肿,Model 将新的数据发送到 View。 MVP 模式将程序分为三个部分:模型、视图(activity)、管理层(Presenter)。MVC模式的View 层和 Model 层存在耦合,M

  • 我有一个wsdl: 我想提交信息以获得回应。我创建了client.php如下: 但它在浏览器中显示错误: SoapFault对象([消息:受保护]= 我错在哪里?对此,可能的解决方案是什么? 编辑: 我已经创建了一个php文件:client。php 但它产生了这个错误: 调用错误:响应不是文本/xml类型:应用程序/wsdl xmlHTTP/1.1 200确定日期:星期二,9月17日2013 15

  • 我目前正在努力让远程EJB调用在wildfly(8.x和9.x)上工作。 详细来说,它是关于使用EJB客户机API方法从独立的客户机应用程序(而不是从另一个应用程序服务器)进行远程调用。远程命名方法适合我,但不适用于我的场景,因为我需要使用客户端拦截器将上下文数据传递给服务器端拦截器进行远程调用。 但是现在,为了一个简单的示例,我尝试使用客户机API进行远程调用。因此,我尝试了用于远程ejb调用的

  • 在Github和在线上,我看到了多个版本的Feign客户端Spring-Cloud、OpenFeign、Netflix.Feign都有不同的版本。谁能描述一下在生产中应该使用的最好的和稳定的假客户是什么? 应用: 我尝试了所有可能的注释排列,认为它可以解决自动操作的东西,但还是失败了

  • 我正试图通过hbc-twitter4j-v3获得推文。示例代码为:https://github.com/twitter/hbc/blob/master/hbc-example/src/main/java/com/twitter/hbc/example/Twitter4jSampleStreamExample.java为了在代理上启用身份验证,我还设置了主机、端口和身份验证的系统属性。但它显示出以下