2008年10月31日星期五

JSON解析之JSONObject对象---js对象转换成java对象

以前用过一段时间的JSON,非常简单,而且觉得2期的学员在学习了jsp的基础之后,都能应用自如.所以觉得有必要说一说它的使用方法.整个json框架以及其工具库的内容还是教多的,饭要一口一口吃,我们先从简单的基础讲起,让大家明白json究竟是什么,为什么要学习使用它,以及掌握它以后在开发过程中都能获得哪些便利.下面,我们即将开始.

要求基础:《使用jsp开发Web应用系统》(s2学期 / y2学期)

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它是大家熟悉的javascript客户端脚本的一个子集。JSON采用完全独立于语言的文本格式,它是一款非常理想的数据交换语言。其中文网站是http://www.json.org/json-zh.html,详细阐述了JSON的概念和数据格式等等,大家如果感兴趣的话可以去浏览一下。

在简要的概述了JSON是什么之后,相信大家也有了一个初步的印象。那么我们下面以一个简单的示例来了解一下JSON如何使用。今天我们示例的主角是JSON基于java的库包-json-lib.jar中的JSONObject对象,我们今天的例子也就是把javascript对象内的数据透明的绑定到简单的java值对象上。

我们还是依旧以实例为导向,这样理解起来非常容易。我们今天就以一个简单的注册页面(不带数据库,大家可以自己在练习中使用数据库)来贯穿我们今天的内容。(要准备的jar包为json-lib-2.2.2-jdk15.jar,commons-beanutils-1.8.0.jar,commons-collections-3.2.1.jar,commons-lang-2.4.jar,commons-logging-1.1.1.jar,可以去网上下载,也可以找我索取)

首先我们建立一个简单的jsp注册页面,代码片断如下:


<form name="frm" action="convertJava.jsp" method="post">
请输入姓名:<input name="username"><br>
请输入密码:<input type="password" name="password" ><br>
请选择你的性别: <input type="radio" name="sex" value="男" >男

<input type="radio" name="sex" value="女"> 女

请选择爱好:<input type="checkbox" name="love" value="java"> java
<input type="checkbox" name="love" value=".net">.net
<input type="checkbox" name="love" value="php">php
<input type="checkbox" name="love" value="vb">vb<br>
<input type="hidden" name="str" value="" />
<input type="button" value="注册" onclick="run()"/>
</form>

这是我们最常见的表单了,但是这里要注意的是大家在设置表单元素的name属性的时候,要确保和以后你新建的java值对象的属性名相同。

也许大家注意到了,最后注册的按钮控件上有个点击事件--run,run这个函数比较重要,我们主要是用这个函数来把这个表单描述为JSON格式的文本。那么下面我们就来看看run函数的代码片段:

function run()
{

var str="{'username':'"+document.frm.username.value+"','password':'"+document.frm.password.value+"','sex':'";
var radios=document.getElementsByName("sex");
var radiovalue="";
for(i=0;i<radios.length;i++)
{
if(radios[i].checked==true)
radiovalue=radios[i].value;
}
str+=radiovalue+"','love':[";
var arraytemp=document.getElementsByName("love");
for(i=0;i {
if(arraytemp[i].checked==false)
continue;
if(arraytemp[i].value=="")
continue;
if(i+1==arraytemp.length&&arraytemp[i].checked==true)
{
str+="'"+arraytemp[i].value+"']";
break;
}
str+="'"+arraytemp[i].value+"',";
}
if(str.substring(str.length-1,str.length)==",")
{
str=str.substring(0,str.length-1)+"]";

}
str+="}";
document.frm.str.value=str;
document.frm.submit();
}


这里卖个关子,具体JSON文本格式是怎样的,请大家把以上的代码片段拼起来,在run方法里加上alert(str),就可以在执行run后弹出的对话框中看到JSON文本的格式了。很简单的,如果想完美点,还可以写一个js方法做一下验证。

我们这段run方法的目的也就是为了把表单元素的name属性以及内部包含的值以key=value的键值对的形式描述为一段JSON文本。

紧接着,我们来创建一个简单的java值对象,代码示例为:

package entity;

public class formBean {
private String username;
private String password;
private String sex;
private String[] love;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String[] getLove() {
return love;
}
public void setLove(String[] love) {
this.love = love;
}
}




有了JSON文本和需要绑定的java值对象后,那么我们下一步就是要编写另一个jsp页面convertJava.jsp(当然,你也可以使用servlet),用来把这段文本转换成java对象了。

另一页面,如: 代码片段如下:

request.setCharacterEncoding("GBK");
String jsobject = request.getParameter("str");// 这个是jsp页面传过来的对象字符串
JSONObject js = JSONObject.fromObject(jsobject);// 根据字符串转换对象
formBean bean = (formBean) js.toBean(js, formBean.class); // 把值绑定成相应的值对象
// 下面输出bean的值
response.setCharacterEncoding("GBK");
response.setContentType("text/html;charset=gbk");
out.println(bean.getUsername());
out.println(bean.getPassword());
out.println(bean.getSex());
out.println("bean的love属性为一个数组:");
for (String s : bean.getLove()) {
out.println("bean的数组元素:" + s );
}


通过上面的代码片段,可以了解到JSONObject有用的方法是fromObject(JSON文本)[用于讲JSON文本创建一个JSONObject实例]和toBean(带有JSON文本的JSONObject对象,你要绑定的java值对象类型.class)[用于把JSON文本转换成java对象]

至此,你就可以利用这个简单的java值对象了,不再用request的getParameter方法一一获取参数值,然后再使用java值对象的setter方法一一设置属性值这么麻烦了。也许刚开始构造JSON对象文本的时候有一些麻烦,但是这些麻烦对于你来说不过是小菜一碟,对吗?要记住,JSON框架的用法不仅仅于次,这只是冰山一角而已,我们陆续会窥探到其内部。希望大家看完此篇文章后回去做练习,掌握今天的内容,我们下一次再继续学习它的其他部分。

1 条评论: