首页 使用JSON插件

使用JSON插件

举报
开通vip

使用JSON插件使用JSON插件 14.4  使用JSON插件 14.4.1 JSON基础 JSON(JavaScript Object Natation),它是一种轻量级、基于文本、语言无关的数据交换格式,类似于XML,是一种结构化数据串行化的文本格式,常常用于服务器与JavaScript之间的数据交换上。        JSON是从ECMAScript语言标准衍生而来的,定义了一套简单的格式化规则,JSON可以描述四种简单的类型,包括字符串、数字、布尔值及和null;还可以描述两种结构化类型,包括对象和数组。        当...

使用JSON插件
使用JSON插件 14.4  使用JSON插件 14.4.1 JSON基础 JSON(JavaScript Object Natation),它是一种轻量级、基于文本、语言无关的数据交换格式,类似于XML,是一种结构化数据串行化的文本格式,常常用于服务器与JavaScript之间的数据交换上。        JSON是从ECMAScript语言标准衍生而来的,定义了一套简单的格式化 规则 编码规则下载淘宝规则下载天猫规则下载麻将竞赛规则pdf麻将竞赛规则pdf ,JSON可以描述四种简单的类型,包括字符串、数字、布尔值及和null;还可以描述两种结构化类型,包括对象和数组。        当然,更多JSON具体的语法不是这里关注的重点,有需要的朋友请参见http://json.org/,在那里可以获取更多的JSON的知识。 14.4.2 JSON插件 为了更容易使用JSON,Struts2提供了JSON插件,这个插件提供了名为“json”的ResultType,如果设置某个Result的类型为json,那么JSON插件会把这个Action对象序列化成为一个json格式的字符串,然后再向客户端返回这个字符串。        要使用JSON插件,只需要把struts2-json-plugin-2.1.8.1.jar文件拷贝到WEB-INF/lib里面即可。        JSON插件提供了一些参数,供大家在有需要的时候选用,可以通过他们实现更精确的控制,基本的参数罗列如下: ​ excludeProperties:输出结果需要去除的属性值,支持正则表达式匹配属性名,可以用“,”分割填充多个正则表达式。如下示例代码就表示,user属性里面的password属性不会被序列化输出,代码如下:   java代码: 查看复制到剪贴板打印 1.​    2.​      3.​     user.password   4.​      5.​    includeProperties:输出结果中需要包含的属性值,支持正则表达式和属性名匹配,可以用“,”分割填充多个正则表达式。如下示例就表示输出user的所有属性,代码如下:   java代码: 查看复制到剪贴板打印 1.​    2.​      3.​     user.*   4.​      5.​    root:根据ognl表达式取出你需要输出的结果的根对象,如下示例就表示输出user的name属性的值,代码如下:   java代码: 查看复制到剪贴板打印 1.​    2.​      3.​     user.name   4.​      5.​    ​ excludeNullProperties:表示是否去掉空值, 默认值是false,如果设置为true会自动将为空的值过滤,只输出不为空的值 ​ ignoreHierarchy:表示是否忽略继承关系,默认值是true,也就是在输出的时候不会自动把父级对象序列化并输出。 当然,JSON插件还有很多的参数,这里就不去一一罗列了,有兴趣的朋友请参见https://cwiki.apache.org/confluence/display/WW/JSON%20Plugin,哪里有详尽的参数说明。 14.4.3使用JSON插件来实现Ajax        沿用前面演示Ajax的示例,实现最常见的输入校验的功能,通过Ajax来判断输入的ID是否重复,并给出相应的提示信息。 (1)Action的写法跟以前差不多,示例代码如下:   java代码: 查看复制到剪贴板打印 1.​ public class AjaxAction extends ActionSupport {   2.​     private String account;   3.​     private String password;   4.​     private String msg;   5.​        6.​     public String getAccount() {   7.​         return account;   8.​     }   9.​     public void setAccount(String account) {   10.​         this.account = account;   11.​     }   12.​     public String getPassword() {   13.​         return password;   14.​     }   15.​     public void setPassword(String password) {   16.​         this.password = password;   17.​     }   18.​     public String getMsg() {   19.​         return msg;   20.​     }   21.​     public void setMsg(String msg) {   22.​         this.msg = msg;   23.​     }   24.​    25.​        26.​     public String execute() throws Exception {   27.​         //准备已经注册的数据,测试使用   28.​         Set set = new HashSet();   29.​         set.add("account1");   30.​         set.add("account2");   31.​         set.add("account3");   32.​            33.​         if(set.contains(account)){   34.​             msg = "输入不正确,请重新输入";   35.​         }else{   36.​             msg = "输入正确";   37.​         }          38.​         return this.SUCCESS;   39.​     }   40.​ }   注意:Action的属性需要提供getter/setter方法,不能用public属性的方式进行值的对应,否则JSON插件是不会正确序列化属性值的。 (2)struts.xml的配置有一些变化,首先是不再继承struts-default,而是改为继承json-default;其次result的type要设置为json,示例代码如下:   java代码: 查看复制到剪贴板打印 1.​    2.​            3.​    (3)页面也有一些变化,主要是在获取Action的返回值过后,需要通过eval方法来把json字符串造型成为一个对象,然后把这个对象中的msg属性的值设置到div中显示即可,示例代码如下:   java代码: 查看复制到剪贴板打印 1.​ <%@ page contentType="text/html; charset=gb2312"%>   2.​    3.​    4.​     var myRequest;   5.​     function t1(){   6.​         //准备向后台传输的数据   7.​         var account = document.getElementById("account").value;    8.​         //Ajax   9.​         myRequest = new ActiveXObject("Msxml2.XMLHTTP");   10.​         myRequest.onreadystatechange = t2;   11.​         myRequest.open("GET","ajaxAction.action?account="+account,true);   12.​         myRequest.send(null);   13.​     }      14.​     function t2(){   15.​         if(myRequest.readyState==4){   16.​             var ret = myRequest.responseText;   17.​             //把json造型成对象   18.​             var obj = eval("("+ret+")");               19.​             //后续处理,把对象的msg设置到div中显示出来   20.​             document.all("myDiv").innerHTML = obj.msg;     21.​         }   22.​     }      23.​    24.​    25.​        26.​            27.​             新用户注册   28.​            29.​            30.​                31.​                32.​                33.​            34.​            35.​                36.​                37.​            38.​            39.​                40.​                41.​            42.​            43.​                44.​            45.​     
用户帐号:*
用户密码:
重复密码:
   46.​    去运行看看,效果应该跟前面AJAX演示的效果是一样的。   私塾在线网站原创《研磨struts2》系列 转自请注明出处:【http://sishuok.com/forum/blogPost/list/0/4132.html】 欢迎访问http://sishuok.com获取更多内容
本文档为【使用JSON插件】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_613971
暂无简介~
格式:doc
大小:80KB
软件:Word
页数:5
分类:互联网
上传时间:2014-01-02
浏览量:18