傳統Web應用和RESTful API模式

傳統Web應用和RESTful API

傳統模式

傳統模式沒有實現前后端分離,服務器處理完業務后直接返回完整的HTML頁面,每次操作都要刷新整個頁面。類似下面的情況:

@Controller
public class UserController {@RequestMapping("/addUser")public String addUser() {// 處理后返回JSP頁面return "user/add"; // 跳轉到添加用戶頁面}@RequestMapping("/saveUser")public String saveUser(User user) {userService.save(user);return "redirect:/userList"; // 重定向到用戶列表頁面}
}

RESTful API模式

RESTful API模式下,服務器不會返回整個頁面,前后端是分離的,對于作為后端的服務器來說只需要返回數據(通常是JSON格式的)。類似下面的情況:

@RestController
@RequestMapping("/api/users")
public class UserController {@GetMapping // 獲取所有用戶public List<User> getAllUsers() {return userService.findAll();}@PostMapping // 創建新用戶public Result createUser(@RequestBody User user) {userService.save(user);return Result.success("用戶創建成功");}@DeleteMapping("/{id}") // 刪除用戶public Result deleteUser(@PathVariable Long id) {userService.delete(id);return Result.success("用戶刪除成功");}
}

總結

為什么我需要搞清楚這個呢,是由于學習Spring MVC的時候,Spring MVC的執行流程中的DispatcherServlet去解析Controller的返回值這個步驟困惑住了我,如果是RESTful API模式,其實就沒有這個流程,如果是傳統Web模式,就會又這個步驟。

下面是簡化的Spring MVC在兩種模式下的執行流程:

傳統模式執行流程:

1. DispatcherServlet接收請求
2. HandlerMapping找到Controller
3. HandlerAdapter調用Controller方法
4. Controller返回ModelAndView(或字符串)
5. DispatcherServlet調用ViewResolver ← 這一步存在
6. ViewResolver解析視圖名 → 物理視圖
7. 渲染視圖(填充數據)
8. 返回HTML頁面

RESTful模式執行流程:

1. DispatcherServlet接收請求
2. HandlerMapping找到Controller
3. HandlerAdapter調用Controller方法
4. Controller返回數據對象
5. HttpMessageConverter序列化對象 ← 跳過視圖解析
6. 直接返回JSON數據

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/86633.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/86633.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/86633.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JS開發node包并發布流程

開發一個可發布到 npm 的 JavaScript 插件&#xff0c;需要遵循標準的開發、測試、打包和發布流程。以下是詳細步驟指南&#xff1a; 1. 初始化項目 創建項目目錄并初始化 package.json mkdir my-js-plugin cd my-js-plugin npm init -y手動修改 package.json&#xff0c;確保…

對比學習(Contrastive Learning)方法詳解

對比學習&#xff08;Contrastive Learning&#xff09;方法詳解 對比學習&#xff08;Contrastive Learning&#xff09;是一種強大的自監督或弱監督表示學習方法&#xff0c;其核心思想是學習一個嵌入空間&#xff0c;在這個空間中&#xff0c;相似的樣本&#xff08;“正樣…

1.6 http模塊nodejs 對比 go

我們以go語言 原生實現 和瀏覽器交互.到現在學習 nodejs http模塊. nodejs 對于請求分發,也需要我們自己處理. 我們應該也對 http 服務是建立在 tcp協議基礎上.有更深入的體會了吧. 對于我們之后 學習 java web容器. 能有更深入的認知. 請求分發 請求分發是指 Web 框架或服務器…

護照閱讀器在景區的應用

護照閱讀器在景區的應用可以顯著提升游客管理效率、增強安全性并優化游客體驗。以下是其主要應用場景、優勢及實施建議&#xff1a; 一、核心應用場景 快速入園核驗 自動身份識別&#xff1a;通過掃描護照芯片&#xff08;MRZ碼或NFC讀取&#xff09;&#xff0c;1-3秒完成身份…

Prompt Tuning、P-Tuning、Prefix Tuning的區別

一、Prompt Tuning、P-Tuning、Prefix Tuning的區別 1. Prompt Tuning(提示調優) 核心思想:固定預訓練模型參數,僅學習額外的連續提示向量(通常是嵌入層的一部分)。實現方式:在輸入文本前添加可訓練的連續向量(軟提示),模型只更新這些提示參數。優勢:參數量少(僅提…

什么是遙測數據?

遙測數據定義 遙測數據提供了關于系統性能的重要洞察&#xff0c;對主動解決問題和做出明智決策至關重要。要實現這一點&#xff0c;不能只依賴原始數據 —— 你需要實時的洞察&#xff0c;而這正是遙測數據提供的。 遙測是從遠程來源&#xff08;如服務器、應用程序和監控設…

【JavaAPI搜索引擎】項目測試報告

JavaAPI搜索引擎測試報告 項目背景與項目介紹項目功能自動化測試單元測試測試ansj分詞器測試能否獲取到正確的URL測試能否正確解析文件中的正文 測試計劃界面測試測試1 頁面布局是否合理美觀&#xff0c;元素是否正確顯示測試2 測試是否可以正常顯示出搜索結果測試3 點擊搜索結…

如何選擇合適的IP輪換周期

選擇合適的IP輪換周期需綜合業務目標、目標平臺風控規則、IP類型與質量等多維度因素&#xff0c;以下是系統化決策框架及實操建議&#xff1a; &#x1f504; 一、核心決策要素 業務場景類型 高頻操作型&#xff08;如數據采集、廣告點擊&#xff09;&#xff1a; 輪換周期短&a…

GO Goroutine 與并發模型面試題及參考答案

目錄 什么是 Goroutine,它與線程有何區別? 如何創建一個 Goroutine?有哪些方式? Goroutine 執行函數時傳遞參數應注意什么問題? 使用 Goroutine 時如何確保主線程不會提前退出? 多個 Goroutine 寫共享變量時會出現什么問題?如何解決? 如何用 sync.WaitGroup 管理 …

Leetcode-11 2 的冪

Leetcode-11 2 的冪&#xff08;簡單&#xff09; 題目描述思路分析通過代碼&#xff08;python&#xff09; 題目描述 給你一個整數 n&#xff0c;請你判斷該整數是否是 2 的冪次方。如果是&#xff0c;返回 true &#xff1b;否則&#xff0c;返回 false 。 如果存在一個整數…

【Java】【力扣】121.買賣股票的最佳時機

思路 所以后續的每次都是在&#xff1a;1-判斷是否更新最低點 2-如果不需要更新最低點 則計算差值 代碼 class Solution { public int maxProfit(int[] prices) { int minprices[0]; int max0; for (int i 1; i < prices.length; i) { //假設0就是最低點 // 判…

微服務架構下大型商城系統的事務一致性攻堅:Saga、TCC與本地消息表的實戰解析

當用戶在商城完成支付卻看到"訂單異常"提示時&#xff0c;背后往往是分布式事務一致性缺失導致的業務裂縫。在微服務拆分的商城系統中&#xff0c;如何保障跨服務的交易原子性&#xff0c;成為架構設計的生死線。 一、商城分布式事務的典型場景與痛點 在某家電品牌商…

深入理解 Vue.observable:輕量級響應式狀態管理利器

目錄 引言 一、什么是 Vue.observable&#xff1f; 二、為什么需要 Vue.observable&#xff1f;解決什么問題&#xff1f; 三、核心原理&#xff1a;響應式系統如何工作 四、如何使用 Vue.observable 功能說明 技術要點 五、關鍵注意事項與最佳實踐 六、實際應用案例 …

JS設計模式(5): 發布訂閱模式

解鎖JavaScript發布訂閱模式&#xff1a;讓代碼溝通更優雅 在JavaScript的世界里&#xff0c;我們常常會遇到這樣的場景&#xff1a;多個模塊之間需要相互通信&#xff0c;但是又不想讓它們產生過于緊密的耦合。這時候&#xff0c;發布訂閱模式就像一位優雅的信使&#xff0c;…

【電路物聯網】SDN架構與工作原理介紹

(??? )&#xff0c;Hello我是祐言QAQ我的博客主頁&#xff1a;C/C語言&#xff0c;數據結構&#xff0c;Linux基礎&#xff0c;ARM開發板&#xff0c;網絡編程等領域UP&#x1f30d;快上&#x1f698;&#xff0c;一起學習&#xff0c;讓我們成為一個強大的攻城獅&#xff0…

vscode 保存 js 時會自動格式化,取消設置也不好使

vscode 里的設置搜索 Editor: Format On Save 取消勾選 卸載 Prettier - Code formatter 這個插件后好使了&#xff0c;本來以為是插件的問題&#xff0c;后來發現是工作區設置的問題。 因為我是用 GitHub 下載的工程打開后&#xff0c; vscode 認為是工作區了, 因為 .vscode…

xcode中project.pbxproj點開為空白問題

由于需要修改signing里面的配置&#xff0c;點擊了project.pbxproj。但是發現一片空白&#xff0c;如圖 以為是配置文件損壞&#xff0c;郵件show in Finder看了一通后沒看出什么所以然。并且發現entitlement文件、list文件全都是點開為白&#xff0c;并且沒有任何保存 最后發…

JUC并發編程(四)常見模式

目錄 一 同步與協調模式 1 保護性暫停模式 2 順序控制模式 3 生產者消費者模式 4 Balking模式&#xff08;猶豫模式&#xff09; 二 線程管理/生命周期模式 1 兩階段終止模式 一 同步與協調模式 1 保護性暫停模式 一個線程需要等待另一個線程提供特定條件&#xff08;通常是…

Vue 數據代理機制對屬性名的要求

Vue 數據代理機制對屬性名的要求 在 Vue 的數據代理機制中,屬性名需遵循以下關鍵規則: 1. 禁止以 _ 或 $ 開頭 ?? Vue 會跳過代理以 _ 或 $ 開頭的屬性原因:這些前綴被 Vue 保留用于內部屬性(如 _data, _uid, $refs, $el 等)示例:data() {return {count: 1, // ?…

pdf.js在iOS移動端分頁加載優化方案(ios移動端反復刷新加載問題)

背景與問題 在iOS移動端加載大型PDF文件時&#xff0c;由于設備內存限制&#xff0c;經常遇到以下問題&#xff1a; 內存不足導致頁面崩潰大文件加載緩慢頁面反復重新加載 ##解決方案 采用PDF.js的分頁加載策略&#xff0c;實現按需加載當前可視頁面及相鄰頁面&#xff0c;…