码迷,mamicode.com
首页 > Web开发 > 详细

struts2 + jquery + json 简单的前后台信息交互

时间:2015-06-16 12:19:29      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:

ajax 是一种客户端与服务器端异步请求的交互技术。相比同步请求,大大提高了信息交互的速度和效率。是当下非常实用和流行的技术。

这里简单的说明 struts2 + jquery + json 下的 信息传递。

1 . 首先创建一个 静态页面 ,然后在 脚本中 写一个 ajax 方法如下:

$.ajax({
            type : "get" , 
            url : "ajax/ajax?time="+Math.random() , 
            datatype : "json" , 
            success : function(data){
                var json = $.parseJSON(data);
                mydiv.innerHTML = data.name;
            } , error : function(data){
                alert(data.status);
            }
        })

2 . 后台的 action 方法如下:

        private String result;

        public String getResult() {
        return result;
    }
    public void setResult(String result) {
        this.result = result;
    }

        public String execute() throws Exception{
                JSONObject jsonObj = new JSONObject();
                jsonObj.put("name", "james");
        this.setResult(jsonObj.toString());
        return SUCCESS;
    }        

3 . 然后在 struts.xml 文件中 配置 action 的 result属性:

<package name="ajax" namespace="/ajax" extends="json-default">
        <action name="ajax" class="org.java.action.AjaxAction" method="execute">
            <result type="json">  /* 注意 result 的 type 属性为 json */
                <param name="excludeNullProperties">true</param>  /* 将存入对象中的 null 值过滤掉 */
            </result>
        </action>
    </package>

其中需要导入一个名叫:struts2-json-plugin-2.3.4.jar 的 jar 包,其中的 package 所扩展的包 ==》json-default 就是从这个 jar 包中 继承的。导入该 jar 包到项目中之后,还将该 jar 包下的 struts-plugin.xml 文件中一个 包名叫 json-default 的包,拷贝到你的 struts.xml 文件中,这样就实现了在 struts2中使用jquery的 ajax 方法,将数据封装成 json 对象进行 前后台的 信息交互了。

json-default 的包信息如下:

<!-- 处理 ajax 请求 json 数据格式的包 -->
    <package name="json-default" extends="struts-default">
        <result-types>
            <result-type name="json" class="org.apache.struts2.json.JSONResult"/>
        </result-types>

        <interceptors>
            <interceptor name="json" class="org.apache.struts2.json.JSONInterceptor"/>
            <interceptor name="jsonValidation" class="org.apache.struts2.json.JSONValidationInterceptor"/>
            <!-- Sample JSON validation stack -->
            <interceptor-stack name="jsonValidationWorkflowStack">
                <interceptor-ref name="basicStack"/>
                <interceptor-ref name="validation">
                    <param name="excludeMethods">input,back,cancel</param>
                </interceptor-ref>
                <interceptor-ref name="jsonValidation"/>
                <interceptor-ref name="workflow"/>
            </interceptor-stack>
        </interceptors>
    </package>

 

struts2 + jquery + json 简单的前后台信息交互

标签:

原文地址:http://www.cnblogs.com/xiaowang1/p/4580111.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!