123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- import { getFilemd5sum } from './utils'
-
- const IMAGE_MULTIPART = '/multipart/upload/'
- const VIDEO_MULTIPART = '/upload/'
-
- const IMAGE_TYPE_ERROR = 101
- const VIDOE_TYPE_ERROR = 102
-
- const UPLOAD_SUCCESS_CODE = 200
- const UPLOAD_FAILED_CODE = 400
-
- function FileFactory(file) {
- this.offset = 0; //用于断点续传,默认为 0
- this.BYTES_PER_CHUNK = 1024 * 1024
- this.file = file
- this.fileSize = file.size
- this.fileType = (file.name.split('.')[1]).toLowerCase()
- this.chunkNum = this.BYTES_PER_CHUNK > this.fileSize ? Math.ceil(this.fileSize / this.BYTES_PER_CHUNK):1
- this.chunkSize = this.BYTES_PER_CHUNK > this.fileSize ? this.fileSize:this.BYTES_PER_CHUNK
- }
-
- FileFactory.prototype.setOffset = function(offset) {
- this.offset = offset
- }
-
- export default function UploadSdk(host, origin, token, file) {
-
- this.host = host
- this.origin = origin
- this.token = token
- this.file = file
-
- this.generateMd5 = function (callback) {
- getFilemd5sum(this.file).then(result => {callback(result)})
- }
-
- this.imageUploadAction = function () {
- return new Promise( (resolve, reject) => {
- let fileFactory = new FileFactory(this.file)
- if( !fileFactory.fileType.match('[(jpg)|(png)|(gif)]+$')) {
- reject(IMAGE_TYPE_ERROR)
- }
- this.generateMd5( (md5) => {
- this.md5 = md5
- this.postImage(this.md5,fileFactory).then( res => {
- resolve(res)
- }).catch( (err) => {
- reject(err)
- })
- })
- })
- }
-
- this.videoUploadAction = function () {
- return new Promise( (resolve, reject) => {
- if( !this.file.type.match('[(mp4)|(rmvb)|(flv)|(mpeg)|(avi)]+$')) {
- reject(VIDOE_TYPE_ERROR)
- }
- this.postVideo().then( res => {
- resolve(res)
- }).catch( (err) => {
- reject(err)
- })
- })
- }
-
- this.postVideo = function() {
- return new Promise( (resolve, reject) => {
- let xhr = new XMLHttpRequest()
- xhr.open('POST', 'http:'+this.host+VIDEO_MULTIPART+this.origin, true)
- xhr.withCredentials = true;
- xhr.setRequestHeader('Authorization', `Bearer ${this.token}`)
- xhr.setRequestHeader('Content-type','application/json')
- let fd = new FormData()
- fd.append('file',this.file)
- fd.append('code_rate','ld,sd,hd')
- xhr.send(fd)
- xhr.onreadystatechange = function () {
- if (xhr.readyState === 4) {
- let obj = JSON.parse(xhr.responseText)
- if (xhr.status === 304 || (xhr.status >= 200 && xhr.status < 300)) {
- resolve({
- code: UPLOAD_SUCCESS_CODE,
- url: obj.url,
- msg: 'success'
- })
- } else {
- reject({
- code: UPLOAD_FAILED_CODE,
- url:'',
- msg:obj.message
- })
- }
- }
- }
- })
- }
-
- this.postImage = function(md5,fileFactory) {
- const self = this
- return new Promise((resolve, reject) => {
- let xhr = new XMLHttpRequest()
- xhr.open('POSt', 'http:'+this.host+IMAGE_MULTIPART+this.origin, true)
- xhr.withCredentials = true
- xhr.setRequestHeader('Authorization', `Bearer ${this.token}`)
- xhr.setRequestHeader('X-Upload-File-Size',fileFactory.fileSize)
- xhr.setRequestHeader('X-Upload-Chunk-Index',1+'')
- xhr.setRequestHeader('X-Upload-Chunk-Num',fileFactory.chunkNum)
- xhr.setRequestHeader('X-Upload-Chunk-Size',fileFactory.chunkSize)
- xhr.setRequestHeader('X-Upload-Offset',fileFactory.offset+'')
- xhr.setRequestHeader('X-Upload-File-Md5',md5)
- xhr.setRequestHeader('X-Upload-File-Type',fileFactory.fileType)
- let fd = new FormData()
- fd.append('file',this.file)
- xhr.send(fd)
- xhr.onreadystatechange = function () {
- if (xhr.readyState === 4) {
- let obj = JSON.parse(xhr.responseText)
- if (xhr.status === 304 || (xhr.status >= 200 && xhr.status < 300)) {
-
- if(obj.status === 1) {
- resolve({
- code: UPLOAD_SUCCESS_CODE,
- url: obj.url,
- msg: 'success'
- })
- } else if (obj.status === 0) {
- fileFactory.setOffset(obj.msg)
- this.getAllResponseHeaders.postImage(md5,fileFactory)
- }
- } else {
- reject({
- code: UPLOAD_FAILED_CODE,
- url:'',
- msg: obj.message
- })
- }
- }
- }
- })
- }
- }
|