Struts2 處理AJAX請求

来源:https://www.cnblogs.com/chy18883701161/archive/2019/12/28/12112589.html
-Advertisement-
Play Games

Struts2整合AJAX有2種方式: 使用type="stream"類型的<result> 使用JSON插件 使用type="stream"類型的<result> 獲取text 前端 <body> <form> 學號:<input type="text" id="no"><br /> 姓名:<in ...


 

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包。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Maven是個很好用的依賴管理工具,但是再好的東西也不是完美的。 ...
  • 近期的flink作業中,需要對上傳的日誌數據進行大量的校驗。 校驗規則大多比較簡單,僅為字元串長度,數組長度,數據的最大值和最小值,非空判斷等。然而不想寫諸多校驗代碼,容易導致代碼又醜又繁瑣。聯想SpringBoot項目中的參數校驗,於是想著在純maven的項目中引入校驗。 引入依賴 SpringB ...
  • 垃圾回收與記憶體分配策略 "垃圾回收與記憶體分配策略" "“垃圾”的定義" "對象是否為“垃圾”" "何為“引用” 四種引用類型" "最後的掙扎 finalize()方法" "回收方法區" "垃圾回收演算法" "回收的前置 分代理論" "標記 清除演算法(Mark Sweep)" "標記 複製演算法" "標記 ...
  • 1. 我們打開一個空的IDEA 2. 選擇Java之後點擊Next 3. 點擊Next創建空白工程 4. 給工程取個名字,叫MYIDEA 5. 勾選之後,點擊This Window按鈕 6. 我們可以看到,有了一個MYIDEA的工程 7. 我們在MYIDEA上右鍵新建一個Module 8. 選擇Sp ...
  • 本篇文章我們來講講PHP四大框架的優缺點都有哪些,讓你們在開發中更好的去選擇使用哪款PHP框架去完成項目,廢話不多說,我們一起來看看吧!! ThinkPHP ThinkPHP(FCS)是一個輕量級的中型框架,是從Java的Struts結構移植過來的中文PHP開發框架。它使用面向對象的開髮結構和MVC ...
  • 1、主題 介紹如果通過Pycharm使用本地Git集。 2、準備工作 (1)PyCharm版本為2.7或更高 (2)已經創建一個工程 (3)Git插件可用,對應可執行文件在 Git page頁面正確配置 3、創建一個Git集 按下Alt+`顯示常用的VCS命令(也可以通過主菜單VCS→VCS Ope ...
  • 先看知識點總結 一、序列操作符x in s 如果x是列表s的元素,返回True,否則Falses + t 連接兩個序列s和ts*n或者n*s 將序列s複製n次s[i] 返回s中第i元素s[i:j]或s[i:j: k] 切片,返回序列s中第i到j-1以k為步長的元素子序列12345函數len(s) 返 ...
  • 素描作為一種近乎完美的表現手法有其獨特的魅力,隨著數字技術的發展,素描早已不再是專業繪畫師的專利,今天這篇文章就來講一講如何使用python批量獲取小姐姐素描畫像。文章共分兩部分: 第一部分介紹兩種使用python生成素描畫的思路 第二部分介紹如何批量獲取素描畫 一、獲取素描圖的兩個思路 本部分介紹 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...