若依前后端分離版本-前后端交互整理

ruoyi-ui與后端交互

方法一:表單

使用 headers: {'Content-Type':'application/x-www-form-urlencoded'},

ruoyi-ui的vue中

//ruoyi-ui的vue中定義
formData: {a: '111',b: '111',c: 1,},
//vue中方法調用              
outBound() { ?          empty(this.formData).then(response => {})
},

ruoyi-ui的api中

???????//ruoyi-ui中js中api
export function empty(data) {const encodedData = qs.stringify(data);return request({url: '/A/info/empty',method: 'post',data: encodedData,headers: {'Content-Type':'application/x-www-form-urlencoded'},})
}

controller方法?


//controller中方法
@RequestMapping("/A/info")
~~~@PreAuthorize("@ss.hasPermi('A:info:remove')")@PostMapping("/empty")public AjaxResult empty( String a, String b, Integer c) {return aInfoService.empty(a, b, c);}

方法二:json

axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8'

ruoyi-ui的vue中

//ruoyi-ui的vue中定義
formData: {a: '111',b: '111',c: 1,},
//vue中方法調用				
outBound() {   			empty(this.formData.a,this.formData.b,this.formData.c).then(response => {})
},

?ruoyi-ui的api中

//ruoyi-ui中js中api
export function empty(a,b,c) {return request({url: '/A/info/empty/'+a+'/'+b+'/'+c,method: 'post',})
}

?controller方法?

   //controller中方法
@RequestMapping("/A/info")@PostMapping("/empty/{a}/{b}/{c}")public AjaxResult empty( @PathVariable String a, @PathVariable String b, @PathVariable Integer c) {return aInfoService.empty(a, b, c);}

ruoyi-app與后端交互

方法一:表單

ruoyi-app的vue中

//ruoyi-app的vue中定義
formData: {a: '111',b: '111',c: 1,},
//vue中方法調用				
outBound() {   			empty(this.formData).then(response => {})
},

ruoyi-app的api中?

//ruoyi-app的js中api
export function empty(data) {return request({url: '/A/info/empty',method: 'post',data: data,header : {"Content-Type":"application/x-www-form-urlencoded"}})
}

?controller中

//controller中方法
@RequestMapping("/A/info")
~~~@PreAuthorize("@ss.hasPermi('A:info:remove')")@PostMapping("/empty")public AjaxResult empty( String a, String b, Integer c) {return aInfoService.empty(a, b, c);}

方法二:json-同ui前后端交互

如果想要ruoyi-ui的前后端表單交互與ruoyi-app使用前后端表單交互相同,需要對request.js進行修改

修改ruoyi-ui的request.js

方法一:axios請求配置中提供了transformRequest方法用于發送前修改請求數據

請求配置 | Axios中文文檔 | Axios中文網 (axios-http.cn)

創建axios實例后,添加
// 新增
// `transformRequest` 允許在向服務器發送前,修改請求數據
// 它只能用于 'PUT', 'POST' 和 'PATCH' 這幾個請求方法
// 數組中最后一個函數必須返回一個字符串, 一個Buffer實例,ArrayBuffer,FormData,或 Stream
service.defaults.transformRequest = [function (data, headers){if (headers['Content-Type'] === 'application/x-www-form-urlencoded') {return typeof data === 'object' ? qs.stringify(data) : data;}if (headers['Content-Type'].includes("application/json")) {return typeof data === 'object' ? JSON.stringify(data) : data;}return data
}]

方法二:request攔截器中添加,用于修改config.data值

import qs from 'qs'
// 【如果是表單類型,判斷一下數據是不是對象,如果是對象,則序列化,如果不是對象則直接返回,如果不是表單則直接返回】
//qs.stringify會將對象序列化為 key1=value1&key2=value2&key3=value3形式
config.data = config.headers['Content-Type'] === "application/x-www-form-urlencoded" ?(typeof config.data === 'object' ? qs.stringify(config.data) : config.data) : config.data;

