


Bagaimana untuk menentukan sama ada JSONObject mengandungi kunci tertentu dalam Java?
Tentukan sama ada Kunci tertentu wujud dalam JSONObject
JSONObject jsonObj = new JSONObject(); jsonObj.put("version", "1.0.0"); // 版本号 jsonObj.put("encoding", "UTF-8"); // 编码方式
Tentukan sama ada atribut vesion wujud dalam jsonObject
jsonObj.has("version"); // 返回true
Semak sama ada kunci wujud dalam rentetan json
Niat asal Disebabkan keperluan kerja, kedua-dua unit memerlukan dok data antara muka Unit satu perlu menghantar rentetan data json ke unit dua Walau bagaimanapun, medan dalam data json yang dihantar oleh unit satu tidak pasti jelaskan bahawa pelanggan memasukkan data pada sistem Untuk medan tersebut, mereka akan membawa medan tersebut, dan untuk medan yang pelanggan tidak masukkan, mereka tidak akan membawanya secara lalai. Unit satu memerlukan unit dua dan nilai lalai medan yang dikesan ini akan kosong!
Jadi sebagai unit dua, kita perlu mencari jalan untuk mengesan medan mana yang tidak dibawa oleh unit satu. Penyelesaian yang segera terlintas di fikiran pada mulanya ialah menggunakan pengendalian pengecualian, kerana program itu sendiri dilaporkan tidak ditemui apabila diuji, jadi boleh difahami untuk menggunakan pengendalian pengecualian. . . Jika anda menggunakan pengecualian, selepas memikirkannya, anda hanya boleh menangkap tidak ditemui, dan kemudian biarkan medan yang ditangkap kosong akhirnya dan ia akan menjadi ok.
Kemudian masalah datang saya mencuba situasi yang tidak normal dan mendapati bahawa terdapat terlalu banyak yang perlu ditangani, jadi saya berfikir untuk menggunakan kaedah lain, menggunakan fungsi containsKey() json untuk menentukan sama ada ia wujud; rentetan json ini adalah sama ada medan ini wujud, sudah tentu, terdapat fungsi lain yang juga boleh dinilai, ini berdasarkan pakej json yang diperkenalkan oleh anda sendiri.
Yang berikut memperkenalkan situasi saya sendiri
Pakej balang yang diimport ialah:
Pertama sekali, pakej json yang saya import:
import net.sf.json.JSONArray; import net.sf.json.JSONObject;
Kodnya adalah seperti berikut:
/** * 9903接口解析json数据并且将数据进行入库 * * @author syp * @time 2019年7月3日11:49:02 */ public String dateRepository(String jsonData) { Log4jBean.logger.info("开始处理入库程序!"); ReadConfig.PullConfigXml(); //启动配置文件 DBUtils db = new DBUtils(); JSONObject json=new JSONObject(); String jsonStr=jsonData.substring(44, jsonData.length()); JSONObject jsonObject = JSONObject.fromObject(jsonStr); JSONObject jsonCard=jsonObject.getJSONObject("cardid_info") JSONObject jsonObu = jsonObject.getJSONObject("obu_info"); JSONObject jsonUser=jsonObject.getJSONObject("user_info"); JSONObject jsonCar = jsonObject.getJSONObject("car_info"); //准备将所有json数据信息入开卡集合表ETC_OPEN_CARD_COLLECTION JSONObject jsonAccno = jsonObject.getJSONObject("accno_info"); String allSql = "insert into ETC_OPEN_CARD_COLLECTION(ACCOUNTID,LINKMOBILE,ACCNO_USERNAME,CERTSN,POSID,GENTIME,TRX_SERNO,EMPLOYEEID,ORG_TRX_SERNO,CARD_ID,CARDTYPE,CARD_BRAND,CARD_MODEL,AGENCYID,CARD_USERID,VEHICLEID,ENABLETIME,EXPIRETIME,ISSUEDTYPE,CHANNELID,ISSUEDTIME,CARD_STATUS,STATUSCHANGETIME,CARD_OPERATION,OBU_ID,OBU_BRAND,OBU_MODEL,OBU_USERID,OBU_VEHICLEID,OBU_ENABLETIME,OBU_EXPIRETIME,REGISTEREDTYPE,REGISTEREDCHANNELID,REGISTEREDTIME,INSTALLTYPE,INSTALLCHANNELID,INSTALLTIME,OBU_STATUS,OBU_STATUSCHANGETIME,OBU_OPERATION,USER_ID,USERTYPE,USER_NAME,USERIDTYPE,USERIDNUM,USER_TEL,USER_ADDRESS,USER_REGISTEREDTYPE,USER_CHANNELID,USER_REGISTEREDTIME,DEPARTMENT,AGENTNAME,AGENTIDTYPE,AGENTIDNUM,USER_STATUS,USER_STATUSCHANGETIME,USER_OPERATION,CAR_ID,CAR_TYPE,CAR_USERID,OWNERNAME,OWNERIDTYPE,OWNERIDNUM,OWNERTEL,CAR_ADDRESS,CAR_CONTACT,CAR_REGISTEREDTYPE,CAR_CHANNELID,CAR_REGISTEREDTIME,VEHICLETYPE,VEHICLEMODEL,USECHARACTER,VIN,ENGINENUM,REGISTERDATE,ISSUEDATE,FILENUM,APPROVEDCOUNT,TOTALMASS,MAINTENANCEMASS,PERMITTEDWEIGHT,OUTSIDEDIMENSIONS,PERMITTEDTOWWEIGHT,TESTRECORD,WHEELCOUNT,AXLECOUNT,AXLEDISTANCE,AXISTYPE,CAR_OPERATION) values('" + (jsonAccno.containsKey("accountid")?jsonAccno.getString("accountid"):"") + "','" + (jsonAccno.containsKey("linkmobile")?jsonAccno.getString("linkmobile"):"") + "','" + (jsonAccno.containsKey("username")?jsonAccno.getString("username"):"") + "','" + (jsonAccno.containsKey("certsn")?jsonAccno.getString("certsn"):"") + "','" + (jsonAccno.containsKey("posid")?jsonAccno.getString("posid"):"") + "','" + (jsonAccno.containsKey("gentime")?jsonAccno.getString("gentime"):"") + "','" + (jsonAccno.containsKey("trx_serno")?jsonAccno.getString("trx_serno"):"") + "','" + (jsonAccno.containsKey("employeeid")?jsonAccno.getString("employeeid"):"") + "','" + (jsonAccno.containsKey("org_trx_serno")?jsonAccno.getString("org_trx_serno"):"") + "','" + (jsonCard.containsKey("id")?jsonCard.getString("id"):"") + "','" + (jsonCard.containsKey("cardType")?jsonCard.getString("cardType"):"") + "','" + (jsonCard.containsKey("brand")?jsonCard.getString("brand"):"") + "','" + (jsonCard.containsKey("model")?jsonCard.getString("model"):"") + "','" + (jsonCard.containsKey("agencyId")?jsonCard.getString("agencyId"):"") + "','" + (jsonCard.containsKey("userId")?jsonCard.getString("userId"):"") + "','" + (jsonCard.containsKey("vehicleId")?jsonCard.getString("vehicleId"):"") + "','" + (jsonCard.containsKey("enableTime")?jsonCard.getString("enableTime"):"") + "','" + (jsonCard.containsKey("expireTime")?jsonCard.getString("expireTime"):"") + "','" + (jsonCard.containsKey("issuedType")?jsonCard.getString("issuedType"):"") + "','" + (jsonCard.containsKey("channelId")?jsonCard.getString("channelId"):"") + "','" + (jsonCard.containsKey("issuedTime")?jsonCard.getString("issuedTime"):"") + "','" + (jsonCard.containsKey("status")?jsonCard.getString("status"):"") + "','" + (jsonCard.containsKey("statusChangeTime")?jsonCard.getString("statusChangeTime"):"") + "','" + (jsonCard.containsKey("operation")?jsonCard.getString("operation"):"") + "','" + (jsonObu.containsKey("id")?jsonObu.getString("id"):"") + "','" + (jsonObu.containsKey("brand")?jsonObu.getString("brand"):"") + "','" + (jsonObu.containsKey("model")?jsonObu.getString("model"):"") + "','" + (jsonObu.containsKey("userId")?jsonObu.getString("userId"):"") + "','" + (jsonObu.containsKey("vehicleId")?jsonObu.getString("vehicleId"):"") + "','" + (jsonObu.containsKey("enableTime")?jsonObu.getString("enableTime"):"") + "','" + (jsonObu.containsKey("expireTime")?jsonObu.getString("expireTime"):"") + "','" + (jsonObu.containsKey("registeredType")?jsonObu.getString("registeredType"):"") + "','" + (jsonObu.containsKey("registeredChannelId")?jsonObu.getString("registeredChannelId"):"") + "','" + (jsonObu.containsKey("registeredTime")?jsonObu.getString("registeredTime"):"") + "','" + (jsonObu.containsKey("installType")?jsonObu.getString("installType"):"") + "','" + (jsonObu.containsKey("installChannelId")?jsonObu.getString("installChannelId"):"") + "','" + (jsonObu.containsKey("installTime")?jsonObu.getString("installTime"):"") + "','" + (jsonObu.containsKey("status")?jsonObu.getString("status"):"") + "','" + (jsonObu.containsKey("statusChangeTime")?jsonObu.getString("statusChangeTime"):"") + "','" + (jsonObu.containsKey("operation")?jsonObu.getString("operation"):"") + "','" + (jsonUser.containsKey("id")?jsonUser.getString("id"):"") + "','" + (jsonUser.containsKey("userType")?jsonUser.getString("userType"):"") + "','" + (jsonUser.containsKey("userName")?jsonUser.getString("userName"):"") + "','" + (jsonUser.containsKey("userIdType")?jsonUser.getString("userIdType"):"") + "','" + (jsonUser.containsKey("userIdNum")?jsonUser.getString("userIdNum"):"") + "','" + (jsonUser.containsKey("tel")?jsonUser.getString("tel"):"") + "','" + (jsonUser.containsKey("address")?jsonUser.getString("address"):"") + "','" + (jsonUser.containsKey("registeredType")?jsonUser.getString("registeredType"):"") + "','" + (jsonUser.containsKey("channelId")?jsonUser.getString("channelId"):"") + "','" + (jsonUser.containsKey("registeredTime")?jsonUser.getString("registeredTime"):"") + "','" + (jsonUser.containsKey("department")?jsonUser.getString("department"):"") + "','" + (jsonUser.containsKey("agentName")?jsonUser.getString("agentName"):"") + "','" + (jsonUser.containsKey("agentIdType")?jsonUser.getString("agentIdType"):"") + "','" + (jsonUser.containsKey("agentIdNum")?jsonUser.getString("agentIdNum"):"") + "','" + (jsonUser.containsKey("status")?jsonUser.getString("status"):"") + "','" + (jsonUser.containsKey("statusChangeTime")?jsonUser.getString("statusChangeTime"):"") + "','" + (jsonUser.containsKey("operation")?jsonUser.getString("operation"):"") + "','" + (jsonCar.containsKey("id")?jsonCar.getString("id"):"") + "','" + (jsonCar.containsKey("type")?jsonCar.getString("type"):"") + "','" + (jsonCar.containsKey("userId")?jsonCar.getString("userId"):"") + "','"+ (jsonCar.containsKey("ownerName")?jsonCar.getString("ownerName"):"") + "','"+ (jsonCar.containsKey("ownerIdType")?jsonCar.getString("ownerIdType"):"") + "','"+ (jsonCar.containsKey("ownerIdNum")?jsonCar.getString("ownerIdNum"):"") + "','"+ (jsonCar.containsKey("ownerTel")?jsonCar.getString("ownerTel"):"") + "','"+ (jsonCar.containsKey("address")?jsonCar.getString("address"):"") + "','"+ (jsonCar.containsKey("contact")?jsonCar.getString("contact"):"") + "','"+ (jsonCar.containsKey("registeredType")?jsonCar.getString("registeredType"):"") + "','"+ (jsonCar.containsKey("channelId")?jsonCar.getString("channelId"):"") + "','"+ (jsonCar.containsKey("registeredTime")?jsonCar.getString("registeredTime"):"") + "','"+ (jsonCar.containsKey("vehicleType")?jsonCar.getString("vehicleType"):"") + "','"+ (jsonCar.containsKey("vehicleModel")?jsonCar.getString("vehicleModel"):"") + "','"+ (jsonCar.containsKey("useCharacter")?jsonCar.getString("useCharacter"):"") + "','"+ (jsonCar.containsKey("VIN")?jsonCar.getString("VIN"):"") + "','"+ (jsonCar.containsKey("engineNum")?jsonCar.getString("engineNum"):"") + "','"+ (jsonCar.containsKey("registerDate")?jsonCar.getString("registerDate"):"") + "','"+ (jsonCar.containsKey("issueDate")?jsonCar.getString("issueDate"):"") + "','"+ (jsonCar.containsKey("fileNum")?jsonCar.getString("fileNum"):"") + "','"+ (jsonCar.containsKey("approvedCount")?jsonCar.getString("approvedCount"):"") + "','"+ (jsonCar.containsKey("totalMass")?jsonCar.getString("totalMass"):"") + "','"+ (jsonCar.containsKey("maintenanceMass")?jsonCar.getString("maintenanceMass"):"") + "','"+ (jsonCar.containsKey("permittedWeight")?jsonCar.getString("permittedWeight"):"") + "','"+ (jsonCar.containsKey("outsideDimensions")?jsonCar.getString("outsideDimensions"):"") + "','"+ (jsonCar.containsKey("permittedTowWeight")?jsonCar.getString("permittedTowWeight"):"") + "','"+ (jsonCar.containsKey("testRecord")?jsonCar.getString("testRecord"):"") + "','"+ (jsonCar.containsKey("wheelCount")?jsonCar.getString("wheelCount"):"") + "','"+ (jsonCar.containsKey("axleCount")?jsonCar.getString("axleCount"):"") + "','"+ (jsonCar.containsKey("axleDistance")?jsonCar.getString("axleDistance"):"") + "','"+ (jsonCar.containsKey("axisType")?jsonCar.getString("axisType"):"") + "','"+ (jsonCar.containsKey("operation")?jsonCar.getString("operation"):"") + "')"; int allParam = db.updateMethod(allSql, null); if (allParam > 0) { Log4jBean.logger.info("开卡集合数据写入开卡集合表成功!"); json.put("return_msg", "处理成功!"); json.put("return_code", "0"); } else { Log4jBean.logger.error("开卡集合数据写入开卡集合表失败!"); json.put("return_msg", "处理失败!"); json.put("return_code", "-1"); } return json.toString(); }
Seperti yang anda lihat daripada kod, setiap medan diproses dengan fungsi containsKey(), jadi anda tidak perlu risau tentang medan mana yang tidak boleh ditemui dalam rentetan j'son yang dihantar oleh unit Keadaan telah tiba.
Atas ialah kandungan terperinci Bagaimana untuk menentukan sama ada JSONObject mengandungi kunci tertentu dalam Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.