本文目錄一覽:
- 1、Java解析json數據
- 2、JAVA中遍歷JSONObject不能按原順序遍歷
- 3、java校驗json格式及內容
- 4、JAVA中按原順序遍歷JSONObject
- 5、json.parseobject()的set方法設置順序
Java解析json數據
一、 JSON (JavaScript Object Notation)一種簡單的數據格式,比xml更輕巧。
Json建構於兩種結構:
1、「名稱/值」對的集合(A collection of name/value pairs)。不同的語言中,它被理解為對象(object),紀錄(record),結構(struct),字典(dictionary),哈希表(hash table),有鍵列表(keyed list),或者關聯數組 (associative array)。 如:
{
「name」:」jackson」,
「age」:100
}
2、值的有序列表(An ordered list of values)。在大部分語言中,它被理解為數組(array)如:
{
「students」:
[
{「name」:」jackson」,「age」:100},
{「name」:」michael」,」age」:51}
]
}
二、java解析JSON步驟
A、服務器端將數據轉換成json字符串
首先、服務器端項目要導入json的jar包和json所依賴的jar包至builtPath路徑下(這些可以到JSON-lib官網下載:)
然後將數據轉為json字符串,核心函數是:
public static String createJsonString(String key, Object value)
{
JSONObject jsonObject = new JSONObject();
jsonObject.put(key, value);
return jsonObject.toString();
}
B、客戶端將json字符串轉換為相應的javaBean
1、客戶端獲取json字符串(因為android項目中已經集成了json的jar包所以這裡無需導入)
public class HttpUtil
{
public static String getJsonContent(String urlStr)
{
try
{// 獲取HttpURLConnection連接對象
URL url = new URL(urlStr);
HttpURLConnection httpConn = (HttpURLConnection) url
.openConnection();
// 設置連接屬性
httpConn.setConnectTimeout(3000);
httpConn.setDoInput(true);
httpConn.setRequestMethod(“GET”);
// 獲取相應碼
int respCode = httpConn.getResponseCode();
if (respCode == 200)
{
return ConvertStream2Json(httpConn.getInputStream());
}
}
catch (MalformedURLException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return “”;
}
private static String ConvertStream2Json(InputStream inputStream)
{
String jsonStr = “”;
// ByteArrayOutputStream相當於內存輸出流
ByteArrayOutputStream out = new ByteArrayOutputStream();
byte[] buffer = new byte[1024];
int len = 0;
// 將輸入流轉移到內存輸出流中
try
{
while ((len = inputStream.read(buffer, 0, buffer.length)) != -1)
{
out.write(buffer, 0, len);
}
// 將內存流轉換為字符串
jsonStr = new String(out.toByteArray());
}
catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return jsonStr;
}
}
2、獲取javaBean
public static Person getPerson(String jsonStr)
{
Person person = new Person();
try
{// 將json字符串轉換為json對象
JSONObject jsonObj = new JSONObject(jsonStr);
// 得到指定json key對象的value對象
JSONObject personObj = jsonObj.getJSONObject(“person”);
// 獲取之對象的所有屬性
person.setId(personObj.getInt(“id”));
person.setName(personObj.getString(“name”));
person.setAddress(personObj.getString(“address”));
}
catch (JSONException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return person;
}
public static ListPerson getPersons(String jsonStr)
{
ListPerson list = new ArrayListPerson();
JSONObject jsonObj;
try
{// 將json字符串轉換為json對象
jsonObj = new JSONObject(jsonStr);
// 得到指定json key對象的value對象
JSONArray personList = jsonObj.getJSONArray(“persons”);
// 遍歷jsonArray
for (int i = 0; i personList.length(); i++)
{
// 獲取每一個json對象
JSONObject jsonItem = personList.getJSONObject(i);
// 獲取每一個json對象的值
Person person = new Person();
person.setId(jsonItem.getInt(“id”));
person.setName(jsonItem.getString(“name”));
person.setAddress(jsonItem.getString(“address”));
list.add(person);
}
}
catch (JSONException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
}
JAVA中遍歷JSONObject不能按原順序遍歷
這個估計沒辦法,json本來就是無序的。我來試一下,沒遇到這種情況。
可以重寫原碼,不過不推薦,如下:
要使輸出是有序的,可以用LinkedHashMap來替換HashMap。
修改org.json.JSONObject的構造函數,
public JSONObject() {
this.map = new LinkedHashMap(); //new HashMap();
}
可能會對JSON 函數的執行效率有所影響。
java校驗json格式及內容
代碼如下
import java.text.CharacterIterator;
import java.text.StringCharacterIterator;
public class JsonValidator {
private CharacterIterator it;
private char c;
private int col;
public JsonValidator(){
}
/**
* 驗證一個字符串是否是合法的JSON串
*
* @param input 要驗證的字符串
* @return true-合法 ,false-非法
*/
public boolean validate(String input) {
input = input.trim();
boolean ret = valid(input);
return ret;
}
private boolean valid(String input) {
if (“”.equals(input)) return true;
boolean ret = true;
it = new StringCharacterIterator(input);
c = it.first();
col = 1;
if (!value()) {
ret = error(“value”, 1);
} else {
skipWhiteSpace();
if (c != CharacterIterator.DONE) {
ret = error(“end”, col);
}
}
return ret;
}
private boolean value() {
return literal(“true”) || literal(“false”) || literal(“null”) || string() || number() || object() || array();
}
private boolean literal(String text) {
CharacterIterator ci = new StringCharacterIterator(text);
char t = ci.first();
if (c != t) return false;
int start = col;
boolean ret = true;
for (t = ci.next(); t != CharacterIterator.DONE; t = ci.next()) {
if (t != nextCharacter()) {
ret = false;
break;
}
}
nextCharacter();
if (!ret) error(“literal ” + text, start);
return ret;
}
private boolean array() {
return aggregate(‘[‘, ‘]’, false);
}
private boolean object() {
return aggregate(‘{‘, ‘}’, true);
}
private boolean aggregate(char entryCharacter, char exitCharacter, boolean prefix) {
if (c != entryCharacter) return false;
nextCharacter();
skipWhiteSpace();
if (c == exitCharacter) {
nextCharacter();
return true;
}
for (;;) {
if (prefix) {
int start = col;
if (!string()) return error(“string”, start);
skipWhiteSpace();
if (c != ‘:’) return error(“colon”, col);
nextCharacter();
skipWhiteSpace();
}
if (value()) {
skipWhiteSpace();
if (c == ‘,’) {
nextCharacter();
} else if (c == exitCharacter) {
break;
} else {
return error(“comma or ” + exitCharacter, col);
}
} else {
return error(“value”, col);
}
skipWhiteSpace();
}
nextCharacter();
return true;
}
private boolean number() {
if (!Character.isDigit(c) c != ‘-‘) return false;
int start = col;
if (c == ‘-‘) nextCharacter();
if (c == ‘0’) {
nextCharacter();
} else if (Character.isDigit(c)) {
while (Character.isDigit(c))
nextCharacter();
} else {
return error(“number”, start);
}
if (c == ‘.’) {
nextCharacter();
if (Character.isDigit(c)) {
while (Character.isDigit(c))
nextCharacter();
} else {
return error(“number”, start);
}
}
if (c == ‘e’ || c == ‘E’) {
nextCharacter();
if (c == ‘+’ || c == ‘-‘) {
nextCharacter();
}
if (Character.isDigit(c)) {
while (Character.isDigit(c))
nextCharacter();
} else {
return error(“number”, start);
}
}
return true;
}
private boolean string() {
if (c != ‘”‘) return false;
int start = col;
boolean escaped = false;
for (nextCharacter(); c != CharacterIterator.DONE; nextCharacter()) {
if (!escaped c == ‘\\’) {
escaped = true;
} else if (escaped) {
if (!escape()) {
return false;
}
escaped = false;
} else if (c == ‘”‘) {
nextCharacter();
return true;
}
}
return error(“quoted string”, start);
}
private boolean escape() {
int start = col – 1;
if (” \\\”/bfnrtu”.indexOf(c) 0) {
return error(“escape sequence \\\”,\\\\,\\/,\\b,\\f,\\n,\\r,\\t or \\uxxxx “, start);
}
if (c == ‘u’) {
if (!ishex(nextCharacter()) || !ishex(nextCharacter()) || !ishex(nextCharacter())
|| !ishex(nextCharacter())) {
return error(“unicode escape sequence \\uxxxx “, start);
}
}
return true;
}
private boolean ishex(char d) {
return “0123456789abcdefABCDEF”.indexOf(c) = 0;
}
private char nextCharacter() {
c = it.next();
++col;
return c;
}
private void skipWhiteSpace() {
while (Character.isWhitespace(c)) {
nextCharacter();
}
}
private boolean error(String type, int col) {
System.out.printf(“type: %s, col: %s%s”, type, col, System.getProperty(“line.separator”));
return false;
}
public static void main(String[] args){
String jsonStr = “{\”website\”:\”open-open.com\”}”;
System.out.println(jsonStr+”:”+new JsonValidator().validate(jsonStr));
}
}
JAVA中按原順序遍歷JSONObject
正常的玩法應該是這樣, 因為 ObjectMapper 有各種配置, 可以更好的實現轉換, 比如 解析數據順序, 忽略錯誤字段 等等 高端大氣上檔次的東西, 你的方法已經被時代淘汰了。
ObjectMapper objectMapper = new ObjectMapper();
Map map = objectMapper.readValue(resultStr,LinkedHashMap.class);
json.parseobject()的set方法設置順序
取出數據庫中的字符串通過前端的JSON.parse(str)遍歷顯示key,value值。到此一個新的要求是要顯示的順序和數據庫中保持一致,通過JSON.parse()通常會按照key排序。所以使用JSON.parse失敗。
只能手動獲取字符串中的key,value值,最好的方式是採用正則,不然也可以採用 replace,replaceALl,split等方法逐步分割在回到如果不需要保持順序的情況下,使用JSON.parse()遇到了拋出異常的問題,一看數據庫中的內容,發現並不是標準的JSON格式,比如這段{name:「張三」,age:12},此時使用JSON.parse便會拋出異常,所以需要改為{「name」:「張三」,age:12} 解決的思路是前端給該字符串補全雙引號,不過也可以用JAVA。
思路是通過fastjson庫將字符串轉換為JSON對象,在轉回JSON字符串。這裡利用了fastjson對JSON格式要求不嚴格
在使用fastjson直接將字符串轉為JSON對象後在轉換回JSON字符串,順序將保證不了。修改代碼這裡僅僅對key,value形式,key不帶雙引號的,value僅僅是字符串(也僅帶特殊符號”:”)的處理,對於嵌套的JSON格式或者value值為時間,數字,其它轉義特殊符號還考慮。還有些地方需要完善。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/207265.html