小白一枚,可能有不對的地方~

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

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

相關文章

6款網頁表白代碼6(附帶源碼)

6款網頁表白代碼6 前言效果圖及部分源碼1.愛心倒計時2.一起看星星3.愛心4.愛心(有鼠標移動特效)5.愛心(高級效果)6.愛心(3D效果) 領取源碼下期更新預報 前言 大部分人都有喜歡的人,學會這些表白…

藍橋杯物聯網競賽_STM32L071KBU6_關于sizo of函數產生的BUG

首先現象是我在用LORA發送信息的時候,左邊顯示長度是8而右邊接收到的數據長度卻是4 我以為是OLED顯示屏壞了,又或者是我想搞創新用了const char* 類型強制轉換數據的原因,結果發現都不是 void Function_SendMsg( unsigned char* data){unsi…

微軟Edge

微軟Edge瀏覽器概述 功能介紹 微軟Edge是一款基于Chromium開源項目的網頁瀏覽器,旨在提供更快的網頁加載速度、更高的安全性和更好的用戶體驗。它支持多種操作系統,包括Windows、macOS、Android和iOS,能夠滿足不同用戶的需求。Edge瀏覽器擁…

趕緊收藏!2024 年最常見 20道 Redis面試題(三)

上一篇地址:趕緊收藏!2024 年最常見 20道 Redis面試題(二)-CSDN博客 五、Redis的持久化機制是什么? Redis 是一個高性能的鍵值存儲系統,支持多種類型的數據結構,如字符串、哈希、列表、集合、…

python數據類型之字符串

目錄 1.字符串概念和注意事項 2.字符串內置函數 3.字符串的索引、切片和遍歷 4.字符串運算符 5.字符串常用方法 性質判斷 開頭結尾判斷 是否存在某個子串 大小寫等格式轉化 子串替換 刪除兩端空白字符 格式化字符串 分割與合并 6.字符串模板 7.exec 函數 8.字符…

【Linux】-Zookeeper安裝部署[17]

簡介 apache ZooKeeper是一個分布式的,開放源碼的分布式應用程序協調服務,是Hadoop和Hbase的重要組件。它是一個為分布式應用提供一致性服務的軟件,提供的功能包括:配置維護、域名服務、分布式同步、組服務等。 除了為Hadoop和H…

2024最新 Jenkins + Docker 實戰教程(四) - 編寫自己的Springboot項目實現自動化部署

😄 19年之后由于某些原因斷更了三年,23年重新揚帆起航,推出更多優質博文,希望大家多多支持~ 🌷 古之立大事者,不惟有超世之才,亦必有堅忍不拔之志 🎐 個人CSND主頁——Mi…

VMware Num Lock 總自動切換的問題解決

VMware Num Lock 總自動切換的問題解決 0. 問題描述1. 解決方法 0. 問題描述 使用 VMware 虛擬機時,鼠標在 VMware 和主機之間切換時,總是顯示 “Num Lock 開” 和 “Num Lock 關” 的提示框。 1. 解決方法 在 VMware 系統中,按 fn num 統…

0407放大電路的頻率響應

放大電路的頻率響應 單時間常數RC電路的頻率響應中頻響應高頻響應低頻響應全頻域響應 放大電路頻率響應概述1. 直接耦合放大電路頻域響應阻容耦合放大電路頻域響應 4.7.1 單時間常數RC電路的頻率響應 4.7.2 放大電路頻率響應概述 4.7.3 單級共射極放大電路的頻率響應 4.7.4 單級…

TOSHIBA UTLH21 屬于Unifi NV系列

TOSHIBA UTLH21 是東芝推出的一款工業控制器,屬于Unifi NV系列。 這款控制器代表了東芝在工業自動化領域的一次重要進步,它在功能和性能上都超越了現有的V系列控制器。以下是UTLH21的一些主要特點: 高速邏輯與控制能力:UTLH21具…

Spring框架中獲取方法參數名稱:DefaultParameterNameDiscoverer

DefaultParameterNameDiscoverer 是Spring框架中用于獲取方法參數名稱的一個類。在Java中,方法的參數名稱通常在編譯時會丟失,因為Java字節碼并不強制要求保留這些信息。Spring提供了一種機制來恢復這些參數名稱,這就是通過DefaultParameterN…

IT行業的現狀與未來趨勢

這里寫目錄標題 一、引言二、IT行業的現狀三、IT行業面臨的挑戰四、IT行業的未來趨勢五、結論 一、引言 信息技術(IT)行業在過去幾十年中經歷了飛速發展,從早期的計算機硬件和軟件開發,到如今涵蓋云計算、人工智能、大數據、物聯…

深度學習之基于Django+Tensorflow卷積神經網絡實時口罩檢測系統

歡迎大家點贊、收藏、關注、評論啦 ,由于篇幅有限,只展示了部分核心代碼。 文章目錄 一項目簡介 二、功能三、系統四. 總結 一項目簡介 一、項目背景 隨著全球疫情的持續,佩戴口罩成為了公眾日常生活中不可或缺的一部分。特別是在人員密集的…

【python】python社交交友平臺系統設計與實現(源碼+數據庫)【獨一無二】

👉博__主👈:米碼收割機 👉技__能👈:C/Python語言 👉公眾號👈:測試開發自動化【獲取源碼商業合作】 👉榮__譽👈:阿里云博客專家博主、5…

BEVFuison測試全過程記錄

cuda版本10.1 pytorch: 根據cuda版本選擇pytorch版本: 1. 創建conda虛擬環境: conda create -y --name mmcv python3.8 conda activate mmcv2. 安裝依賴庫: pytorch: conda install pytorch1.7.1 torchvision0.8.2 torchaudi…

智能代理四大范式解析

Agent四大范式 在2024年紅杉資本人工智能峰會上,著名的人工智能專家吳恩達發表了一場備受關注的演講,深入探討了智能代理(agent)的四大范式。這四大范式代表了當前AI技術在不同應用領域中的核心方法和實踐,分別是反思(Reflection)、工具使用(Tool Use)、規劃(Planni…

特征融合篇 | YOLOv8改進之引入輕量級跨尺度特征融合模塊CCFM | 源自RT-DETR

前言:Hello大家好,我是小哥談。CCFM(Cross-Scale Feature Fusion Module)即為跨尺度特征融合模塊。這個模塊的作用是將不同尺度的特征通過融合操作整合起來,以增強模型對于尺度變化的適應性和對小尺度對象的檢測能力。CCFM可以有效地整合細節特征和上下文信息,從而提高模…

2024定制版搶單支付系統源碼(開代理自動搶單接單)

隨著網絡和移動支付技術的不斷進步,搶單支付系統已經成為商家和用戶進行交易的便利工具。2024定制版搶單支付系統源碼為開發者提供了一個可定制化的解決方案,具備開放代理和自動搶單接單功能,幫助用戶快速搭建搶單支付平臺。本文將為您介紹這…

專題匯編 | ChatGPT引領AIGC新浪潮(一)

ChatGPT的產生與迭代 2022年11月末,美國人工智能研究實驗室OpenAI推出ChatGPT。上線的ChatGPT只用了2個月,活躍用戶數就突破了1億,創造了應用增速最快的紀錄。 ChatGPT是什么 ChatGPT是一種人工智能技術驅動的自然語言處理(Natural Language Processing,NLP)工具,使用的…

20240520金融讀報:旅游強國金融數據要素升級融資性貿易房地產政策變化

1、房地產政策變化:1)刺激買方:降首付,公積金貸款利率下調0.25%,商貸貸款利率不設下限 2)托底賣方:“白名單”貸款項目,覆蓋項目建成交付的資金缺口 3)增加賣方&#xff…