uniapp中uploadFile的用法

基本語法

uni.uploadFile(OBJECT)

OBJECT?是一個包含上傳相關配置的對象,常見參數如下:

參數類型必填說明
urlString開發者服務器地址。
filePathString要上傳文件資源的本地路徑。
nameString文件對應的 key,開發者在服務端可以通過這個 key 獲取文件的二進制內容。
headerObjectHTTP 請求 Header,Header 中不能設置 Referer。
formDataObjectHTTP 請求中其他額外的 form data。
successFunction接口調用成功的回調函數。
failFunction接口調用失敗的回調函數。
completeFunction接口調用結束的回調函數(調用成功、失敗都會執行)。

使用示例

前端代碼(uni-app)

以下代碼實現了從本地選擇圖片并上傳到服務器的功能。

// 選擇圖片并上傳
uni.chooseImage({count: 1,success: function (res) {const tempFilePaths = res.tempFilePaths;uni.uploadFile({url: 'https://example.com/upload', // 替換為實際的后端接口地址filePath: tempFilePaths[0],name: 'file',header: {'Authorization': 'Bearer your_token'},formData: {'key1': 'value1','key2': 'value2'},success: function (uploadRes) {console.log('上傳成功', uploadRes.data);},fail: function (err) {console.log('上傳失敗', err);}});}
});
代碼解釋
  1. 選擇圖片:使用?uni.chooseImage?方法從本地相冊選擇一張圖片,獲取其臨時文件路徑。
  2. 上傳文件:調用?uni.uploadFile?方法,將選擇的圖片上傳到指定的服務器地址。
    • url:指定后端服務器的接口地址。
    • filePath:圖片的臨時文件路徑。
    • name:文件在表單中的字段名,后端通過該字段名獲取文件。
    • header:設置請求頭,可用于身份驗證等。
    • formData:傳遞額外的表單數據。
后端代碼示例(Node.js + Express + multer)
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.Map;@RestController
@RequestMapping("/api")
public class FileUploadController {@PostMapping(value = "/upload", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)public ResponseEntity<String> uploadFile(@RequestParam("file") MultipartFile file,@RequestHeader("Authorization") String authorization,@RequestParam Map<String, String> formData) {if (file.isEmpty()) {return ResponseEntity.badRequest().body("文件為空,請選擇文件上傳");}try {// 共享文件夾路徑String sharedFolderPath = "/mydata/app/doc/shouqian_file/";// 獲取文件名String fileName = file.getOriginalFilename();// 構建目標文件路徑Path targetPath = Paths.get(sharedFolderPath, fileName);// 創建共享文件夾(如果不存在)File sharedFolder = new File(sharedFolderPath);if (!sharedFolder.exists()) {if (!sharedFolder.mkdirs()) {return ResponseEntity.status(500).body("無法創建共享文件夾");}}// 將文件保存到共享文件夾Files.write(targetPath, file.getBytes());// 打印讀取到的請求頭和表單數據System.out.println("Authorization: " + authorization);System.out.println("Form Data: " + formData);return ResponseEntity.ok("文件上傳成功");} catch (IOException e) {e.printStackTrace();return ResponseEntity.status(500).body("文件上傳失敗:" + e.getMessage());}}
}
代碼解釋
  • @RestController:表明這是一個 RESTful 風格的控制器。
  • @PostMapping:指定處理 POST 請求的路徑為?/api/upload,并且指定請求的內容類型為?multipart/form-data
  • @RequestParam("file") MultipartFile file:用于接收上傳的文件。
  • @RequestHeader("Authorization") String authorization:從請求頭中獲取?Authorization?字段的值。
  • @RequestParam Map<String, String> formData:以鍵值對的形式接收前端傳遞的?formData

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

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

相關文章

Android設計模式之責任鏈模式

一、定義&#xff1a; 使多個對象都有機會處理請求&#xff0c;從而避免了請求的發送者和接收者之間的耦合關系將這些對象連城一條鏈&#xff0c;并沿著這條鏈傳遞該請求&#xff0c;只到有對象處理它為止。 二、模式結構&#xff1a; 抽象處理者&#xff08;Handler&#xff…

Oracle數據庫數據編程SQL<3.3 PL/SQL 游標>

游標(Cursor)是Oracle數據庫中用于處理查詢結果集的重要機制&#xff0c;它允許開發者逐行處理SQL語句返回的數據。 目錄 一、游標基本概念 1. 游標定義 2. 游標分類 二、靜態游標 &#xff08;一&#xff09;顯式游標 【一】不帶參數&#xff0c;普通的顯示游標 1. 顯式…

逗萬DareWorks|創意重構書寫美學,引領新潮無界的文創革命

當傳統文具陷入同質化泥潭時&#xff0c;逗萬DareWorks品牌猶如一顆璀璨的明星&#xff0c;以其獨特的創意理念和卓越的產品品質&#xff0c;迅速贏得了廣大消費者的青睞。 逗萬DareWorks隸屬于東莞司貿文教贈品有限公司&#xff0c;后者深耕制筆行業45年&#xff0c;占地4.6萬…

寫Prompt的技巧和基本原則

一.基本原則 1.一定要描述清晰你需要大模型做的事情&#xff0c;不要模棱兩可 2.告訴大模型需要它做什么&#xff0c;不需要做什么 改寫前: 請幫我推薦一些電影 改寫后: 請幫我推薦2025年新出的10部評分比較高的喜劇電影&#xff0c;不要問我個人喜好等其他問題&#xff…

【React】基于 React+Tailwind 的 EmojiPicker 選擇器組件

1.背景 React 寫一個 EmojiPicker 組件&#xff0c;基于 emoji-mart 組件二次封裝。支持添加自定義背景 、Emoji 圖標選擇&#xff01;并在頁面上展示&#xff01; 2.技術棧 emoji-mart/data 、emoji-mart : emoji 圖標庫、元數據 tailwindcss: 原子化 CSS 樣式庫 antd : 組…

Qt中繪制不規則控件

在Qt中繪制不規則控件可通過設置遮罩&#xff08;Mask&#xff09;實現。以下是詳細步驟: ?繼承目標控件?&#xff1a;如QPushButton或QWidget。?重寫resizeEvent?&#xff1a;當控件大小變化時&#xff0c;更新遮罩形狀。?創建遮罩區域?&#xff1a;使用QRegion或QPain…

Parallel_Scheduling_of_DAGs_under_Memory_Constraints論文閱讀

內存約束下的 DAG 并行調度 點擊閱讀原文語雀鏈接更清晰 摘要 科學工作流通常被建模為任務的有向無環圖&#xff08;DAG&#xff09;&#xff0c;這些任務代表計算模塊及其依賴關系&#xff0c;依賴關系表現為任務生成的數據被其他任務使用。這種形式化方法允許使用運行時系統&…

探索MVC、MVP、MVVM和DDD架構在不同編程語言中的實現差異

MVC與MVP/MVVM/DDD架構對比&#xff0c;不同語言實現 MVC 分層架構設計概述 模型-視圖-控制器&#xff08;Model-View-Controller&#xff0c;簡稱 MVC&#xff09;是一種經典軟件架構設計&#xff0c;通過分層解耦&#xff0c;使得系統結構清晰和易于維護&#xff0c;具有良…

一文讀懂 UML:基礎概念與體系框架

UML 圖是一種標準化的建模語言&#xff0c;在軟件開發和系統設計等領域有著廣泛的應用。以下是對 UML 圖各類圖的詳細介紹&#xff1a; 1.用例圖 定義&#xff1a;用例圖是從用戶角度描述系統功能的模型圖&#xff0c;展現了系統的參與者與用例之間的關系。作用&#xff1a;幫…

Spring 及 Spring Boot 條件化注解(15個)完整列表及示例

Spring 及 Spring Boot 條件化注解完整列表及示例 1. 所有條件化注解列表 Spring 和 Spring Boot 提供了以下條件化注解&#xff08;共 15 個&#xff09;&#xff0c;用于在配置類或方法上實現條件化注冊 Bean 或配置&#xff1a; 注解名稱作用來源框架Conditional自定義條件…

【Kafka】深入探討 Kafka 如何保證一致性

文章目錄 Kafka 基本概念回顧?副本角色? 數據寫入一致性?同步副本&#xff08;ISR&#xff09;集合?數據讀取一致性?故障處理與一致性恢復?總結? 在分布式系統領域&#xff0c;數據一致性是至關重要的一環。作為一款高性能的分布式消息隊列系統&#xff0c;Kafka 在設計…

從入門到精通:SQL注入防御與攻防實戰——紅隊如何突破,藍隊如何應對!

引言&#xff1a;為什么SQL注入攻擊依然如此強大&#xff1f; SQL注入&#xff08;SQL Injection&#xff09;是最古老且最常見的Web應用漏洞之一。盡管很多公司和組織都已經采取了WAF、防火墻、數據庫隔離等防護措施&#xff0c;但SQL注入依然在許多情況下能夠突破防線&#…

【算法day27】有效的數獨——請你判斷一個 9 x 9 的數獨是否有效。只需要 根據以下規則 ,驗證已經填入的數字是否有效即可。

36. 有效的數獨 請你判斷一個 9 x 9 的數獨是否有效。只需要 根據以下規則 &#xff0c;驗證已經填入的數字是否有效即可。 數字 1-9 在每一行只能出現一次。 數字 1-9 在每一列只能出現一次。 數字 1-9 在每一個以粗實線分隔的 3x3 宮內只能出現一次。&#xff08;請參考示例…

leetcode 2360. 圖中的最長環 困難

給你一個 n 個節點的 有向圖 &#xff0c;節點編號為 0 到 n - 1 &#xff0c;其中每個節點 至多 有一條出邊。 圖用一個大小為 n 下標從 0 開始的數組 edges 表示&#xff0c;節點 i 到節點 edges[i] 之間有一條有向邊。如果節點 i 沒有出邊&#xff0c;那么 edges[i] -1 。…

PySpur: AI 智能體可視化開發平臺

GitHub&#xff1a;https://github.com/PySpur-Dev/pyspur 更多AI開源軟件&#xff1a;發現分享好用的AI工具、AI開源軟件、AI模型、AI變現 - 小眾AI PySpur是一個開源的輕量級可視化AI智能體工作流構建器&#xff0c;旨在簡化AI系統的開發流程。通過拖拽式界面&#xff0c;用戶…

vcpkg安裝及使用教程,以安裝matio庫解析mat文件為例

vcpkg安裝及使用教程,以安裝matio庫解析mat文件為例 1. vcpkg安裝2 安裝matio三方庫3 將三方庫集成到VS中3.1 全局集成3.2 集成到特定工程4 結語Vcpkg 是微軟開發的一款開源的 C/C++ 包管理工具,旨在簡化 C/C++ 項目依賴庫的安裝和管理。它支持跨平臺(Windows、Linux、macO…

LLM架構解析:NLP基礎(第一部分)—— 模型、核心技術與發展歷程全解析

本專欄深入探究從循環神經網絡&#xff08;RNN&#xff09;到Transformer等自然語言處理&#xff08;NLP&#xff09;模型的架構&#xff0c;以及基于這些模型構建的應用程序。 本系列文章內容&#xff1a; NLP自然語言處理基礎&#xff08;本文&#xff09;詞嵌入&#xff0…

【Rtklib入門指南】2. 使用RTKLIB GUI進行觀測數據分析

數據準備 下載2025年1月1日的香港CORS站數據和觀測星歷&#xff0c;詳情參照如下博客&#xff1a; 使用GAMP_GOOD進行hk數據下載教程-CSDN博客 分析工具 RTKLIB 2.4.3 demo5&#xff08;也可以選用RTKLIB2.4.2&#xff0c;但不建議使用RTKLIB2.4.3&#xff09; 分析流程 …

suse15 sp1使用華為云軟件源yum源zypper源

登錄suse15終端&#xff0c; cd /etc/zypp/repos.d/進入目錄后執行以下命令&#xff1a; zypper ar -fcg https://mirrors.huaweicloud.com/opensuse/distribution/leap/15.1/repo/oss HuaWeiCloud:15.1:OSS zypper ar -fcg https://mirrors.huaweicloud.com/opensuse/distribu…

首屏加載時間優化解決

&#x1f916; 作者簡介&#xff1a;水煮白菜王&#xff08;juejin/csdn同名&#xff09; &#xff0c;一位前端勸退師 &#x1f47b; &#x1f440; 文章專欄&#xff1a; 高德AMap專欄 &#xff0c;記錄一下平時學習在博客寫作中記錄&#xff0c;總結出的一些開發技巧?。 感…