- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图从数据库中获取信息并将其写入 TextView 以在输入订单名称后显示数据库中的信息
package com.example.mauricio.pairlines;
import android.content.Intent;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.toolbox.Volley;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
public class Seeorder extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_seeorder);
final EditText etOrdernum = (EditText) findViewById(R.id.etOrdernum);
final TextView tvPilotname = (TextView) findViewById(R.id.tvPilotname);
final TextView tvPilotcash = (TextView) findViewById(R.id.tvPilotcash);
final TextView tvDate = (TextView) findViewById(R.id.tvDate);
final TextView tvPlanemodel = (TextView) findViewById(R.id.tvPlanemodel);
final TextView tvHoobsstart = (TextView) findViewById(R.id.tvHoobsstart);
final TextView tvHoobsend = (TextView) findViewById(R.id.tvHoobsend);
final TextView tvWatchtime = (TextView) findViewById(R.id.tvWatchtime);
final TextView tvHoobstime = (TextView) findViewById(R.id.tvHoobstime);
final TextView tvGas = (TextView) findViewById(R.id.tvGas);
final TextView tvLiter = (TextView) findViewById(R.id.etLiter);
final TextView tvRepairname = (TextView) findViewById(R.id.tvRepairname);
final TextView tvRepaircost = (TextView) findViewById(R.id.tvRepaircost);
final TextView tvTravelexpense = (TextView) findViewById(R.id.tvTravelexpense);
final TextView tvOthername1 = (TextView) findViewById(R.id.tvOthername1);
final TextView tvOthercost1 = (TextView) findViewById(R.id.tvOthercost1);
final Button bTickets = (Button) findViewById(R.id.bTickets);
final Button bBack = (Button) findViewById(R.id.bBack);
final Button btSerach = (Button) findViewById(R.id.bSerach);
btSerach.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
final String ordernum = etOrdernum.getText().toString();
Response.Listener<String> responseListener = new Response.Listener<String>() {
@Override
public void onResponse(String response) {
try {
JSONObject jsonResponse = new JSONObject(response);
int succees = jsonResponse.getInt("success");
if(succees==1){
JSONArray array = jsonResponse.getJSONArray("myorder");
JSONObject jsonName1 = array.getJSONObject(0);
String ordernum= jsonName1.getString("ordernum")+" Numero de orden";
JSONObject jsonName2 = array.getJSONObject(1);
String pilotname= jsonName2.getString("pilotname")+" Nombre del piloto";
JSONObject jsonName3 = array.getJSONObject(2);
String pilotcash= jsonName3.getString("pilotcash")+"$ Sueldo del piloto";
JSONObject jsonName4 = array.getJSONObject(3);
String date= jsonName4.getString("date")+" Fecha ";
JSONObject jsonName5 = array.getJSONObject(4);
String planemodel= jsonName5.getString("planemodel")+" Modelo del avion";
JSONObject jsonName6 = array.getJSONObject(5);
String hoobsstart= jsonName6.getString("hoobsstart")+" Hoobs inicio";
JSONObject jsonName7 = array.getJSONObject(6);
String hoobsend= jsonName7.getString("hoobsend")+"Hoobs final";
JSONObject jsonName8 = array.getJSONObject(7);
String watchtime= jsonName8.getString("watchtime")+" Watch time";
JSONObject jsonName9 = array.getJSONObject(8);
String hoobstime= jsonName9.getString("hoobstime")+" Hoobstime";
JSONObject jsonName10 = array.getJSONObject(9);
String gas= jsonName10.getString("gas")+" Combustible";
JSONObject jsonName11 = array.getJSONObject(10);
String liter= jsonName11.getString("liter")+" litros de combustible";
JSONObject jsonName12 = array.getJSONObject(11);
String repairname= jsonName12.getString("repairname")+" Nombre de refaccion";
JSONObject jsonName13 = array.getJSONObject(12);
String repaircost= jsonName13.getString("repaircost")+"$ Costo de refaccion";
JSONObject jsonName14 = array.getJSONObject(13);
String travelexpense= jsonName14.getString("travelexpense")+"$ Costo viaticos";
JSONObject jsonName15 = array.getJSONObject(13);
String othername1= jsonName15.getString("othername1")+"$ Otros Concepto";
JSONObject jsonName16 = array.getJSONObject(13);
String othercost1= jsonName16.getString("othercost1")+"$ Otros precio";
tvPilotname.setText(pilotname);
tvPilotcash.setText(pilotcash);
tvDate.setText(date);
tvPlanemodel.setText(planemodel);
tvHoobsstart.setText(hoobsstart);
tvHoobsend.setText(hoobsend);
tvWatchtime.setText(watchtime);
tvHoobstime.setText(hoobstime);
tvGas.setText(gas);
tvLiter.setText(liter);
tvRepairname.setText(repairname);
tvRepaircost.setText(repaircost);
tvTravelexpense.setText(travelexpense);
tvOthername1.setText(othername1);
tvOthercost1.setText(othercost1);
}else{
AlertDialog.Builder builder = new AlertDialog.Builder(Seeorder.this);
builder.setMessage("La orden no existe")
.setNegativeButton("Retry",null)
.create()
.show();
}
} catch (JSONException e) {
e.printStackTrace();
}
}
};
SeeorderRequest seeorderRequest = new SeeorderRequest(ordernum, responseListener);
RequestQueue queue = Volley.newRequestQueue(Seeorder.this);
queue.add(seeorderRequest);
bBack.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent registerIntent =new Intent(Seeorder.this, UserArea.class);
Seeorder.this.startActivity(registerIntent);
}
});
}
});
}
}
这是日志
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: org.json.JSONException: Index 1 out of range [0..1)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at org.json.JSONArray.get(JSONArray.java:293)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at org.json.JSONArray.getJSONObject(JSONArray.java:521)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at com.example.mauricio.pairlines.Seeorder$1$1.onResponse(Seeorder.java:70)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at com.example.mauricio.pairlines.Seeorder$1$1.onResponse(Seeorder.java:59)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:60)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:30)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:99)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at android.os.Handler.handleCallback(Handler.java:739)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at android.os.Handler.dispatchMessage(Handler.java:95)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at android.os.Looper.loop(Looper.java:135)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at android.app.ActivityThread.main(ActivityThread.java:5254)
08-25 14:36:55.833 4782-4782/com.example.mauricio.pairlines W/System.err: at java.lang.reflect.Method.invoke(Native Method)
08-25 14:36:55.834 4782-4782/com.example.mauricio.pairlines W/System.err: at java.lang.reflect.Method.invoke(Method.java:372)
08-25 14:36:55.834 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:902)
08-25 14:36:55.834 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:697)
08-25 14:37:04.248 4782-4782/com.example.mauricio.pairlines I/ViewRootImpl: CPU Rendering VSync enable = false
08-25 14:37:07.594 4782-4782/com.example.mauricio.pairlines I/Timeline: Timeline: Activity_idle id: android.os.BinderProxy@2c32922a time:3689475
08-25 14:37:09.092 4782-4782/com.example.mauricio.pairlines I/Timeline: Timeline: Activity_launch_request id:com.example.mauricio.pairlines time:3690974
08-25 14:37:09.203 4782-4782/com.example.mauricio.pairlines I/ViewRootImpl: CPU Rendering VSync enable = false
08-25 14:37:09.392 4782-4821/com.example.mauricio.pairlines D/OpenGLRenderer: endAllStagingAnimators on 0xb75eb718 (RippleDrawable) with handle 0xb765d220
08-25 14:37:09.398 4782-4782/com.example.mauricio.pairlines I/Timeline: Timeline: Activity_idle id: android.os.BinderProxy@2e649e84 time:3691280
08-25 14:37:10.182 4782-4782/com.example.mauricio.pairlines I/ViewRootImpl: CPU Rendering VSync enable = false
08-25 14:37:10.452 4782-4782/com.example.mauricio.pairlines I/ViewRootImpl: CPU Rendering VSync enable = false
08-25 14:37:19.005 4782-4782/com.example.mauricio.pairlines W/System.err: org.json.JSONException: Index 1 out of range [0..1)
08-25 14:37:19.005 4782-4782/com.example.mauricio.pairlines W/System.err: at org.json.JSONArray.get(JSONArray.java:293)
08-25 14:37:19.005 4782-4782/com.example.mauricio.pairlines W/System.err: at org.json.JSONArray.getJSONObject(JSONArray.java:521)
08-25 14:37:19.005 4782-4782/com.example.mauricio.pairlines W/System.err: at com.example.mauricio.pairlines.Seeorder$1$1.onResponse(Seeorder.java:70)
08-25 14:37:19.005 4782-4782/com.example.mauricio.pairlines W/System.err: at com.example.mauricio.pairlines.Seeorder$1$1.onResponse(Seeorder.java:59)
08-25 14:37:19.005 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:60)
08-25 14:37:19.005 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:30)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:99)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at android.os.Handler.handleCallback(Handler.java:739)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at android.os.Handler.dispatchMessage(Handler.java:95)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at android.os.Looper.loop(Looper.java:135)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at android.app.ActivityThread.main(ActivityThread.java:5254)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at java.lang.reflect.Method.invoke(Native Method)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at java.lang.reflect.Method.invoke(Method.java:372)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:902)
08-25 14:37:19.006 4782-4782/com.example.mauricio.pairlines W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:697)
如果我使用 postman 发送 ordernum,这是我从数据库得到的响应
{"success":1,"myorder":[{"ordernum":"1","pilotname":"1","pilotcash":"2","date":"3","planemodel":"4","hoobsstart":"5","hoobsend":"6","watchtime":"7","hoobstime":"8","gas":"9","liter":null,"repairname":"11","repaircost":"12","travelexpense":null,"othername1":"14","othercost1":"15"}]}
问题是我什至无法在 logcat 上找到问题它似乎是这个JSONException:索引 1 超出范围 [0..1),我认为这意味着插槽 1 中的 myorder 数组上没有任何内容,但它应该是一个“pilotname”:“1”
最佳答案
您只需要对 if
语句进行一点重构,因为数组只有一个项目:
if(succees==1){
JSONArray array = jsonResponse.getJSONArray("myorder");
JSONObject orderObj = array.getJSONObject(0);
String ordernum= orderObj.getString("ordernum")+" Numero de orden";
String pilotname= orderObj.getString("pilotname")+" Nombre del piloto";
String pilotcash= orderObj.getString("pilotcash")+"$ Sueldo del piloto";
String date= orderObj.getString("date")+" Fecha ";
String planemodel= orderObj.getString("planemodel")+" Modelo del avion";
String hoobsstart= orderObj.getString("hoobsstart")+" Hoobs inicio";
String hoobsend= orderObj.getString("hoobsend")+"Hoobs final";
String watchtime= orderObj.getString("watchtime")+" Watch time";
String hoobstime= orderObj.getString("hoobstime")+" Hoobstime";
String gas= orderObj.getString("gas")+" Combustible";
String liter= orderObj.getString("liter")+" litros de combustible";
String repairname= orderObj.getString("repairname")+" Nombre de refaccion";
String repaircost= orderObj.getString("repaircost")+"$ Costo de refaccion";
String travelexpense= orderObj.getString("travelexpense")+"$ Costo viaticos";
String othername1= orderObj.getString("othername1")+"$ Otros Concepto";
String othercost1= orderObj.getString("othercost1")+"$ Otros precio";
Take a look at this article too: http://www.technotalkative.com/android-json-parsing/
关于php - 试图从数据库中获取信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39153824/
我需要您在以下方面提供帮助。近一个月来,我一直在阅读有关任务和异步的内容。 我想尝试在一个简单的 wep api 项目中实现我新获得的知识。我有以下方法,并且它们都按预期工作: public Htt
我的可执行 jar 中有一个模板文件 (.xls)。不需要在运行时我需要为这个文件创建 100 多个副本(稍后将唯一地附加)。用于获取 jar 文件中的资源 (template.xls)。我正在使用
我在查看网站的模型代码时对原型(prototype)有疑问。我知道这对 Javascript 中的继承很有用。 在这个例子中... define([], function () { "use
影响我性能的前三项操作是: 获取滚动条 获取偏移高度 Ext.getStyle 为了解释我的应用程序中发生了什么:我有一个网格,其中有一列在每个单元格中呈现网格。当我几乎对网格的内容做任何事情时,它运
我正在使用以下函数来获取 URL 参数。 function gup(name, url) { name = name.replace(/[\[]/, '\\\[').replace(/[\]]/,
我最近一直在使用 sysctl 来做很多事情,现在我使用 HW_MACHINE_ARCH 变量。我正在使用以下代码。请注意,当我尝试获取其他变量 HW_MACHINE 时,此代码可以完美运行。我还认为
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关闭 9 年前。 要求提供代码的问题必须表现出对所解决问题的最低限度的理解。包括尝试过的解决方案、为什么
由于使用 main-bower-files 作为使用 Gulp 的编译任务的一部分,我无法使用 node_modules 中的 webpack 来require 模块code> dir 因为我会弄乱当
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我使用 Gridlayout 在一行中放置 4 个元素。首先,我有一个 JPanel,一切正常。对于行数变大并且我必须能够向下滚动的情况,我对其进行了一些更改。现在我的 JPanel 上添加了一个 J
由于以下原因,我想将 VolumeId 的值保存在变量中: #!/usr/bin/env python import boto3 import json import argparse import
我正在将 MSAL 版本 1.x 更新为 MSAL-browser 的 Angular 。所以我正在尝试从版本 1.x 迁移到 2.X.I 能够成功替换代码并且工作正常。但是我遇到了 acquireT
我知道有很多关于此的问题,例如 Getting daily averages with pandas和 How get monthly mean in pandas using groupby但我遇到
This is the query string that I am receiving in URL. Output url: /demo/analysis/test?startDate=Sat+
我正在尝试使用 javascript 中的以下代码访问 Geoserver 层 var gkvrtWmsSource =new ol.source.ImageWMS({ u
API 需要一个包含授权代码的 header 。这就是我到目前为止所拥有的: var fullUrl = 'https://api.ecobee.com/1/thermostat?json=\{"s
如何获取文件中的最后一个字符,如果是某个字符,则删除它而不将整个文件加载到内存中? 这就是我目前所拥有的。 using (var fileStream = new FileStream("file.t
我是这个社区的新手,想出了我的第一个问题。 我正在使用 JSP,我成功地创建了 JSP-Sites,它正在使用jsp:setParameter 和 jsp:getParameter 具有单个字符串。
在回答 StoreStore reordering happens when compiling C++ for x86 @Peter Cordes 写过 For Acquire/Release se
我有一个函数,我们将其命名为 X1,它返回变量 Y。该函数在操作 .on("focusout", X1) 中使用。如何获取变量Y?执行.on后X1的结果? 最佳答案 您可以更改 Y 的范围以使其位于函
我是一名优秀的程序员,十分优秀!