JSON

官网:http://www.json.org/

一。定义

JSON(JavaScript Object Notation),类似于XML,是一种数据交换格式,比如JAVA产生了一个数据想要给JavaScript,则除了利用XML外,还可以利用JSON;

易于人阅读和编写,同时也易于机器解析和生成。

它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。 

JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。

从定义我们可以总结出几个关键点:

轻量级

数据交换格式

易于编写和阅读

基于JavaScript的一个子集

纯文本独立于语言和平台

重点是它以纯文本存储,可以独立于任何语言和平台,且主要用于数据交换。

比如JSON适用于:数据交换,尤其跨平台的数据交换,表示JavaScript对象

注:JSON并不是一个文档格式,没有*.json的文档,一般JSON格式的文档存在txt中,而XML可以是一个标准;

二。json 解析示例

public static void JsonParsexml(){

try {

// xml 转换成json格式(获得json 对象)

JSON json = new XMLSerializer().readFromStream(Parsexml.class.getClassLoader().getResourceAsStream("json.xml"));

System.out.println("json=="+json);

// 格式化 json 对象

JSONArray jo = JSONArray.fromObject(json.toString());

System.out.println(jo.toString(1));

JsonConfig jsonConfig = new JsonConfig();

jsonConfig.setArrayMode(JsonConfig.MODE_LIST);

jsonConfig.setRootClass(JsonBean.class);

List<JsonBean> jsonBeans = (List<JsonBean>) JSONSerializer.toJava(jo, jsonConfig);

for (JsonBean jsonBean : jsonBeans) {

System.out.println("jsonBean.getCron()="jsonBean.getCron());

System.out.println("jsonBean.getJobClass()="jsonBean.getJobClass());

System.out.println("jsonBean.getName()="jsonBean.getName());

}

System.out.println("jsonConfig=="+jsonConfig);

} catch (Exception e) {

e.printStackTrace();

}

}

public static class JsonBean {

String name;

String cron;

String jobClass;

。。。//提供get、set方法

}

三。与java交换示例

//ShowEmpServlet.java java处理 拼接成json格式的数据

public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {

response.setContentType("text/html;charset=UTF-8");

response.setCharacterEncoding("UTF-8");

request.setCharacterEncoding("UTF-8");

PrintWriter out = response.getWriter();

String empno=request.getParameter("empno"); 

EmployeeDAO dao=new EmployeeDAO();

StringBuffer buffer=new StringBuffer();

buffer.append("{");

if(empno!=null && !"".equals(empno.trim())){

Employee employee=dao.findById(Long.parseLong(empno));

if(employee!=null){

buffer.append("'status':'yes',")

             .append("'empno':'").append(empno).append("',")

             .append("'ename':'").append(employee.getEname()).append("',")

             .append("'sex':'").append(employee.getSex()).append("',")

             .append("'hiredate':'").append(employee.getHiredate()).append("'");

}else {

buffer.append("'status':'no'");

}

} else {

buffer.append("'status':'input'");

}

buffer.append("}");

System.out.println("拼接后的Str==="+buffer);

out.write(buffer.toString());

out.flush();

out.close();

}

//ajax提交

<script type="text/javascript">

$(document).ready(function (){

$('#eid').blur(function (){ 

                 $.post(

                    'ShowEmpServlet',{'empno':$('#eid').val()},

                    function (data){

var str=eval(data);

if(str.status==='yes'){

                    $('#eid').attr('value',str.empno);

                    $('#ename').attr('value',str.ename);

                    

                    if(str.sex==='M'){

                        $('#sex1').attr('value','M').attr('checked',true);

                    }if(str.sex==='F'){

                       $('#sex2').attr('value','F').attr('checked',true);

                    }

                    $('#hiredate').attr('value',str.hiredate);

                    $('#div1').empty(); 

                    $('#ADDbutt').attr('disabled',true);

                    $('#UPbutt').attr('disabled',false);

}else if(str.status==='no'){

                     $('#ename').attr('value','');

                     $('#sex1').attr('value','M').attr('checked',false);

                     $('#sex2').attr('value','F').attr('checked',false);

                     $('#hiredate').attr('value','');

                              $('#div1').empty().append("对不起,没有您要查找的信息,请重新输入或重新添加");

                              $('#ADDbutt').attr('disabled',false);

                              $('#UPbutt').attr('disabled',true);   

}else if(str.status==='input'){

                          $('#ename').attr('value','');

                     $('#sex1').attr('value','')

                     $('#sex2').attr('value','')

                     $('#hiredate').attr('value','');

                     $('#div1').empty().append("请输入编号");

}

                    },'json');

});

});

</script>

<body>

   员工编号:<input type="text" name="eid" id="eid"><br>

   <div id="div1" style="color: green"></div>

   员工姓名:<input type="text" name="ename" id="ename"><br>

   员工性别:男<input type="radio" name="sex" value="M" id="sex1">

            女<input type="radio" name="sex" value="F" id="sex2"><br>

   入职时间:<input type="text" name="hiredate" id="hiredate"><br>

   <input type="button" value="修改" id="UPbutt" disabled="disabled">

   <input type="button" value="添加" id="ADDbutt" disabled="disabled">

</body>

四。总结:

(1)JSON的数据结构只有两种;

(2)可以嵌套表示,比如Array中可以嵌套Object等;

(3)记住:Object是以{'':'','':'',...}表示,Array是以[{},{},...]表示;

更多入门收藏

json for java 入门:

http://blog.csdn.net/xiazdong/article/details/7059573

相关推荐