开发者社区> 问答> 正文

GoogleCloudEndpoints错误原因:IllegalArgumentException

我有一个从我的Android应用程序调用的简单Google Cloud Endpoint。很长时间以来,它一直像魅力一样工作。最近,我更新了项目中的Android Studio,Gradle插件和build.gradle文件。

从那时起,Android应用程序每次尝试调用该端点时都会返回此错误:

Process: com.berylo.chat, PID: 26426
    java.lang.RuntimeException: An error occurred while executing doInBackground()
        at android.os.AsyncTask$3.done(AsyncTask.java:354)
        at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:383)
        at java.util.concurrent.FutureTask.setException(FutureTask.java:252)
        at java.util.concurrent.FutureTask.run(FutureTask.java:271)
        at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:245)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
        at java.lang.Thread.run(Thread.java:764)
     Caused by: java.lang.IllegalArgumentException: 
        at com.google.api.client.json.JsonParser.parseValue(JsonParser.java:889)
        at com.google.api.client.json.JsonParser.parse(JsonParser.java:382)
        at com.google.api.client.json.JsonParser.parse(JsonParser.java:355)
        at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:87)
        at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:81)
        at com.google.api.client.http.HttpResponse.parseAs(HttpResponse.java:459)
        at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:469)
        at com.berylo.chat.Encriptador$3.doInBackground(Encriptador.java:282)
        at com.berylo.chat.Encriptador$3.doInBackground(Encriptador.java:277)
        at android.os.AsyncTask$2.call(AsyncTask.java:333)
        at java.util.concurrent.FutureTask.run(FutureTask.java:266)
        at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:245) 
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167) 
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641) 
        at java.lang.Thread.run(Thread.java:764) 
     Caused by: java.lang.IllegalArgumentException: expected primitive class, but got: class com.crypto.berylo.com.clavePublica4Api.model.RespuestaAlCliente
        at com.google.api.client.util.Data.parsePrimitiveValue(Data.java:453)
        at com.google.api.client.json.JsonParser.parseValue(JsonParser.java:859)
        at com.google.api.client.json.JsonParser.parse(JsonParser.java:382) 
        at com.google.api.client.json.JsonParser.parse(JsonParser.java:355) 
        at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:87) 
        at com.google.api.client.json.JsonObjectParser.parseAndClose(JsonObjectParser.java:81) 
        at com.google.api.client.http.HttpResponse.parseAs(HttpResponse.java:459) 
        at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:469) 
        at com.berylo.chat.Encriptador$3.doInBackground(Encriptador.java:282) 
        at com.berylo.chat.Encriptador$3.doInBackground(Encriptador.java:277) 
        at android.os.AsyncTask$2.call(AsyncTask.java:333) 
        at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
        at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:245) 
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167) 
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641) 
        at java.lang.Thread.run(Thread.java:764)

这是端点代码:

@ApiMethod(name = "obtenerDiasCaducidadClavesDeGrupo",
            path = "grupo",
            httpMethod = ApiMethod.HttpMethod.GET)
    public RespuestaAlCliente obtenerDiasCaducidadClavesDeGrupo(User user)
            throws OAuthRequestException, IOException {
        String dias = "";
        if (user == null)
        {
            throw new OAuthRequestException("Usuario no valido");
        }
        else {
            dias = DIAS_HASTA_CADUCIDAD_DE_CLAVES_DE_GRUPO;
        }
        respuestaalcliente.setMessage(dias);
        logger.info("respuestaalcliente: " + respuestaalcliente);
        return respuestaalcliente;
    }

这是Android应用程序代码。触发错误的行标有THIS ------>

private void obtenernumeroDiasValidezClavesAsimetricas(final Context context){
        try {
            AsyncTask<Void, Void, String> miTareaAsincrona;
            miTareaAsincrona = new AsyncTask<Void, Void, String>() {

                @Override
                protected String doInBackground(Void... params) {
                    try {
THIS ------>            RespuestaAlCliente respuestaAlCliente = MisEndPointsClavePublica.serviceEndPoint.obtenerDiasCaducidadClaveAsimetrica().execute();
                        return respuestaAlCliente.getMessage();
                    } catch (IOException e) {
                        e.printStackTrace();
                        return null;
                    }
                }

                @Override
                protected void onPostExecute(String result) {
                    if((result != null) && (!result.equals("") && (!result.equals("null")))) {
                        numeroDiasValidezClaveAsimetrica = parseInt(result);
                    } else {
                        numeroDiasValidezClaveAsimetrica = 1;
                    }
                    try {
                        generateAsymmetricKeys(context, numeroDiasValidezClaveAsimetrica);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }

            };
            miTareaAsincrona.execute(null, null, null);
        } catch (Exception e){
            e.printStackTrace();
        }
    }

RespuestaAlCliente是包装端点响应的简单类,因为不允许将原语作为端点响应

public class RespuestaAlCliente {

    public String message;

    public RespuestaAlCliente() {}

    public RespuestaAlCliente(String message) {
        this.message = message;
    }

    public String getMessage() {
        return message;
    }

    public void setMessage(String message) {
        this.message = message;
    }
}

我尝试过恢复到以前的Android Studio版本,gradle插件,库,甚至还恢复了一些项目的备份。错误仍然存​​在。

我想念什么,有什么想法吗?提前致谢。

编辑:我忘了提到我在google-api-java-client的github中找到了这个旧问题,并使用了相同的stacktrace。这可能与我的问题有关。https://github.com/googleapis/google-api-java-client/issues/1250

问题来源:Stack Overflow

展开
收起
montos 2020-03-22 16:19:36 1419 0
1 条回答
写回答
取消 提交回答
  • 好吧,可耻的是我,这是我的错:(

    我希望某些人在发布网站之前先查看我的网站,因此我将其在安全性限制下上传到了web.xml文件中,并向这些用户授予了权限。这些限制阻止了Android应用到达后端端点。

    我希望没有人在此浪费时间。不便之处,敬请原谅。

    回答来源:Stack Overflow

    2020-03-22 16:19:59
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载