• Struts2 处理AJAX请求


    Struts2整合AJAX有2种方式:

    • 使用type="stream"类型的<result>
    • 使用JSON插件

    使用type="stream"类型的<result>  获取text

    前端

      <body>
      <form>
        学号:<input type="text" id="no"><br />
        姓名:<input type="text" id="name"><br />
        <button type="button" id="btn">查询成绩</button>
      </form>
      <p id="score"></p>
    
      <script src="js/jquery-3.4.1.min.js"></script>
      <script>
        $("#btn").click(function () {
          $.ajax({
            url:"HandlerAction",   
            type:"get",   
            data:{"no":$("#no").val(),"name":$("#name").val()},
            dataType:"text",
            error:function () {
              console.log("ajax请求失败!")
            },
            success:function (data) {
              $("#score").text(data);
            }
          })
        });
      </script>
      </body>

    url要和struts.xml中action的name、包的namespace对应。

    action

    public class HandlerAction extends ActionSupport {
        private int no;
        private String name;
        private InputStream inputStream;
    
        public int getNo() {
            return no;
        }
    
        public void setNo(int no) {
            this.no = no;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public InputStream getInputStream() {
            return inputStream;
        }
    
        public void setInputStream(InputStream inputStream) {
            this.inputStream = inputStream;
        }
    
        @Override
        public String execute() throws Exception {
            //此处缺省连接数据库查询总分
            String result = name + "同学,你的总分是:680";
            //设置要返回的数据。我们传给浏览器的数据含有中文,需要设置utf-8编码,来解决中文乱码
            inputStream=new ByteArrayInputStream(result.getBytes("utf-8"));
            return SUCCESS;
        }
    }

    前端向后台发送了2个字段:no、name

    action需要设置2个同名的成员变量,并提供对应的getter、setter方法,才能接收到前端传来的数据。

    需要一个InputStream类型的成员变量,并提供对应的getter、setter,用于向浏览器返回数据。

    需要一个处理请求的方法(execute),设置返回给浏览器的数据。

    struts.xml

    <struts>
        <package name="action" namespace="/" extends="struts-default">
            <action name="HandlerAction" class="action.HandlerAction">
                <result name="success" type="stream">
                    <!-- 设置返回给浏览器的数据类型 -->
                    <param name="contentType">text/html</param>
                    <!--指定获取InputStream的方法,getInputStream(),约定:去掉get,后面部分使用camel写法 -->
                    <param name="inputName">inputStream</param>
                </result>
            </action>
        </package>
    </struts>

    流程分析

    • 前端向后台发送ajax请求,传递no、name2个字段
    • JVM创建action实例,调用no、name对应的setter方法把前端传过来的值赋给成员变量(会自动转换为目标类型),完成action的初始化
    • JVM调用action处理业务的方法execute,设置向浏览器返回的数据
    • JVM根据struts.xml中<result>指定的方法(getInputStream),获取InputSteam,将里面的数据传给浏览器。

    使用type="stream"类型的<result>  获取json

    前端

     <body>
      <form>
        学号:<input type="text" id="no"><br />
        <button type="button" id="btn">查询学生信息</button>
      </form>
      <div id="show"></div>
    
      <script src="js/jquery-3.4.1.min.js"></script>
      <script>
        $("#btn").click(function () {
          $.ajax({
            url:"HandlerAction",
            type:"post",
            data:{"no":$("#no").val()},
            dataType:"json",
            error:function () {
              console.log("ajax请求失败!")
            },
            success:function (data) {
              $("#show").append("姓名:" + data.name+",");
              $("#show").append("年龄:" + data.age+",");
              $("#show").append("成绩:" + data.score+"。");
            }
          })
        });
      </script>
      </body>

    action

    public class HandlerAction extends ActionSupport {
        private int no;
        private InputStream inputStream;
    
        public int getNo() {
            return no;
        }
    
        public void setNo(int no) {
            this.no = no;
        }
    
        public InputStream getInputStream() {
            return inputStream;
        }
    
        public void setInputStream(InputStream inputStream) {
            this.inputStream = inputStream;
        }
    
        @Override
        public String execute() throws Exception {
            //此处缺省连接数据库查询得到学生信息
            Student student = new Student(1, "张三", 20, 100);
            String jsonStr = JSON.toJSONString(student);
    
            //设置要返回的数据
            inputStream=new ByteArrayInputStream(jsonStr.getBytes("utf-8"));
            return SUCCESS;
        }
    }

    使用了阿里的fastjson.jar,需要自己下载引入。

    struts.xml

    配置同上


    使用JSON插件实现AJAX

    前端

    <body>
      <form>
        学号:<input type="text" id="no"><br />
        <button type="button" id="btn">查询学生信息</button>
      </form>
      <div id="show"></div>
    
      <script src="js/jquery-3.4.1.min.js"></script>
      <script>
        $("#btn").click(function () {
          $.ajax({
            url:"HandlerAction",
            type:"post",
            data:{"no":$("#no").val()},
            dataType:"json",
            error:function () {
              console.log("ajax请求失败!")
            },
            success:function (data) {
              $("#show").append("姓名:" + data.student.name+",");
              $("#show").append("年龄:" + data.student.age+",");
              $("#show").append("成绩:" + data.student.score+"。");
            }
          })
        });
      </script>
      </body>

    action

    public class HandlerAction extends ActionSupport {
        private int no;
        private Student student;
    
        public int getNo() {
            return no;
        }
    
        public void setNo(int no) {
            this.no = no;
        }
    
        public Student getStudent() {
            return student;
        }
    
        public void setStudent(Student student) {
            this.student = student;
        }
    
        @Override
        public String execute() throws Exception {
            //此处缺省连接数据库查询得到学生信息
            student = new Student(1, "张三", 20, 100);
            return SUCCESS;
        }
    }

    需要设置同名的成员变量,并提供getter、setter方法,来接收前端传来的数据。

    此种方式是由JSON插件把action对象序列化为一个JSON格式的字符串,传给浏览器。浏览器可以直接访问action的所有成员变量(实质是调用对应的getter方法)。

    我们只需要把ajax要请求的数据封装为action的成员变量,并提供对应的getter、setter方法。需要在主调方法(execute)的return语句之前对请求的数据赋值。

    success:function (data) {
              $("#show").append("姓名:" + data.student.name+",");
              $("#show").append("年龄:" + data.student.age+",");
              $("#show").append("成绩:" + data.student.score+"。");
    }

    浏览器接受到的数据data本身就是action实例,可通过.访问成员变量。

    struts.xml

    <struts>
        <package name="example" namespace="/" extends="json-default">
            <action name="HandlerAction" class="action.HandlerAction">
                <!--type="json"的result,可以缺省name属性,当然写上也行-->
                <result type="json">
                    <param name="noCache">true</param>
                    <!-- 设置返回给浏览器的数据类型 -->
                    <param name="contentType">text/html</param>
                </result>
            </action>
        </package>
    </struts>

     json-default包继承了struts-default包的配置,所以不必再继承struts-default。

    说明

    需要手动添加JSON插件 struts2-json-plugin.jar 。

    上面的压缩包含有struts的所有jar包,其中就包括了struts2-json-plugin.jar。

    下面的压缩包只有struts核心的8个jar包。

  • 相关阅读:
    基本的数据库操作类
    GridView 导出Excle
    VS2005 调试时断点无效的小问题
    TSQL日期相关
    Data Access Application Block 利用DataSet 操作DB
    vs2005 字体和颜色加载包失败,无法修改的问题
    GridView 编辑和删除的实现
    operamasksui之omGrid简单使用
    ANT简明教程
    ANT从入门到精通
  • 原文地址:https://www.cnblogs.com/chy18883701161/p/12112589.html
Copyright © 2020-2023  润新知