6 changed files with 478 additions and 11 deletions
			
			
		- 
					8.env.development
- 
					6src/api/material/material.js
- 
					105src/views/components/upload_img.vue
- 
					161src/views/components/upload_img2.vue
- 
					187src/views/components/upload_img3.vue
- 
					22src/views/materialContent/materialList/index.vue
| @ -0,0 +1,105 @@ | |||||
|  | <template> | ||||
|  |   <!-- upload --> | ||||
|  |   <div class="upload"> | ||||
|  |     <el-upload | ||||
|  |       class="avatar-uploader" | ||||
|  |       :action="domain" | ||||
|  |       :http-request="upqiniu" | ||||
|  |       :show-file-list="false" | ||||
|  |       :before-upload="beforeUpload" | ||||
|  |     > | ||||
|  |       <img v-if="imageUrl" :src="imageUrl" class="avatar" /> | ||||
|  |       <i v-else class="el-icon-plus avatar-uploader-icon"></i> | ||||
|  |     </el-upload> | ||||
|  |   </div> | ||||
|  | </template> | ||||
|  | <script> | ||||
|  | import axios from 'axios' | ||||
|  | import { getQiniuToken } from '@/api/material/material' | ||||
|  | export default { | ||||
|  |   data() { | ||||
|  |     return { | ||||
|  |       imageUrl: '', | ||||
|  |       token: {}, | ||||
|  |       // 七牛云的上传地址,根据自己所在地区选择,我这里是华南区 | ||||
|  |       domain: 'https://upload.qiniup.com/', | ||||
|  |       // 这是七牛云空间的外链默认域名 | ||||
|  |       qiniuaddr: 'qiniu.aiyxlib.com' | ||||
|  |     } | ||||
|  |   }, | ||||
|  |   methods: { | ||||
|  |     // 上传文件到七牛云 | ||||
|  |     upqiniu(req) { | ||||
|  |       console.log(req) | ||||
|  |       const config = { | ||||
|  |         headers: { 'Content-Type': 'multipart/form-data' } | ||||
|  |       } | ||||
|  |       let filetype = '' | ||||
|  |       if (req.file.type === 'image/png') { | ||||
|  |         filetype = 'png' | ||||
|  |       } else { | ||||
|  |         filetype = 'jpg' | ||||
|  |       } | ||||
|  |       // 重命名要上传的文件 | ||||
|  |       const keyname = 'material' + Math.random() * 100 + '.' + filetype | ||||
|  |       // 从后端获取上传凭证token | ||||
|  |       getQiniuToken().then(res => { | ||||
|  |         console.log(res) | ||||
|  |         const formdata = new FormData() | ||||
|  |         formdata.append('file', req.file) | ||||
|  |         formdata.append('token', res.data) | ||||
|  |         formdata.append('key', keyname) | ||||
|  |         // 获取到凭证之后再将文件上传到七牛云空间 | ||||
|  |         axios.post(this.domain, formdata, config).then(res => { | ||||
|  |           this.imageUrl = 'http://' + this.qiniuaddr + '/' + res.data.key | ||||
|  |           console.log(this.imageUrl) | ||||
|  |         }) | ||||
|  |       }) | ||||
|  |       // this.axios.get('/up/token').then(res => { | ||||
|  | 
 | ||||
|  |       // }) | ||||
|  |     }, | ||||
|  |     // 验证文件合法性 | ||||
|  |     beforeUpload(file) { | ||||
|  |       const isJPG = file.type === 'image/jpeg' || file.type === 'image/png' | ||||
|  |       const isLt2M = file.size / 1024 / 1024 < 10 | ||||
|  |       if (!isJPG) { | ||||
|  |         this.$message.error('上传头像图片只能是 JPG 格式!') | ||||
|  |       } | ||||
|  |       if (!isLt2M) { | ||||
|  |         this.$message.error('上传头像图片大小不能超过 10MB!') | ||||
|  |       } | ||||
|  |       return isJPG && isLt2M | ||||
|  |     } | ||||
|  |   } | ||||
|  | } | ||||
|  | </script> | ||||
|  | <style scoped> | ||||
|  | .upload { | ||||
|  |   width: 600px; | ||||
|  |   margin: 0 auto; | ||||
|  | } | ||||
|  | .avatar-uploader .el-upload { | ||||
|  |   border: 5px dashed #ca1717 !important; | ||||
|  |   border-radius: 6px; | ||||
|  |   cursor: pointer; | ||||
|  |   position: relative; | ||||
|  |   overflow: hidden; | ||||
|  | } | ||||
|  | .avatar-uploader .el-upload:hover { | ||||
|  |   border-color: #409EFF; | ||||
|  | } | ||||
|  | .avatar-uploader-icon { | ||||
|  |   font-size: 28px; | ||||
|  |   color: #8c939d; | ||||
|  |   width: 178px; | ||||
|  |   height: 178px; | ||||
|  |   line-height: 178px; | ||||
|  |   text-align: center; | ||||
|  | } | ||||
|  | .avatar { | ||||
|  |   width: 178px; | ||||
|  |   height: 178px; | ||||
|  |   display: block; | ||||
|  | } | ||||
|  | </style> | ||||
| @ -0,0 +1,161 @@ | |||||
|  | <template> | ||||
|  |   <div id="mef-m-authentication-apply"> | ||||
|  |     <div class="apply-upload-item fr noMb"> | ||||
|  |       <div class="photo-upload item-03" :class="{uploaded: userWorkPhoto}" @click="photoUpload('userWorkPhoto')"> | ||||
|  |         <img :src="userWorkPhoto" onerror="this.src=''" class="fit-cover-img" /> | ||||
|  |         <span v-if="userWorkPhoto" class="delete-icon" @click.stop="clearPhotoUrl('userWorkPhoto')"></span> | ||||
|  |       </div> | ||||
|  |     </div> | ||||
|  |   </div> | ||||
|  | </template> | ||||
|  | 
 | ||||
