科技知識動態:javascript - 上傳失敗 token not specified

導讀 跟大家講解下有關javascript - 上傳失敗 token not specified,相信小伙伴們對這個話題應該也很關注吧,現在就為小伙伴們說說javascri

跟大家講解下有關javascript - 上傳失敗 token not specified,相信小伙伴們對這個話題應該也很關注吧,現在就為小伙伴們說說javascript - 上傳失敗 token not specified,小編也收集到了有關javascript - 上傳失敗 token not specified的相關資料,希望大家看到了會喜歡。

同樣的代碼在www.a.com 下上傳正常在www.b.com 下,相同的代碼,通過www.a.com 拿到token 上傳報錯 error:"token not specified

uptoken_func 下uptoken 返回了空值之后才被 ajax 回調過來的數據賦值,所以上傳的時候 token 為空

var qiniu_up = qiniu.uploader({ runtimes : 'html5,flash,html4', browse_button : 'qiniu_browse', get_new_uptoken: true, unique_names: false, save_key : true, domain : '', container : 'container', max_file_size: '4mb', flash_swf_url : '', silverlight_xap_url : '', max_retries: 1, dragdrop: false, drop_element : 'container', chunk_size : '4mb', auto_start: false, multi_selection: false, filters : { mime_types : [{title : 'Image files', extensions : 'jpg,jpeg,gif,png,bmp'},{title : 'Voice files', extensions : 'mp3,wav'}] }, init : { }, uptoken_func: function(file){ var uptoken = ''; var media_info = '[{"directory":"1","directory_class":"","up_file_name":"'+file.name+'","media_type":"1"}]'; $.ajax({ type :"post", async : false, url : '', data : { app_version : '1.0', app_target : 3, sdk_version : '1.0', plat : 'other', media_info : media_info }, dataType :"jsonp", jsonp:"jsonpCallback", success : function(data){ if(data.code == '1') { var list = data.data.uptoken_list; uptoken = list[0]['uptoken']; media_id = list[0]['media_id']; } else { alert(data.message); } }, error : function(XMLHttpRequest, textStatus, errorThrown){ } }); return uptoken; } });

回復內容:

同樣的代碼在www.a.com 下上傳正常在www.b.com 下,相同的代碼,通過www.a.com 拿到token 上傳報錯 error:"token not specified

uptoken_func 下uptoken 返回了空值之后才被 ajax 回調過來的數據賦值,所以上傳的時候 token 為空

var qiniu_up = qiniu.uploader({ runtimes : 'html5,flash,html4', browse_button : 'qiniu_browse', get_new_uptoken: true, unique_names: false, save_key : true, domain : '', container : 'container', max_file_size: '4mb', flash_swf_url : '', silverlight_xap_url : '', max_retries: 1, dragdrop: false, drop_element : 'container', chunk_size : '4mb', auto_start: false, multi_selection: false, filters : { mime_types : [{title : 'Image files', extensions : 'jpg,jpeg,gif,png,bmp'},{title : 'Voice files', extensions : 'mp3,wav'}] }, init : { }, uptoken_func: function(file){ var uptoken = ''; var media_info = '[{"directory":"1","directory_class":"","up_file_name":"'+file.name+'","media_type":"1"}]'; $.ajax({ type :"post", async : false, url : '', data : { app_version : '1.0', app_target : 3, sdk_version : '1.0', plat : 'other', media_info : media_info }, dataType :"jsonp", jsonp:"jsonpCallback", success : function(data){ if(data.code == '1') { var list = data.data.uptoken_list; uptoken = list[0]['uptoken']; media_id = list[0]['media_id']; } else { alert(data.message); } }, error : function(XMLHttpRequest, textStatus, errorThrown){ } }); return uptoken; } });

看樓主的代碼 好像是往七牛CDN上面上傳文件token的問題 樓主可以看看是不是JS跨域問題 你也可以看看七牛的開發文檔 或者 聯系七牛的技術人員聯調一下

uptoken_func 下的ajax 跨域了以后他的運行順序變了 所有的程序都執行完了才執行到success 下的uptoken 的被賦值,所以上傳上去的uptoken 為空

來源:php中文網

免責聲明:本文由用戶上傳,如有侵權請聯系刪除!