从android中的API检索数据到ListView

如何解决从android中的API检索数据到ListView

我需要从此链接 http://www.autotrack.rs/android_juzna_backa/get_voznja.php? 检索数据到列表视图。我需要使用 value-POST 方法发送密钥,以获得如下内容:http://www.autotrack.rs/android_juzna_backa/get_voznja.php?voznja_id=42。我的代码如下:谢谢。类型 org.json.JSONObject$1 的数据中的错误值 null 无法转换为 JSONArray

 public class fetchData extends AsyncTask<String,String,String> {

        @Override
        public void onPreExecute() {
            super.onPreExecute();
            swipeRefresh.setRefreshing(true);
        }

        @Override
        protected String doInBackground(String... params) {
            arrayList.clear();
            String result = null;
            try {
                OkHttpClient client = new OkHttpClient().newBuilder()
                        .build();
                MediaType mediaType = MediaType.parse("text/plain");
                RequestBody body = new MultipartBody.Builder().setType(MultipartBody.FORM)
                        .addFormDataPart("voznja_id","42")
                        .build();
                Request request = new Request.Builder()
                        .url("http://www.autotrack.rs/android_juzna_backa/get_voznja.php")
                        .method("POST",body)
                        .build();
                try {
                    response = client.newCall(request).execute();
//                System.out.println(response.body().string());
                } catch (IOException e) {
                    e.printStackTrace();
                }
                return "";


            } catch (Exception e) {
                e.printStackTrace();
            }
            return result;
        }

        @Override
        public void onPostExecute(String rezultat) {

            try {
                rezultat = response.body().string();
            }catch (Exception m)
            {
                m.printStackTrace();
            }
                Intent intent;
                Gson gson = new Gson();
                Type type = new TypeToken<Voznja>() {
                }.getType();

                Voznja voznja = gson.fromJson(rezultat,type);

                Intent im = new Intent(getApplicationContext(),Unos.class);
                im.putExtra("voznja",voznja);
               // startActivity(im);
             swipeRefresh.setRefreshing(false);
                try {
                    JSONObject object = new JSONObject(rezultat);
                   JSONArray array = object.getJSONArray("data");

                    for (int i = 0; i < array.length(); i++) {

                        JSONObject jsonObject = array.getJSONObject(i);
                        String id = jsonObject.getString("id");
                        String vozilo_id = jsonObject.getString("vozilo_id");
                        String vozac_id = jsonObject.getString("vozac_id");
                        String pocetna_kilometraza = jsonObject.getString("pocetna_kilometraza");
                        String pocetno_vreme = jsonObject.getString("pocetno_vreme");
                        String razlog = jsonObject.getString("razlog");
                        String zavrsna_kilometraza = jsonObject.getString("zavrsna_kilometraza");
                        String zavrsno_vreme = jsonObject.getString("zavrsno_vreme");
                        String moto_sati = jsonObject.getString("moto_sati");
                        String id_projekat_jb = jsonObject.getString("id_projekat_jb");

                        ItemModel model = new ItemModel();
                        model.setVoznja_id(id);
                        model.setVoziloId(vozilo_id);
                        model.setVozac_id(vozac_id);
                        model.setPocetnaKilometraza(pocetna_kilometraza);
                        model.setPocetnoVreme(pocetno_vreme);
                        model.setRazlog(razlog);
                        model.setZavrsnaKilometraza(zavrsna_kilometraza);
                        model.setZavrsnoVreme(zavrsno_vreme);
                        model.setMotoSati(moto_sati);
                        model.setProjekatId(id_projekat_jb);
                        arrayList.add(model);
                    }
                } catch (JSONException e) {
                    e.printStackTrace();
                }

                VoznjaAdapter adapter = new VoznjaAdapter(ListaVoznji.this,arrayList);
                listView.setAdapter(adapter);

解决方法

您的 api 响应是 JSONObject。

{"data":{"id":"42","vozilo_id":"777777003561","vozac_id":"2","pocetna_kilometraza":"50000","pocetno_vreme":"2020-12-25 07:15:00","projekat":null,"razlog":"Sastanak","zavrsna_kilometraza":"50150","zavrsno_vreme":"2020-12-25 10:45:00","moto_sati":"3","insert_time":"2021-01-08 10:47:33.683885","id_projekat_jb":"330"}}

所以你应该使用 JSONObject 而不是 JSONArray

            try {
                JSONObject object = new JSONObject(rezultat);
               JSONObject jsonObject = object.getJSONObject("data");

                    String id = jsonObject.getString("id");
                    String vozilo_id = jsonObject.getString("vozilo_id");
                    String vozac_id = jsonObject.getString("vozac_id");
                    String pocetna_kilometraza = jsonObject.getString("pocetna_kilometraza");
                    String pocetno_vreme = jsonObject.getString("pocetno_vreme");
                    String razlog = jsonObject.getString("razlog");
                    String zavrsna_kilometraza = jsonObject.getString("zavrsna_kilometraza");
                    String zavrsno_vreme = jsonObject.getString("zavrsno_vreme");
                    String moto_sati = jsonObject.getString("moto_sati");
                    String id_projekat_jb = jsonObject.getString("id_projekat_jb");

                    ItemModel model = new ItemModel();
                    model.setVoznja_id(id);
                    model.setVoziloId(vozilo_id);
                    model.setVozac_id(vozac_id);
                    model.setPocetnaKilometraza(pocetna_kilometraza);
                    model.setPocetnoVreme(pocetno_vreme);
                    model.setRazlog(razlog);
                    model.setZavrsnaKilometraza(zavrsna_kilometraza);
                    model.setZavrsnoVreme(zavrsno_vreme);
                    model.setMotoSati(moto_sati);
                    model.setProjekatId(id_projekat_jb);
                    arrayList.add(model);
            } catch (JSONException e) {
                e.printStackTrace();
            }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-