Я анализирую объект JSON для объекта Java, но некоторые поля пусты.
Результаты
//Printed object after parsing, some fields are null
{host_ip='null', open=false, host_fqdn='null', nmap_results='null', cvss_vector='cvss2#av:n/ac:l/au:n/c:c/i:c/a:c', cvss=10.0, attackvector='n', list_
of_ports=null, ports___port='null', plugin_family='Windows', scanner_name='Local Scanner', operating_system='null', plugin_name='Microsoft Windows XP Unsupported
Installation Detection'
Использование библиотеки Gson:
for (int v = 0; v < splunk_results_as_Array.size(); v++)
{
String vuln_as_string = splunk_results_as_Array.get(v).toString();
Splunk_data splunkdata = new Gson().fromJson(vuln_as_string, Splunk_data.class); // parsing happens here
System.out.print("\n Splunk : Splunk Java Object created \n" + splunkdata.toString());
splunkdata.ports_to_List();
splunkdata.setDataType(dataType);
list_of_Hosts.add(splunkdata);
}
Объект Json как строка
"result":
{"cvss_vector":"cvss2#av:n/ac:l/au:n/c:c/i:c/a:c","host-ip":"XX.XX.XX.XX","plugin_family":"Windows","scanner_name":"Local Scanner","plugin_name":"Microsoft RDP RCE (CVE-2019-0708) (uncredentialed check)","hostname":"XX.XX.XX.XX","cvss":"10.0","attackvector":"n","ports{}.port":"3389"}
}
как вы можете видеть, поля: host-ip и ports{}.ports действительно имеют значение.
Используемые классы:
public class Splunk_data
{
private String host_ip;
private boolean open;
private String host_fqdn;
private String nmap_results;
private String cvss_vector;
private double cvss;
private String attackvector;
private String ports_port;
private String plugin_family;
private String scanner_name;
private String operating_system;
private String plugin_name;
}
Я думаю, что проблема возникла из-за того, что host_ip не соответствует host-ip, но я не могу использовать Java, поэтому я использовал «_».
есть способ как это исправить?




Чтобы использовать имя переменной, отличное от фактического ключа в JSON, вы можете использовать аннотацию @Serialized.
@Serialized("host-ip")
private String host_ip;
Это будет работать и анализировать ваш host-ip как строку.