Express + Element-ui 實現圖片/文件上傳

使用第三方插件 formidable 處理表單數據/文件

Express 4 以前,我們通常使用 req.files 來對請求中的文件進行處理,但在 Express 4 中這種用法已經被拋棄,默認情況下 req.filesreq 對象上不再可用。官方推薦我們使用第三方中間件。
1136673-20180829091559198-569891639.png
在這里我們使用第三方中間件 formidable,可用于解析表單數據和上傳的文件。以下是基本使用:

var formidable = require('formidable')app.post('/upload', (req, res, next) => {var form = new formidable.IncomingForm()form.parse(req, (err, fields, files) => {if(err) return next(err)console.log(fields) //Object 表單數據console.log(files) //上傳文件用files.<name>訪問res.json({ code: 1, message: 'upload success' })})
})

Element-ui -- upload 上傳組件

前端框架使用Vue2, 以頭像上傳為例。

<el-upload :action="$apiURL + '/upload'" <!--后臺上傳地址--> :data="uploadData" <!--需要傳到后臺的附加數據 我這里把用戶名傳了過去-->:show-file-list="false" :on-success="getAvatarSuccess" <!--上傳成功回調--> :before-upload="beforeAvatarUpload"> <!--上傳前調用的鉤子--> <img :src="$imageURL + avatar" class="avatar" />
</el-upload>
export default {data(){return {avatar: '', //頭像文件名 使用時需要拼接形成完整路徑uploadData: {//使用 vuex 將用戶名放在了 state 中 便于存取name: this.$store.state.username}}},methods: {getAvatarSuccess(res, file) {// res是響應數據 file是文件信息this.avatar = res.avatarconsole.log(res) // 本例中是  { avatar: 'xxx.jpg' }},beforeAvatarUpload(file) {const isJPG = file.type === 'image/jpeg'const isLt2M = file.size / 1024 / 1024 < 2if (!isJPG) {this.$message.error('上傳頭像圖片只能是 JPG 格式!')}if (!isLt2M) {this.$message.error('上傳頭像圖片大小不能超過 2MB!')}//返回 true 時進行請求上傳return isJPG && isLt2M }}
}

Express 中使用 formidable 處理請求做出響應

app.post('/upload', (req, res, next) => {let form = new formidable.IncomingForm()form.encoding = 'utf-8' // 編碼form.keepExtensions = true // 保留擴展名form.uploadDir = path.join(__dirname, '../public/images/') //文件存儲路徑 最后要注意加 '/' 否則會被存在public下form.parse(req, (err, fileds ,files) => { // 解析 formData 數據if(err) return next(err) let username = fileds.name //用戶名 用于修改用戶頭像路徑let oldPath = files.file.path //獲取文件路徑 ~/public/images/<隨機生成的文件名>.<擴展名>let imgname = files.file.name //前臺上傳時的文件名 也就是文件原本的名字let userImgname = imgname.replace(/[^.]+/, username) //把擴展名前的文件名給替換掉//我這里為了方便存儲 統一將文件名改為 <用戶名>.jpglet newPath = path.join(path.dirname(oldPath), userImgname) fs.rename(oldPath, newPath, (err) => {if(err) return next(err)Model.User.updateOne({ name: username },  //更新用戶的avatar屬性{ avatar: userImgname }, err => {if(err) return next(err)res.json({ avatar: userImgname })                     })})})
})

轉載于:https://www.cnblogs.com/qimeng/p/9552275.html

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

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

相關文章

weblogic12.1.3安裝

weblogic weblogic12.1.3安裝 環境&#xff1a; centos7.5 ip: 192.168.0.94 1、安裝jdk 2、安裝 weblogic 下載、解壓安裝包 wls1213_dev.zip unzip /application/weblogic12/wls1213_dev.zip mv wls12130 /application/weblogic12/ 配置環境變量 配置主機名解析 運行安裝…

閉包那些事

定義&#xff1a; 在一個內部函數里&#xff0c; 對在外部作用域&#xff08;但不是在全局作用域&#xff09; 的變量進行引用&#xff0c; 那么內部函數就被認為是閉包&#xff08;closure&#xff09;。 例子&#xff1a; 1 def make_adder(addend):2 def adder(augend):3 …

10-04 矩形覆蓋(斐波那契數列的應用)

題目描述&#xff1a; 我們可以用2*1的小矩形橫著或者豎著去覆蓋更大的矩形。請問用n個2*1的小矩形無重疊地覆蓋一個2*n的大矩形&#xff0c;總共有多少種方法&#xff1f; 解題思路與代碼&#xff1a; 1&#xff09; 排列組合&#xff1a; class Solution { public:int rectC…

Spring 源碼分析 spring-core

先來看下 spring-core 的包結構 總共有6個模塊&#xff0c;分別是 asm、cglib、core、lang、objenesis、util asm包&#xff1a; 用來操作字節碼&#xff0c;動態生成類或者增強既有類的功能。主要包含以下這些類。詳細功能。 https://www.ibm.com/developerworks/cn/java/j…

logging 模塊

一、logging模塊級別及常用函數 默認的level是logging.Warning,低于該級別的就不輸出了。級別排序:Critical> Error > Warning > Info > Debug Logging.Formatter&#xff1a;配置日志的格式&#xff0c;在里面自定義設置日期和時間&#xff0c;輸出日志的時候將會…

大數據項目中的QA需要迎接新的挑戰

大數據項目中的QA需要迎接新的挑戰根據IDC全球半年度大數據和分析支出指南的最新預測&#xff0c;到2022年全球大數據和業務分析解決方案的收入將達到2600億美元。在大數據和業務分析解決方案上投資增長最快的行業包括銀行&#xff08;復合年增長率13.3%&#xff09;、醫療、保…

spring源碼分析之spring-core總結篇

1.spring-core概覽 spring-core是spring框架的基石&#xff0c;它為spring框架提供了基礎的支持。 spring-core從源碼上看&#xff0c;分為6個package&#xff0c;分別是asm&#xff0c;cglib&#xff0c;core&#xff0c;lang&#xff0c;objenesis和util。 1.1 asm 關于as…

五分鐘搞懂后綴數組!

為什么學后綴數組 后綴數組是一個比較強大的處理字符串的算法&#xff0c;是有關字符串的基礎算法&#xff0c;所以必須掌握。 學會后綴自動機(SAM)就不用學后綴數組(SA)了&#xff1f;不&#xff0c;雖然SAM看起來更為強大和全面&#xff0c;但是有些SAM解決不了的問題能被SA解…

spring-core

spring最核心的組件是BeanFactory&#xff0c;看了源碼才發現&#xff0c;BeanFactory并非定義在spring-core中&#xff0c;那spring-core都有啥東東&#xff1f; spring-core主要提供以下服務&#xff0c;為BeanFactory的定義提供基礎服務。 1, ConversionService Conversi…

nginx配置靜態文件過期時間

1. 編輯虛擬主機配置文件/usr/local/nginx/conf/vhosts/huangzhenping.conf 說明&#xff1a;采用location方式 12345678910location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)${access_log off;expires 1d;}location ~ \.(js|css){access_log off;expires 1d;}2. 檢查配置文件&#x…

vue 移動端在div上綁定click事件 失效

在.vue的文件中使用了better-scroll&#xff0c;在div標簽上綁定click事件后&#xff0c;無效。 原因&#xff1a;使用了better-scroll&#xff0c;默認它會阻止touch事件。所以在配置中需要加上click: true 即可解決 mounted(){this.$nextTick(() > {let bscrollDom this.…

Java中的鉤子方法

鉤子方法是啥 鉤子顧名思義就是用來掛東西的。那么要掛東西必須有個被掛的東西&#xff0c;要不就是鐵環、要不就是墻的邊沿。所以要能掛住東西必須要有個被勾住的鐵環&#xff0c;要一個鉤子。那么在java中也是同樣的原理&#xff0c;你首先需要一個被掛在的東西&#xff0c;一…

啟動tomcat出現too many connections的原因及解決方法

感謝分享&#xff0c;原文地址&#xff1a;http://blog.sina.com.cn/s/blog_e7e07ec30102vsba.html一、原因 產生too many connections 的直接原因是因為數據庫提供的連接被全部占滿了。數據庫可以提供多少連接&#xff0c;可以再my.cnf(linux)或者my.ini(windows)下設定。這個…

Spring Beans 初始化流程分析

測試用例 依然使用這個官網上的用例&#xff0c;來進行調試&#xff1b; Person.java package org.shangyang.spring.container;/**- - author shangyang**/public class Person {String name;Person spouse;public String getName() {return name;}public void setName(Stri…

劍指offer(65)矩陣中的路徑

題目描述 請設計一個函數&#xff0c;用來判斷在一個矩陣中是否存在一條包含某字符串所有字符的路徑。路徑可以從矩陣中的任意一個格子開始&#xff0c;每一步可以在矩陣中向左&#xff0c;向右&#xff0c;向上&#xff0c;向下移動一個格子。如果一條路徑經過了矩陣中的某一個…

VSCode中怎么改變文件夾的圖標

昨天更新了VSCode后我的文件夾圖標莫名其妙的沒有了&#xff0c;變成了下圖這樣 看著真的讓我難受的頭皮發麻&#xff0c;本來打代碼就頭發少&#xff0c;難道非要讓我變成禿頭&#xff0c;不可能不可能&#xff0c;所以我找了找怎么解決 來&#xff0c;各位看官上眼 如圖所示 …

jdk1.8以前不建議使用其自帶的Base64來加解密

JDK1.8之前的base64是內部測試使用的代碼&#xff0c;不建議生產環境使用&#xff0c;而且未來可能會移除&#xff0c; JDK1.8提供最新可以正式使用的Base64類&#xff0c; 不要使用JDK中自帶的sun.misc.BASE64Decoder這個類去BASE64&#xff0c; 這個會在后面多加換行。使用ap…

Redis的五大數據類型

1.String&#xff08;字符串&#xff09; String是Redis最基本的類型&#xff0c;一個Key對應一個Value。 String類型是二進制安全的&#xff0c;意思是Redis的String可以包含任何數據&#xff0c;比如jpg圖片或者序列化的對象。 String類型是Redis最基本的數據類型&#xff0c…

springxml解析

1.XML驗證模式的認識 首先XML的驗證模式有兩種&#xff1a;DTD和XSD。 DTD文檔類型定義&#xff0c;是XML約束模式語言。它是為了保證XML文檔格式正確有效的方法。通過XML文檔和DTD文檔的比較來判斷XML是否符合規范。(現在我很少見&#xff0c;不知道是不是淘汰了) 舉個例子&…

jq函數綁定與解綁

最近學到幾個新的jq函數 1、bind&#xff08;&#xff09;綁定函數 2、unbind&#xff08;&#xff09;解綁函數 3、add() .給元素追加字符串 4、addClass() 給某元素增加class屬性值轉載于:https://www.cnblogs.com/bigwang1126/p/9566556.html