|  | <script> | ||||
|  | /* function getQiniuToken() { | ||||
|  |   return Promise.resolve({'uptoken': 'xxx'}); | ||||
|  | } */ | ||||
|  | 
 | ||||
|  | // c39eAF6CRLXTPcOp7YZWN47QG-R8GMdJwBtBQ1Eb:vQEKW6kSJvaMFOD6G0Fj1toohjE=:eyJzY29wZSI6ImFpeXVleGluZzoiLCJkZWFkbGluZSI6MTY0NzU3NjY4N30= | ||||
|  | 
 | ||||
|  | /* c39eAF6CRLXTPcOp7YZWN47QG-R8GMdJwBtBQ1Eb:MZKUih1U9m0jKz57RwADJw02a9U=:eyJwZXJzaXN0ZW50UGlwZWxpbmUiOiJhaXl4bGliX3ZpZGVvLXBpcGUiLCJzY29wZSI6ImFpeXVleGluZyIsInBlcnNpc3RlbnRPcHMiOiJhdnRodW1iL20zdTgvbm9Eb21haW4vMS9zZWd0aW1lLzE1L3ZiLzQ0MGsvaGxzS2V5L2Z0em4xOWFpeXhsaWIyMDEvaGxzS2V5VXJsL2h0dHBzOi8vcWluaXUuYWl5eGxpYi5jb20vYWl4eWxpYndvcmQua2V5fHNhdmVhcy8iLCJkZWFkbGluZSI6MTY0NzU3NjcxOX0=*/ | ||||
|  | import { getQiniuToken } from '@/api/material/material' | ||||
|  | export default { | ||||
|  |   name: 'Upload', | ||||
|  |   data() { | ||||
|  |     return { | ||||
|  |       userWorkPhoto: '' | ||||
|  |     } | ||||
|  |   }, | ||||
|  |   mounted() { | ||||
|  | 
 | ||||
|  |   }, | ||||
|  |   methods: { | ||||
|  |     clearPhotoUrl(urlName) { | ||||
|  |       this[urlName] = '' | ||||
|  |     }, | ||||
|  |     photoUpload(type) { | ||||
|  |       const ipt = document.createElement('input') | ||||
|  |       ipt.setAttribute('type', 'file') | ||||
|  |       ipt.setAttribute('accept', 'image/*') | ||||
|  |       ipt.style.width = 0 | ||||
|  |       ipt.style.height = 0 | ||||
|  |       ipt.addEventListener('change', async() => { | ||||
|  |         const [file] = ipt.files | ||||
|  |         const base64Img = await this.fileToBase64(file) | ||||
|  |         const url = await this.uploadBase64(base64Img) | ||||
|  |         this.userWorkPhoto = url | ||||
|  |         document.body.removeChild(ipt) | ||||
|  |       }) | ||||
|  |       document.body.appendChild(ipt) | ||||
|  |       ipt.click() | ||||
|  |     }, | ||||
|  |     uploadBase64(base64Img) { | ||||
|  |       return new Promise((resolve) => { | ||||
|  |         getQiniuToken() | ||||
|  |           .then(res => { | ||||
|  |             const key = 'qiniu.aiyxlib.com' + this.uuid() + '.jpg' | ||||
|  |             const pic = base64Img.split(',')[1] | ||||
|  |             // const url = 'https://upload.qiniup.com/' + window.btoa(key) // 非华东空间需要根据注意事项 1 修改上传域名 | ||||
|  |             const url = 'https://upload.qiniup.com/' // 非华东空间需要根据注意事项 1 修改上传域名 | ||||
|  |             const xhr = new XMLHttpRequest() | ||||
|  |             xhr.onreadystatechange = () => { | ||||
|  |               if (xhr.readyState == 4) { | ||||
|  |                 resolve( | ||||
|  |                   'qiniu.aiyxlib.com' + JSON.parse(xhr.responseText).key | ||||
|  |                 ) | ||||
|  |               } | ||||
|  |             } | ||||
|  |             xhr.open('POST', url, true) | ||||
|  |             xhr.setRequestHeader('Content-Type', 'application/octet-stream') | ||||
|  |             xhr.setRequestHeader('Authorization', 'UpToken ' + res.data) | ||||
|  |             xhr.send(pic) | ||||
|  |             // 获取到凭证之后再将文件上传到七牛云空间 | ||||
|  |           }) | ||||
|  |           .catch(console.error) | ||||
|  |       }) | ||||
|  |     }, | ||||
|  |     fileToBase64(file) { | ||||
|  |       return new Promise((resolve) => { | ||||
|  |         const reader = new FileReader() | ||||
|  |         // 传入一个参数对象即可得到基于该参数对象的文本内容 | ||||
|  |         reader.readAsDataURL(file) | ||||
|  |         reader.onload = function(e) { | ||||
|  |           // target.result 该属性表示目标对象的DataURL | ||||
|  |           resolve(e.target.result) | ||||
|  |         } | ||||
|  |       }) | ||||
|  |     }, | ||||
|  |     uuid(len, radix) { | ||||
|  |       const chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('') | ||||
|  |       const uuid = [] | ||||
|  |       let i | ||||
|  |       radix = radix || chars.length | ||||
|  |       if (len) { | ||||
|  |         for (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random() * radix] | ||||
|  |       } else { | ||||
|  |         let r | ||||
|  |         uuid[8] = uuid[13] = uuid[18] = uuid[23] = '' | ||||
|  |         uuid[14] = '4' | ||||
|  |         for (i = 0; i < 36; i++) { | ||||
|  |           if (!uuid[i]) { | ||||
|  |             r = 0 | Math.random() * 16 | ||||
|  |             uuid[i] = chars[i == 19 ? r & 0x3 | 0x8 : r] | ||||
|  |           } | ||||
|  |         } | ||||
|  |       } | ||||
|  |       return uuid.join('') | ||||
|  |     } | ||||
|  |   } | ||||
|  | } | ||||
|  | </script> | ||||
|  | <style lang="scss" scoped> | ||||
|  |   #mef-m-authentication-apply{ | ||||
|  |     .apply-upload-item{ | ||||
|  |       width: 132px; | ||||
|  |       margin-bottom: 30px; | ||||
|  |       text-align: center; | ||||
|  |       &.noMb{ | ||||
|  |         margin-bottom: 0; | ||||
|  |       } | ||||
|  |       .photo-upload { | ||||
|  |         width: 132px; | ||||
|  |         height: 96px; | ||||
|  |         position: relative; | ||||
|  |         margin-bottom: 10px; | ||||
|  |         &.item-03{ | ||||
|  |           // background: top / 100% url(~@/assets/images/authentication/upload_workCard.png) | ||||
|  |           // no-repeat; | ||||
|  |         } | ||||
|  |         &.uploaded{ | ||||
|  |           background: none; | ||||
|  |         } | ||||
|  |         img{ | ||||
|  |           width: 85px; | ||||
|  |           height: 85px; | ||||
|  |           position: absolute; | ||||
|  |           left: 50%; | ||||
|  |           top: 50%; | ||||
|  |           transform: translate(-50%,-50%); | ||||
|  |         } | ||||
|  |         .delete-icon{ | ||||
|  |           width: 16px; | ||||
|  |           height: 16px; | ||||
|  |           // background: top / 100% url(~@/assets/images/common/icon-del.png) | ||||
|  |           //   no-repeat; | ||||
|  |           border-radius: 0; | ||||
|  |           top: -8px; | ||||
|  |           right: -8px; | ||||
|  |           position: absolute; | ||||
|  |           i { | ||||
|  |             display: none; | ||||
|  |           } | ||||
|  |         } | ||||
|  |       } | ||||
|  |       .apply-name{ | ||||
|  |         font-size: 14px; | ||||
|  |         font-weight: bold; | ||||
|  |         padding-top: 10px; | ||||
|  |         text-align: center; | ||||
|  |       } | ||||
|  |     } | ||||
|  |   } | ||||
|  | </style> | ||||
| @ -0,0 +1,187 @@ | |||||
|  | <template> | ||||
|  |   <div class="upload"> | ||||
|  |     <div id="video_container"> | ||||
|  |       <div id="pickfiles">上传视频</div> | ||||
|  |       <div> | ||||
|  |         <div class="upload_info"> | ||||
|  |           <b>共{{ fileSize }}MB | 已上传{{ fileLoaded }} | 上传速度{{ fileSpeed }}/s</b> | ||||
|  |         </div> | ||||
|  |         <div> | ||||
|  |           <b>上传进度:{{ filePercent }}%</b> | ||||
|  |         </div> | ||||
|  |         <button @click="pauseUpload">暂停上传</button> | ||||
|  |         <button @click="continueUpload">继续上传</button> | ||||
|  |       </div> | ||||
|  |     </div> | ||||
|  |     <div v-if="coverPic" class="cover-pic"> | ||||
|  |       <img :src="coverPic" alt="" /> | ||||
|  |     </div> | ||||
|  |   </div> | ||||
|  | </template> | ||||
|  | 
 | ||||
