- 浏览: 282337 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
-
zhanggang807:
奇葩的 使用方法 ,,还初始化。。。。
velocity 字符串数字转数字 -
July01:
推荐用StratoIO打印控件,浏览器和系统的兼容性都很好,而 ...
JS实现页面打印 -
f309507762:
...
JS实现页面打印 -
wqguanmu:
谢谢,正需要
ExtJS改变默认字体大小的几种方式 -
mszb00123:
很感谢,对我有帮助
ExtJS改变默认字体大小的几种方式
资料:http://clayz.iteye.com/blog/422125
配置中的参数含义:
root参数用于指定要序列化的根对象,如果省去这一配置,表示要序列化action中的所有属性
ignoreHierarchy 为false时表示要序列化根对象的所有基类
excludeProperties表示排除的序列化的属性
includeProperties表示哪些属性被序列化
Action配置:
<!-- jsonplugin的使用配置 -->
<!-- package要继承json-default 以加载json插件 -->
<action name="jsonAct" class="cn.enjoylife.prac.action.JsonAction">
<result type="json">
<!-- root参数用于指定要序列化的根对象,如果省去这一配置,表示要序列化action中的所有属性 -->
<param name="root">map</param>
<!-- ignoreHierarchy 为false时表示要序列化根对象的所有基类 -->
<param name="ignoreHierarchy">false</param>
<!-- 排除hello属性,使其不被序列化 -->
<param name="excludeProperties">hello</param>
</result>
</action>
JsonAction.java:
/**
* @author Evan
*
*/
public class JsonAction extends ActionSupport {
private static final long serialVersionUID = 3870310687165227565L;
private int[] ints = { 100, 200 };
private Map<String, Object> map = new HashMap<String, Object>();
private String hello = "helloWorld";
private String username = "evan";//没有getter方法,不会被序列化
private String password = "pwd";
private String validateCode = "123456";
public int[] getInts() {
return ints;
}
public void setInts(int[] ints) {
this.ints = ints;
}
@JSON(name="newMap")//重新命名
public Map<String, Object> getMap() {
return map;
}
public void setMap(Map<String, Object> map) {
this.map = map;
}
public String getHello() {
return hello;
}
public void setHello(String hello) {
this.hello = hello;
}
public void setUsername(String username) {
this.username = username;
}
@JSON(serialize=true)//这是默认值,可以省去
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@JSON(serialize=false)//serialize参数为false,不会被序列化
public String getValidateCode() {
return validateCode;
}
public void setValidateCode(String validateCode) {
this.validateCode = validateCode;
}
@Override
public String execute() throws Exception {
map.put("info", "今天的雨真大啊!");
return SUCCESS;
}
}
使用jquery操作返回的json串:
$(document).ready(function(){
$.getJSON(
"./jsonAct.action",
function(data){
alert(data.info);
}
);
});
Annotation:
***********************************************************************************
JSON插件提供了一种名为json的ResultType,一旦为某个Action指定了一个类型为json的Result,则该Result无需映射到任何视图资源。将下载到的jsonplugin-0.7.jar文件复制到Web应用的WEB-INF路径下,即可完成JSON插件的安装。 JSON插件提供了一种名为json的ResultType,一旦为某个Action指定了一个类型为json的Result,则该Result无需映射到任何视图资源。因为JSON插件会负责将Action里的状态信息序列化成JSON格式的数据,并将该数据返回给客户端页面的JavaScript。 简单地说,JSON插件允许我们在JavaScript中异步调用Action,而且Action不再需要使用视图资源来显示该Action里的状态信息,而是由JSON插件负责将Action里的状态信息返回给调用页面——通过这种方式,就可以完成Ajax交互。 Struts2提供了一种可插拔方式来管理插件,安装Struts2的JSON插件与安装普通插件并没有太大的区别,一样只需要将Struts2插件的JAR文件复制到Web应用的WEB-INF/lib路径下即可。 安装JSON插件按如下步骤进行: (1)登陆http://code.google.com/p/jsonplugin/downloads/list站点,下载Struts2的JSON插件的最新版本,当前最新版本是0.7,我们可以下载该版本的JSON插件。 (2)将下载到的jsonplugin-0.7.jar文件复制到Web应用的WEB-INF路径下,即可完成JSON插件的安装。 实现Actio逻辑 假设wo,en输入页面中包含了三个表单域,这三个表单域对于三个请求参数,因此应该使用Action来封装这三个请求参数。三个表单域的name分别为field1、field2和field3。 处理该请求的Action类代码如下: public class JSONExample 在上面代码中,使用了JSON注释,注释时指定了name域,name域指定Action属性被序列化成JSON对象的属性名。除此之外,JSON注释还支持如下几个域: serialize:设置是否序列化该属性 deserialize:设置是否反序列化该属性。 format:设置用于格式化输出、解析日期表单域的格式。例如"yyyy-MM-dd'T'HH:mm:ss"。 配置该Action与配置普通Action存在小小的区别,应该为该Action配置类型为json的Result。而这个Result无需配置任何视图资源。 配置该Action的struts.xml文件代码如下: <?xml version="1.0" encoding="GBK"?> 在上面配置文件中有两个值得注意的地方:
Apache提供的一个插件包,可以把 Action中的数据以 JSON做个封装然后返回。 它会将整个 action中的变量转化为 JSON数据 (根对象在 JSON中数据添加一个 ”root”标识 )。如果要使用它, Action必须遵循以下几点: · 返回的页面类型中 ”content-type”必须是 ”application/json”.(这个已经 Internet Community采用 ). · JSON内容必须是符合格式要求的 . · Action中 field必须有 public的 get方法 .(是不是没有 set方法就不会将 field添加到 JSON数据中,有待验证 ).,可以没有set方法 · 它支持的类型有 : 基本类型 (int,long...String), Date, List, Map, Primitive Arrays, 其它 class, 对象数组 . · 在 JSON中任何的 Object会被封装在 list或 map中,数据会被封装程 Long,如果是含有的数据则会被封装程 Double,数组会被封装程 List. 下面给出 JSON的数据格式: Json代码 1. <span style="font-family: arial,helvetica,sans-serif;">{ 2. "doubleValue": 10.10, 3. "nestedBean": { "name": "Mr Bean" }, 4. "list": ["A", 10, 20.20, { "firstName": "El Zorro" }], 5. "array": [10, 20] 6. }</span> 这个插件支持以下几个注释 :
注释名 简介 默认值 序列化 反序列化 name 配置 JSON 中 name empty yes no serialize 在 serialization 中 true yes no deserialize 在 deserialization 中 true no yes format 格式化 Date 字段 "yyyy-MM-dd'T'HH:mm:ss" yes yes 可以通过配置来显示指出要放在 JSON中 field,其中有个自己的验证规则需要研究 . Xml代码 1. <!-- Result fragment --> 2. <result type="json"> 3. <param name="excludeProperties"> 4. login.password, 5. studentList.*".sin 6. </param> 7. </result> 8. 9. <!-- Interceptor fragment --> 10. <interceptor-ref name="json"> 11. <param name="enableSMD">true</param> 12. <param name="excludeProperties"> 13. login.password, 14. studentList.*".sin 15. </param> 16. </interceptor-ref> 根对象 Xml代码 1. <result type="json"> 2. <param name="root"> 3. person.job 4. </param> 5. </result> 也可以使用拦截器配置操作父对象 Xml代码 1. <interceptor-ref name="json"> 2. <param name="root">bean1.bean2</param> 3. </interceptor-ref> 将 JSON数据用注释封装 如果 wrapWithComments 设置为 true( 默认值为 false) ,则生成的 JSON 数据会变成这样 Json代码 1. /* { 2. "doubleVal": 10.10, 3. "nestedBean": { "name": "Mr Bean" }, 4. "list": ["A", 10, 20.20, { "firstName": "El Zorro" }], 5. "array": [10, 20] 6. } */ 这样做可以避免 js中一些潜在的风险,使用时需要 :Var responseObject = eval("("+data.substring(data.indexOf(""/"*")+2, data.lastIndexOf(""*"/"))+")"); 父类 “root”对象中父类的 field不会(会?) 默认存放到 JSON数据中,如果不想这样做,需要在配置时指定 ignoreHierarchy 为 false: Xml代码 1. <result type="json"> 2. <param name="ignoreHierarchy">false</param> 3. </result> 枚举类型 默认处理枚举类型时,会被处理成 JSON数据中 name等于枚举中 value而 value等于枚举中 name. Java代码 1. public enum AnEnum { 2. ValueA, 3. ValueB 4. } JSON: "myEnum":"ValueA" 如果在处理枚举类型时,在 xml中配置了 enumAsBean,则会被当作一个 Bean处理,在 JSON数据中会有一个特别的属性 ”_name”值为 name().这个枚举中的所有属性都会被处理 . Java代码 1. public enum AnEnum { 2. ValueA("A"), 3. ValueB("B"); 4. 5. private String val; 6. 7. public AnEnum(val) { 8. this.val = val; 9. } 10. 11. public getVal() { 12. return val; 13. } 14. } JSON: myEnum: { "_name": "ValueA", "val": "A" } Xml中配置 : Xml代码 1. <result type="json"> 2. <param name="enumAsBean">true</param> 3. </result>
在Struts 2中使用JSON Ajax支持
{
//封装请求参数的三个属性
private String field1;
private transient String field2;
private String field3;
//封装处理结果的属性
private int[] ints = {10, 20};
private Map map = new HashMap();
private String customName = "custom";
//三个请求参数对应的setter和getter方法
public String getField1()
{
return field1;
}
public void setField1(String field1)
{
this.field1 = field1;
}
//此处省略了field1和field2两个字段的setter和getter方法
...
//封装处理结果的属性的setter和getter方法
public int[] getInts()
{
return ints;
}
public void setInts(int[] ints)
{
this.ints = ints;
}
public Map getMap()
{
return map;
}
public void setMap(Map map)
{
this.map = map;
}
//使用注释语法来改变该属性序列化后的属性名
@JSON(name="newName")
public String getCustomName()
{
return this.customName;
}
public String execute()
{
map.put("name", "yeeku");
return Action.SUCCESS;
}
}
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name="struts.i18n.encoding" value="UTF-8"/>
<package name="example" extends="json-default">
<action name="JSONExample" class="lee.JSONExample">
<result type="json"/>
</action>
</package>
</struts>
第一个地方是配置struts.i18n.encoding常量时,不再是使用GBK编码,而是UTF-8编码,这是因为Ajax的POST请求都是以UTF-8的方式进行编码的。
第二个地方是配置包时,自己的包继承了json-default包,而不再继承默认的default包,这是因为只有在该包下才有json类型的Result。
- Jsonplugin.rar (26.8 KB)
- 下载次数: 20
评论
请问这种情况改怎么处理呢?
发表评论
-
m2e离线安装,myeclipse9和eclipse3.6
2013-08-29 09:15 1920详见: http://licoolxue.iteye.c ... -
java方法中可变参数的理解
2013-08-21 11:05 1159收集了一些看法, 尊重别人的劳动成果, 详见: ... -
Java的内省和反射
2013-01-05 19:12 1162原文地址:http://java.chinaitlab.com ... -
js函数的执行环境和作用域链的深入解析
2012-09-14 17:20 1002摘自:http://www.cnblogs.com/retur ... -
CGI与Servlet的比较
2012-05-29 08:59 1812转载自:http://www.maxhis.info/arch ... -
Ext JS 4.1最终版发布 .
2012-05-14 21:03 1665摘自:http://blog.csdn.net/t ... -
优化基于ExtJS 4.1的应用 .
2012-05-14 21:01 1645虽然Sencha在Ext JS 4.1提高了性能,但基于Ext ... -
正则验证字符串左右非空开
2012-04-19 14:04 1259regex : /^\S((\S*$)|(.*\S+$))/ -
Firebug中的console tab使用总结及js
2012-04-06 17:18 1135Firebug一共有Console,HTML,CSS,Scri ... -
JS的Function和Arguments
2012-01-12 11:24 4053javascript的Function属性:1 ... -
js的delete操作
2012-01-11 10:54 1149Js的delete运算符 delete 运算符从对象中删除 ... -
JS实现页面跳转的几种方式
2012-01-10 19:17 19018Javascript刷新页面的几种方法: 1 his ... -
JS中null与undefined的区别
2011-10-28 12:30 1126JS中Null与Undefined的区别 在JavaScri ... -
js中的事件冒泡
2011-10-21 17:51 1313还在整理当中~~~ 1、 <!DOCTYPE htm ... -
Java 基本数据类型数据取值范围
2011-10-17 16:14 1682Java中基本数据类型范围: 序号 类型 位数 ... -
Ant的安装和配置
2011-10-09 10:21 1145******************************* ... -
自己写的Java导出Excel组件
2011-09-13 16:47 1943自己写的,记录下来,方便以后使用。 package org. ... -
JMagick处理图片代码收集
2011-09-07 17:42 7229写在前面的话: 如果要在Web Application ... -
使用JMagick+ImageMagick处理图片
2011-09-07 17:38 2836windows环境的安装 1. 首先给出这个地址:http: ... -
JS返回上一页
2011-09-07 15:44 1614JS返回上一页的方法: 1、 <a href =&q ...
相关推荐
毕业论文-安全跳转页面-整站商业源码.zip
实训商业源码-视频解析-毕业设计.zip
实训商业源码-小小素材库V7.8.45 小程序前端+后端-毕业设计.zip
毕业论文-二刺螈导航-整站商业源码.zip
AI在MES中的应用.pdf
基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例,该项目是个人毕设项目,答辩评审分达到98分,代码都经过调试测试,确保可以运行!欢迎下载使用,可用于小白学习、进阶。该资源主要针对计算机、通信、人工智能、自动化等相关专业的学生、老师或从业者下载使用,亦可作为期末课程设计、课程大作业、毕业设计等。项目整体具有较高的学习借鉴价值!基础能力强的可以在此基础上修改调整,以实现不同的功能。 基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了Cesium的一些基础示例基于Vue 3实现的Cesium大屏可视化项目源代码,展示了
内容概要:该报告由Co.media可美亚发布,基于Amazon平台上的蓝牙音箱产品数据,通过网页工具抓取并清理了772笔交易信息,最终分析了248笔有效数据。报告揭示了评论数高的产品通常售价较高,但低价并非获得高评级的有效手段。高频关键词如“Speaker”、“Bluetooth”、“Smart”、“Wireless”等能显著提升搜索匹配度和销售排名,尤其是前20名产品大多带有这些关键词。此外,价格较低的产品多归类为手机&配件,而价格较高的则归类为电子产品。前50名产品在金额、评论和星数方面具有明显优势,而新产品若想快速进入搜索排名前10,则需重点投入于产品定价和评论星数的提升。 适合人群:希望拓展北美市场的中国品牌企业、从事跨境电商的从业者以及对蓝牙音箱市场感兴趣的投资者。 使用场景及目标:①帮助企业了解蓝牙音箱在北美市场的竞争态势;②指导企业优化产品标题中的关键词选择,以提高搜索排名;③为制定产品定价策略和提升用户评价提供数据支持。 其他说明:Co.media可美亚是一家专注于为中国品牌提供跨境整合营销服务的公司,尤其擅长帮助企业在北美市场建立品牌知名度和竞争力。报告中涉及的数据分析方法包括统计回归分析,用于评估不同因素对搜索排名和销售排名的影响。
基于Go+python实现的网络异常流量检测系统+源码+GUI界面,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用 基于Go+python实现的网络异常流量检测系统+源码+GUI界面,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用~ 基于Go+python实现的网络异常流量检测系统+源码+GUI界面,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用 基于Go+python实现的网络异常流量检测系统+源码+GUI界面,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用 基于Go+python实现的网络异常流量检测系统+源码+GUI界面,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用 基于Go+python实现的网络异常流量检测系统+源码+GUI界面,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用
ANSYS SpaceClaim直接建模技术.pdf
毕业论文-超人配送代驾跑腿小程序V1.5.10 前端+后端-整站商业源码.zip
毕业论文-wx码支付-整站商业源码.zip
实训商业源码-智能AI雷达名片+1.6.7-毕业设计.zip
ANSYS网格划分.pdf
3D变形技术在汽车造型设计中的应用.pdf
ANSYS高级流体动力学培训手册2.pdf
vosk-model-small-cn-022
实训商业源码-视频小店V1.0.7 原版-毕业设计.zip
HR_S30-1800.hard
C++语言任意进制转换(1).zip