vue上傳圖片到阿里OSS

有不少同學(xué)在問vue上傳文件到阿里oss的問題蕾哟,我之前也遇到過覆积,現(xiàn)在給同學(xué)們分享一下我的方法

先說明一點,web端上傳的方式有3種:
1徐紧、JavaScript客戶端簽名直傳
2静檬、服務(wù)端簽名后直傳
3、服務(wù)端簽名直傳并設(shè)置上傳回調(diào)
我用的是第二種服務(wù)端簽名后直傳并级,上傳組件是餓了么的Upload 上傳拂檩。

1、服務(wù)端做簽名(這是后端干的嘲碧,如果您是純前端就忽略吧)

let now = new Date()
now = now.setMinutes(now.getMinutes() + config.ALIYUN.get('EXPIRATION')) // 這是您自己定的簽名有效時間(我這里是以分鐘為單位)
let expiration = new Date(now)
var policyText = {
  'expiration': expiration, // 設(shè)置該Policy的失效時間稻励,超過這個失效時間之后,就沒有辦法通過這個policy上傳文件了
  'conditions': [
    ['content-length-range', 0, config.ALIYUN.get('CONTENTLENGTHRANGE')] // 自定義設(shè)置上傳文件的大小限制
  ]
}
var accessid = config.ALIYUN.get('ACCESSKEY') // ACCESSKEY呀潭、SECRETKEY都是阿里云申請的
var accesskey = config.ALIYUN.get('SECRETKEY')
var policyBase64 = Base64.encode(JSON.stringify(policyText)) // 這之后的都是加密和簽名钉迷,Base64用的是js-base64包至非,CryptoJS用的是crypto-js包
var message = policyBase64
var bytes = CryptoJS.HmacSHA1(message, accesskey)
var signature = bytes.toString(CryptoJS.enc.Base64)

this.body = { // 這里就是返回數(shù)據(jù)了
  policy: policyBase64,
  OSSAccessKeyId: accessid,
  signature: signature
}

2钠署、前端獲取簽名

現(xiàn)在剩下的就是前端的工作了,前端先從服務(wù)端獲取簽名荒椭,再上傳圖片谐鼎。
前端從服務(wù)端獲取數(shù)據(jù)的方式很多,比如ajax趣惠、superagent等狸棍,用自己熟悉的吧身害,這里就不說了。直接說說餓了么的上傳組件吧草戈。

<el-upload class="avatar-uploader" :action="uploadHost" accept="image/*" :show-file-list="false" :on-success="handleSuccess" :before-upload="beforeUpload" :data="ossParams">
  
</el-upload>

參數(shù)說明:
action:您創(chuàng)建oss的外網(wǎng)地址
accept:接受的文件類型
on-success:上傳成功的回調(diào)函數(shù)
before-upload:上傳前的回調(diào)函數(shù)塌鸯,可以在這里做文件大小驗證等
data:這里放您從服務(wù)端獲取到的簽名數(shù)據(jù)

核心代碼如下:

// data字段
ossParams: { 
  key: '', // key后面有用,先默認(rèn)設(shè)空字符串
  success_action_status: '200', // 默認(rèn)200
}

// 從服務(wù)端獲取到簽名的處理
let r = await request.get(process.env.OSS_TOKEN)
Object.assign(this.ossParams, r.body)

// 生成隨機字符串
randomString() {
  return (new Date % 9e6).toString(36) + Math.random().toString(36).substring(2, 7)
},

// 上傳成功的回調(diào)
handleSuccess(res, file) {
  this.imageUrl = this.uploadHost + '/' + this.ossParams.key
  console.info(this.imageUrl)
},

// 上傳之前的回調(diào)
beforeUpload(file) {
  const isLt2M = file.size / 1024 / 1024 < 2
  if (!isLt2M) {
    this.$message.error('上傳頭像圖片大小不能超過 2MB!');
  }
  this.ossParams.key = `${this.type}/${this.randomString()}.${file.type.split('/').pop()}`
  return isLt2M;
},

更多詳細(xì)流程及用法請移駕oss文檔唐片、餓了么Upload組件丙猬,感謝您的閱讀。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末费韭,一起剝皮案震驚了整個濱河市茧球,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌星持,老刑警劉巖抢埋,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異督暂,居然都是意外死亡揪垄,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門逻翁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來福侈,“玉大人,你說我怎么就攤上這事卢未》玖荩” “怎么了?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵辽社,是天一觀的道長伟墙。 經(jīng)常有香客問我,道長滴铅,這世上最難降的妖魔是什么戳葵? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮汉匙,結(jié)果婚禮上拱烁,老公的妹妹穿的比我還像新娘。我一直安慰自己噩翠,他們只是感情好戏自,可當(dāng)我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著伤锚,像睡著了一般擅笔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天猛们,我揣著相機與錄音念脯,去河邊找鬼。 笑死弯淘,一個胖子當(dāng)著我的面吹牛绿店,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播庐橙,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼惯吕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了怕午?” 一聲冷哼從身側(cè)響起废登,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎郁惜,沒想到半個月后堡距,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡兆蕉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年羽戒,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片虎韵。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡易稠,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出包蓝,到底是詐尸還是另有隱情驶社,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布测萎,位于F島的核電站亡电,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏硅瞧。R本人自食惡果不足惜份乒,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望腕唧。 院中可真熱鬧或辖,春花似錦、人聲如沸枣接。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽月腋。三九已至蟀架,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間榆骚,已是汗流浹背片拍。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留妓肢,地道東北人捌省。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像碉钠,于是被迫代替她去往敵國和親纲缓。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內(nèi)容