|  | <script> | ||||
|  | // import { apis, chttp } from '@/libs/interfaces' | ||||
|  | import * as qiniu from 'qiniu-js' | ||||
|  | export default { | ||||
|  |   data() { | ||||
|  |     return { | ||||
|  |       fileSize: 0, | ||||
|  |       fileLoaded: 0, | ||||
|  |       fileSpeed: 0, | ||||
|  |       filePercent: 0, | ||||
|  |       uploader: null, | ||||
|  |       token: '', | ||||
|  |       filename: '', | ||||
|  |       hash: '', | ||||
|  |       resFileName: '', | ||||
|  |       coverPic: '', | ||||
|  |       phoneType: null | ||||
|  |     } | ||||
|  |   }, | ||||
|  |   mounted() { | ||||
|  |     this.phoneType = this.getPhoneType() | ||||
|  |     this.getToken(() => { | ||||
|  |       this.initUploader() | ||||
|  |     }) | ||||
|  |   }, | ||||
|  |   methods: { | ||||
|  |     pauseUpload() { | ||||
|  |       this.uploader.stop() | ||||
|  |     }, | ||||
|  |     continueUpload() { | ||||
|  |       this.uploader.start() | ||||
|  |     }, | ||||
|  |     toDecimal(size) { | ||||
|  |       size = size / 1024 / 1024 | ||||
|  |       var f = parseFloat(size) | ||||
|  |       if (isNaN(f)) { | ||||
|  |         return | ||||
|  |       } | ||||
|  |       f = Math.round(size * 10) / 10 | ||||
|  |       var s = f.toString() | ||||
|  |       var rs = s.indexOf('.') | ||||
|  |       if (rs < 0) { | ||||
|  |         rs = s.length | ||||
|  |         s += '.' | ||||
|  |       } | ||||
|  |       while (s.length <= rs + 1) { | ||||
|  |         s += '0' | ||||
|  |       } | ||||
|  |       return s | ||||
|  |     }, | ||||
|  |     initUploader() { | ||||
|  |       const plupload = window.plupload | ||||
|  |       const Qiniu = global.Qiniu | ||||
|  |       const _this = this | ||||
|  |       // domain为七牛空间对应的域名,选择某个空间后,可通过 空间设置->基本设置->域名设置 查看获取 | ||||
|  |       const isIphone5 = this.phoneType === '5' | ||||
|  |       // uploader为一个plupload对象,继承了所有plupload的方法 | ||||
|  |       this.uploader = Qiniu.uploader({ | ||||
|  |         runtimes: 'html5,flash,html4', // 上传模式,依次退化 | ||||
|  |         browse_button: 'pickfiles', // 上传选择的点选按钮,必需 | ||||
|  |         uptoken: this.token, // uptoken是上传凭证,由其他程序生成 | ||||
|  |         get_new_uptoken: true, // 设置上传文件的时候是否每次都重新获取新的uptoken | ||||
|  |         bucket_name: 'common-web', // 空间名 | ||||
|  |         unique_names: false, // 默认false,key为文件名。若开启该选项,JS-SDK会为每个文件自动生成key(文件名) | ||||
|  |         save_key: false, // 默认false。若在服务端生成uptoken的上传策略中指定了sava_key,则开启,SDK在前端将不对key进行任何处理 | ||||
|  |         domain: 'https://upload.qiniup.com/', // bucket domain eg:http://qiniu-plupload.qiniudn.com/ | ||||
|  |         container: 'video_container', // 上传区域DOM ID,默认是browser_button的父元素 | ||||
|  |         max_file_size: '10mb', // 最大文件体积限制 | ||||
|  |         dragdrop: false, // 开启可拖曳上传 | ||||
|  |         drop_element: 'video_container', // 拖曳上传区域元素的ID,拖曳文件或文件夹后可触发上传 | ||||
|  |         chunk_size: '4mb', // 分块上传时,每块的体积 | ||||
|  |         max_retries: 3, // 上传失败最大重试次数 | ||||
|  |         auto_start: true, // 选择文件后自动上传,若关闭需要自己绑定事件触发上传 | ||||
|  |         multi_selection: !isIphone5, | ||||
|  |         init: { | ||||
|  |           Key: function(up, files) { | ||||
|  |             return _this.filename | ||||
|  |           }, | ||||
|  |           FilesAdded: function(up, files) { | ||||
|  |             plupload.each(files, function(file) { | ||||
|  |               // 文件添加进队列后,处理相关的事情 | ||||
|  |               console.log('FilesAdded') | ||||
|  |               _this.fileSize = _this.toDecimal(file.size) | ||||
|  |             }) | ||||
|  |           }, | ||||
|  |           BeforeUpload: function(up, file) { | ||||
|  |             console.log('BeforeUpload') | ||||
|  |           }, | ||||
|  |           ChunkUploaded: function(up, file, info) { | ||||
|  |             console.log('ChunkUploaded') | ||||
|  |           }, | ||||
|  |           UploadProgress: function(up, file) { | ||||
|  |             // 每个文件上传时,处理相关的事情 | ||||
|  |             _this.filePercent = parseInt(file.percent) | ||||
|  |             _this.fileLoaded = plupload.formatSize(file.loaded).toUpperCase() | ||||
|  |             _this.fileSpeed = plupload.formatSize(file.speed).toUpperCase() | ||||
|  |           }, | ||||
|  |           FileUploaded: function(up, file, info) { | ||||
|  |             console.log('FileUploaded') | ||||
|  |             const response = JSON.parse(info.response) | ||||
|  |             _this.hash = response.hash | ||||
|  |             _this.resFileName = response.key | ||||
|  |             _this.coverPic = 'qiniu.aiyxlib.com' + response.key + '?vframe/png/offset/7/w/480' | ||||
|  |           }, | ||||
|  |           Error: function(up, err, errTip) { | ||||
|  |             // 上传出错时,处理相关的事情 | ||||
|  |             _this.$toast('Error =') | ||||
|  |             _this.$toast(err) | ||||
|  |             _this.$toast('errTip =') | ||||
|  |             _this.$toast(errTip) | ||||
|  |           }, | ||||
|  |           UploadComplete: function() { | ||||
|  |             // 队列文件处理完毕后,处理相关的事情 | ||||
|  |             _this.$toast('UploadComplete') | ||||
|  |           } | ||||
|  |         } | ||||
|  |       }) | ||||
|  |     }, | ||||
|  |     getToken(callback) { | ||||
|  |       this.filename = 'webvideo/' + new Date().getTime() + '.mp4' | ||||
|  |       const params = { | ||||
|  |         filename: this.filename | ||||
|  |       } | ||||
|  |       chttp.get(apis.qiniuToken, { params: params }) | ||||
|  |         .then(res => { | ||||
|  |           this.token = res.token | ||||
|  |           callback() | ||||
|  |         }) | ||||
|  |     }, | ||||
|  |     getPhoneType() { | ||||
|  |       // 正则,忽略大小写 | ||||
|  |       var patternPhone = new RegExp('iphone', 'i') | ||||
|  |       var patternAndroid = new RegExp('Android', 'i') | ||||
|  |       var userAgent = navigator.userAgent.toLowerCase() | ||||
|  |       var isAndroid = patternAndroid.test(userAgent) | ||||
|  |       var isIphone = patternPhone.test(userAgent) | ||||
|  |       var phoneType = 'phoneType' | ||||
|  |       if (isAndroid) { | ||||
|  |         var zhCnIndex = userAgent.indexOf('-') | ||||
|  |         var spaceIndex = userAgent.indexOf('build', zhCnIndex + 4) | ||||
|  |         var fullResult = userAgent.substring(zhCnIndex, spaceIndex) | ||||
|  |         phoneType = fullResult.split('')[1] | ||||
|  |       } else if (isIphone) { | ||||
|  |         // 6   w=375    6plus w=414   5s w=320     5 w=320 | ||||
|  |         var wigth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth | ||||
|  |         if (wigth > 400) { | ||||
|  |           phoneType = 'iphone6 plus' | ||||
|  |         } else if (wigth > 370) { | ||||
|  |           phoneType = 'iphone6' | ||||
|  |         } else if (wigth > 315) { | ||||
|  |           phoneType = '5' | ||||
|  |         } else { | ||||
|  |           phoneType = 'iphone 4s' | ||||
|  |         } | ||||
|  |       } else { | ||||
|  |         phoneType = '您的设备太先进了' | ||||
|  |       } | ||||
|  |       return phoneType | ||||
|  |     } | ||||
|  |   } | ||||
|  | } | ||||
|  | </script> | ||||
|  | 
 | ||||
|  | <style lang="scss" scoped> | ||||
|  | </style> | ||||
|  | 
 | ||||
						Write
						Preview
					
					
					Loading…
					
					Cancel
						Save
					
		Reference in new issue