説明なし
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

article_media_edit.htm 42KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837
  1. <style>
  2. .url-box_sys .layui-btn:focus
  3. {
  4. color: #fff;
  5. }
  6. </style>
  7. <div class="item-from-row">
  8. <div class="from-row-l">
  9. 视频上传:
  10. </div>
  11. <div class="from-row-r">
  12. <a href="javascript:void(0);" onclick="addUrlSys();" class="el-button el-button--primary el-button--small">新增</a>
  13. <textarea name="video" id="video" cols="30" rows="10" style="display: none;"></textarea>
  14. <table class="layui-table">
  15. <thead>
  16. <tr>
  17. <th>链接地址</th>
  18. <th>选集名称</th>
  19. <th style="text-align: center;">时长(秒)</th>
  20. <th style="text-align: center;">操作</th>
  21. <th style="text-align: center;">试看</th>
  22. </tr>
  23. </thead>
  24. <tbody id="url-box_sys" class="url-box_sys" style="padding: 10px 0" >
  25. </tbody>
  26. </table>
  27. </div>
  28. </div>
  29. <div class="item-from-row">
  30. <div class="from-row-l">
  31. 附件地址:
  32. </div>
  33. <div class="from-row-r">
  34. <input type="text" name="addonFieldExt[courseware]" value="{$ArchivesData.courseware|default=''}" id="addonFieldExt_courseware" class="input-txt">
  35. <input type="file" id="courseware_file" data-type='local' onchange="upload_file_courseware_1585641738(this)" style="display: none;">
  36. {if isset($channelRow.data.qiniuyun_open) && $channelRow.data.qiniuyun_open == 1}
  37. &nbsp;<a href="javascript:void(0);" class="el-button el-button--primary is-plain el-button--small" id="upload_addonFieldExt_courseware_qiniu" onclick="$('#courseware_file').attr('data-type','qiniu').trigger('click');">七牛云上传</a>
  38. {elseif isset($channelRow.data.oss_open) && $channelRow.data.oss_open == 1}
  39. &nbsp;<a href="javascript:void(0);" class="el-button el-button--primary is-plain el-button--small" id="upload_addonFieldExt_courseware_oss" onclick="$('#courseware_file').attr('data-type','oss').trigger('click');">oss上传</a>
  40. {elseif isset($channelRow.data.cos_open) && $channelRow.data.cos_open == 1}
  41. &nbsp;<a href="javascript:void(0);" class="el-button el-button--primary is-plain el-button--small" id="upload_addonFieldExt_courseware_cos" onclick="$('#courseware_file').attr('data-type', 'cos').trigger('click');">cos上传</a>
  42. {else/}
  43. &nbsp;<a href="javascript:void(0);" class="el-button el-button--primary is-plain el-button--small" id="upload_addonFieldExt_courseware_local" onclick="$('#courseware_file').attr('data-type','local').trigger('click');">本地上传</a>
  44. {/if}
  45. </div>
  46. </div>
  47. <script>
  48. $(function () {
  49. var data = '{$video_list|default=""}';
  50. if(data){
  51. data = JSON.parse(data);
  52. var num = 0;
  53. data.forEach(function(v){
  54. num++;
  55. addUrlSys(num,v);
  56. });
  57. }
  58. })
  59. layui.use('upload', function(){
  60. var upload = layui.upload;
  61. //执行实例
  62. //创建监听函数
  63. var xhrOnProgress=function(fun) {
  64. xhrOnProgress.onprogress = fun; //绑定监听
  65. //使用闭包实现监听绑
  66. return function() {
  67. var xhr = $.ajaxSettings.xhr(); //通过此方法获得XMLHttpRequest对象
  68. //判断监听函数是否为函数
  69. if (typeof xhrOnProgress.onprogress !== 'function') {
  70. return xhr;
  71. }
  72. //如果有监听函数并且xhr对象支持绑定时就把监听函数绑定上去
  73. if (xhrOnProgress.onprogress && xhr.upload) {
  74. xhr.upload.onprogress = xhrOnProgress.onprogress;
  75. }
  76. return xhr;
  77. }
  78. };
  79. upload.render({
  80. elem: "#upload_video_sys_1" //绑定元素
  81. ,url: "{:url('Uploadify/upVideo', ['savepath'=>'media'])}" //上传接口
  82. ,accept: 'video' //视频
  83. ,exts: '{$media_type}'
  84. ,size: {$upload_max_filesize} //限制文件大小,单位 KB
  85. ,before: function(obj){
  86. $("#upload_video_sys_1").text('等待中...');
  87. }
  88. ,xhr:xhrOnProgress
  89. ,progress: function(percent) {
  90. //上传进度回调 value进度值
  91. $("#upload_video_sys_1").text('上传中...'+percent+'%');
  92. }
  93. ,done: function(res){
  94. if ("SUCCESS" == res.state) {
  95. $("#video_url_sys_1").val(res.url);
  96. $("#video_time_sys_1").val(res.time);
  97. $("#video_size_sys_1").val(res.size);
  98. $("#video_mime_sys_1").val(res.mime);
  99. $("#video_name_sys_1").val(res.title);
  100. $("#upload_video_sys_1").text('上传成功');
  101. setTimeout(function(){
  102. $('#upload_video_sys_1').text('本地上传');
  103. }, 2000 )
  104. }else {
  105. $("#upload_video_sys_1").text('上传失败');
  106. setTimeout(function(){
  107. $('#upload_video_sys_1').text('本地上传');
  108. }, 2000 )
  109. layer.msg(res.state,{icon: 2});
  110. }
  111. }
  112. ,error: function(){
  113. // layer.close(load); //关闭loading
  114. }
  115. });
  116. });
  117. function addUrlSys(n,v) {
  118. var is_show_qiniuyun = {$channelRow.data.qiniuyun_open|default=0};
  119. var is_show_oss = {$channelRow.data.oss_open|default=0};
  120. var is_show_cos = {$channelRow.data.cos_open|default=0};
  121. if (n) {
  122. var num = n;
  123. var html = "";
  124. html += "<tr id=\"num_upload_box_sys\" class='media_del_1586481014_"+num+"' data-num='"+num+"' style='margin-bottom: 10px;'>\n" +
  125. " <td class=\"th_server_name\">\n" +
  126. " <input type=\"text\" class=\"input-txt\" id=\"video_url_sys_"+num+"\" value=\"" + v.file_url + "\" style=\"width: 310px !important;\" >\n" +
  127. " </td>\n" +
  128. " <td class=\"th_server_name\">\n" +
  129. " <input type=\"text\" class=\"input-txt\" id=\"video_title_sys_"+num+"\" value=\"" + v.file_title + "\" style=\"width: 140px !important;\">\n" +
  130. " </td>\n" +
  131. " <td class=\"th_server_name\">\n" +
  132. " <input type=\"text\" class=\"input-txt\" id=\"video_time_sys_"+num+"\" value=\"" + v.file_time + "\" style=\"width: 60px !important;\">\n" +
  133. " </td>\n" +
  134. " <input type=\"hidden\" class=\"input-txt\" id=\"video_size_sys_"+num+"\" value=\"" + v.file_size + "\">" +
  135. " <input type=\"hidden\" class=\"input-txt\" id=\"video_mime_sys_"+num+"\" value=\"" + v.file_mime + "\">" +
  136. " <input type=\"hidden\" class=\"input-txt\" id=\"video_name_sys_" + num + "\" value=\"" + v.file_name + "\">" +
  137. " <input type=\"hidden\" class=\"input-txt\" id=\"video_file_id_" + num + "\" value=\"" + v.file_id + "\">" +
  138. " <input type=\"file\" class=\"input-txt\" id=\"qiniu_click_sys_"+num+"\" onchange=\"QiniuUpload('"+num+"');\" style=\"display: none;\">\n"+
  139. " <input type=\"file\" class=\"input-txt\" id=\"oss_click_sys_"+num+"\" onchange=\"OssUpload('"+num+"');\" style=\"display: none;\">\n"+
  140. " <input type=\"file\" class=\"input-txt\" id=\"cos_click_sys_"+num+"\" onchange=\"CosUpload('"+num+"');\" style=\"display: none;\">\n"+
  141. " <td style=\"text-align: center;\">\n";
  142. if (is_show_qiniuyun == 1) {
  143. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"qiniu_upload_video_sys_"+num+"\" onclick=\"click_qiniu_sys('"+num+"');\">七牛云上传</a>\n";
  144. }else if (is_show_oss == 1) {
  145. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"oss_upload_video_sys_"+num+"\" onclick=\"click_oss_sys('"+num+"');\">oss上传</a>\n";
  146. }else if (is_show_cos == 1) {
  147. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"cos_upload_video_sys_"+num+"\" onclick=\"click_cos_sys('"+num+"');\">cos上传</a>\n";
  148. }else{
  149. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"upload_video_sys_"+num+"\" data-num='"+num+"'>本地上传</a>\n" ;
  150. }
  151. var IsGratis = 1 == v.gratis ? 'checked' : '';
  152. html += " <br><a href=\"javascript:void(0);\" class=\"fc-colours\" onclick=\"media_del('"+num+"');\">删除</a>\n" +
  153. " </td>\n" +
  154. " <td style=\"text-align: center;\">\n" +
  155. " <label onselectstart='return false'><input type='checkbox' id='video_gratis_sys_"+num+"' value='1' " + IsGratis + "></label>" +
  156. " </td>\n" +
  157. " </tr>";
  158. $('#url-box_sys').append(html);
  159. } else {
  160. var num = $("#url-box_sys #num_upload_box_sys").last().attr("data-num");
  161. if (!num) {
  162. num = 0;
  163. }
  164. num++;
  165. var html = "";
  166. html += "<tr id=\"num_upload_box_sys\" class='media_del_1586481014_"+num+"' data-num='"+num+"' style='margin-bottom: 10px;'>\n" +
  167. " <td class=\"th_server_name\">\n" +
  168. " <input type=\"text\" class=\"input-txt\" id=\"video_url_sys_"+num+"\" style=\"width: 310px !important;\" >\n" +
  169. " </td>\n" +
  170. " <td class=\"th_server_name\">\n" +
  171. " <input type=\"text\" class=\"input-txt\" id=\"video_title_sys_"+num+"\" style=\"width: 140px !important;\">\n" +
  172. " </td>\n" +
  173. " <td class=\"th_server_name\">\n" +
  174. " <input type=\"text\" class=\"input-txt\" id=\"video_time_sys_"+num+"\" style=\"width: 60px !important;\">\n" +
  175. " </td>\n" +
  176. " <input type=\"hidden\" class=\"input-txt\" id=\"video_size_sys_"+num+"\">" +
  177. " <input type=\"hidden\" class=\"input-txt\" id=\"video_mime_sys_"+num+"\">" +
  178. " <input type=\"hidden\" class=\"input-txt\" id=\"video_name_sys_"+num+"\">" +
  179. " <input type=\"file\" class=\"input-txt\" id=\"qiniu_click_sys_"+num+"\" onchange=\"QiniuUpload('"+num+"');\" style=\"display: none;\">\n"+
  180. " <input type=\"file\" class=\"input-txt\" id=\"oss_click_sys_"+num+"\" onchange=\"OssUpload('"+num+"');\" style=\"display: none;\">\n"+
  181. " <input type=\"file\" class=\"input-txt\" id=\"cos_click_sys_"+num+"\" onchange=\"CosUpload('"+num+"');\" style=\"display: none;\">\n"+
  182. " <td style=\"text-align: center;\">\n";
  183. if (is_show_qiniuyun == 1) {
  184. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"qiniu_upload_video_sys_"+num+"\" onclick=\"click_qiniu_sys('"+num+"');\">七牛云上传</a>\n";
  185. }else if (is_show_oss == 1) {
  186. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"oss_upload_video_sys_"+num+"\" onclick=\"click_oss_sys('"+num+"');\">oss上传</a>\n";
  187. }else if (is_show_cos == 1) {
  188. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"cos_upload_video_sys_"+num+"\" onclick=\"click_cos_sys('"+num+"');\">cos上传</a>\n";
  189. }else{
  190. html += " <a href=\"javascript:void(0);\" class=\"fc-colours\" id=\"upload_video_sys_"+num+"\" data-num='"+num+"'>本地上传</a>\n" ;
  191. }
  192. html += " <br><a href=\"javascript:void(0);\" class=\"fc-colours\" onclick=\"media_del('"+num+"');\">删除</a>\n" +
  193. " </td>\n" +
  194. " <td style=\"text-align: center;\">\n" +
  195. " <label onselectstart='return false'><input type='checkbox' id='video_gratis_sys_"+num+"' value='1'></label>" +
  196. " </td>\n" +
  197. " </tr>";
  198. $('#url-box_sys').append(html);
  199. }
  200. layui.use('upload', function(){
  201. var upload = layui.upload;
  202. var xhrOnProgress=function(fun) {
  203. xhrOnProgress.onprogress = fun;
  204. return function() {
  205. var xhr = $.ajaxSettings.xhr();
  206. if (typeof xhrOnProgress.onprogress !== 'function') {
  207. return xhr;
  208. }
  209. if (xhrOnProgress.onprogress && xhr.upload) {
  210. xhr.upload.onprogress = xhrOnProgress.onprogress;
  211. }
  212. return xhr;
  213. }
  214. };
  215. upload.render({
  216. elem: "#upload_video_sys_"+num
  217. ,url: "{:url('Uploadify/upVideo', ['savepath'=>'media'])}"
  218. ,accept: 'video' //视频
  219. ,exts: '{$media_type}'
  220. ,size: {$upload_max_filesize} //限制文件大小,单位 KB
  221. ,before: function(obj){
  222. $("#upload_video_sys_"+num).text('等待中...');
  223. }
  224. ,xhr:xhrOnProgress
  225. ,progress: function(percent) {
  226. $("#upload_video_sys_"+num).text('上传中...'+percent+'%');
  227. }
  228. ,done: function(res){
  229. if ("SUCCESS" == res.state) {
  230. var n = $(this.item).attr('data-num');
  231. $("#video_url_sys_"+n).val(res.url);
  232. $("#video_time_sys_"+n).val(res.time);
  233. $("#video_size_sys_"+n).val(res.size);
  234. $("#video_mime_sys_"+n).val(res.mime);
  235. $("#video_name_sys_"+n).val(res.title);
  236. $("#upload_video_sys_"+num).text('上传成功');
  237. setTimeout(function(){
  238. $('#upload_video_sys_'+num).text('本地上传');
  239. }, 2000 );
  240. }else {
  241. $("#upload_video_sys_"+num).text('上传失败');
  242. setTimeout(function(){
  243. $('#upload_video_sys_'+num).text('本地上传');
  244. }, 2000 );
  245. layer.msg(res.state,{icon: 2});
  246. }
  247. }
  248. ,error: function(){
  249. // layer.close(load); //关闭loading
  250. }
  251. });
  252. });
  253. }
  254. // 课件地址上传
  255. function upload_file_courseware_1585641738(e){
  256. var data_type = $(e).attr('data-type');
  257. if ('qiniu' == data_type) {
  258. upload_addonFieldExt_courseware_qiniu(e); // 七牛云上传
  259. } else if ('oss' == data_type) {
  260. upload_addonFieldExt_courseware_oss(e); // OSS上传
  261. } else if ('cos' == data_type) {
  262. upload_addonFieldExt_courseware_cos(e); // COS上传
  263. } else {
  264. var file = $(e)[0].files[0];
  265. if (!file) {
  266. return false;
  267. }
  268. var formData = new FormData();
  269. formData.append('file',file);
  270. $.ajax({
  271. type: 'post',
  272. url: "{:url('Uploadify/DownloadUploadFileAjax')}",
  273. data: formData,
  274. contentType: false,
  275. processData: false,
  276. dataType: 'json',
  277. xhr: function () { //获取ajaxSettings中的xhr对象,为它的upload属性绑定progress事件的处理函数
  278. myXhr = $.ajaxSettings.xhr();
  279. if (myXhr.upload) { //检查upload属性是否存在
  280. //绑定progress事件的回调函数
  281. // myXhr.upload.addEventListener('progress', progressHandlingFunction, false);
  282. myXhr.upload.addEventListener('progress', function(e){
  283. var curr = e.loaded;
  284. var total = e.total;
  285. process = parseInt(curr / total * 100);
  286. $("#upload_addonFieldExt_courseware_local").html('上传中...'+process+"%");
  287. });
  288. }
  289. return myXhr; //xhr对象返回给jQuery使用
  290. },
  291. success: function (res) {
  292. if (res.code==0){
  293. showErrorMsg(res.msg);
  294. $('#upload_addonFieldExt_courseware_local').html('本地上传');
  295. }if (res.state && !res.url) {
  296. showErrorMsg(res.state);
  297. $('#upload_addonFieldExt_courseware_local').html('本地上传');
  298. }else {
  299. $("#upload_addonFieldExt_courseware_local").html('上传成功');
  300. setTimeout(function(){
  301. $('#upload_addonFieldExt_courseware_local').html('本地上传');
  302. }, 2000 );
  303. var ori_url = $('#addonFieldExt_courseware').val();
  304. $("#addonFieldExt_courseware").val(res.url);
  305. //删除上次的文件
  306. if (ori_url) {
  307. del_media_file(ori_url)
  308. }
  309. }
  310. }
  311. })
  312. }
  313. }
  314. function upload_addonFieldExt_courseware_qiniu(obj)
  315. {
  316. var file = $("#courseware_file")[0].files[0]; //获取文件路径名
  317. var fileName = file.name;
  318. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  319. var ext = judgeExt(fileExt,1);
  320. if (ext==-1) {
  321. showErrorMsg('不支持选中的文件格式,可在附件设置中修改');
  322. return false;
  323. }
  324. var size = "{$upload_max_filesize}";
  325. if (file.size > size) {
  326. showErrorMsg('文件大小超过限制,可在附件设置中修改');
  327. return false;
  328. }
  329. $.ajax({
  330. type: 'POST',
  331. url: '__ROOT_DIR__/index.php?m=plugins&c=Qiniuyun&a=qiniu_upload',
  332. data: {_ajax:1},
  333. dataType: "JSON",
  334. success: function(res1){
  335. if (1 == res1.code){
  336. var token = res1.data.token;
  337. var formData = new FormData();
  338. formData.append('file', file);
  339. formData.append('token', token);
  340. fileName = res1.data.filePath + fileExt;
  341. formData.append('key', fileName);
  342. $.ajax({
  343. url: res1.data.uphost,
  344. type: 'POST',
  345. dataType: 'JSON',
  346. data: formData,
  347. timeout: 1200000,
  348. cache: false, //默认是true,但是一般不做缓存
  349. processData: false, //用于对data参数进行序列化处理,这里必须false;如果是true,就会将FormData转换为String类型
  350. contentType: false, //一些文件上传http协议的关系,自行百度,如果上传的有文件,那么只能设置为false
  351. xhr: function () { //获取ajaxSettings中的xhr对象,为它的upload属性绑定progress事件的处理函数
  352. myXhr = $.ajaxSettings.xhr();
  353. if (myXhr.upload) { //检查upload属性是否存在
  354. //绑定progress事件的回调函数
  355. // myXhr.upload.addEventListener('progress', progressHandlingFunction, false);
  356. myXhr.upload.addEventListener('progress', function(e){
  357. var curr = e.loaded;
  358. var total = e.total;
  359. process = parseInt(curr / total * 100);
  360. $("#upload_addonFieldExt_courseware_qiniu").html('上传中...'+process+"%");
  361. });
  362. }
  363. return myXhr; //xhr对象返回给jQuery使用
  364. },
  365. success: function(res2){
  366. $("#upload_addonFieldExt_courseware_qiniu").html('上传成功');
  367. setTimeout(function(){
  368. $('#upload_addonFieldExt_courseware_qiniu').html('七牛云上传');
  369. }, 2000 );
  370. var video_url = res1.data.domain+"/"+res2.key;
  371. $("#addonFieldExt_courseware").val(video_url);
  372. },
  373. error: function(e){
  374. showErrorMsg(e.responseText);
  375. return false;
  376. }
  377. });
  378. }else{
  379. $("#courseware_file").val('');
  380. showErrorMsg(res1.msg);
  381. }
  382. },
  383. error: function(e){
  384. $("#courseware_file").val('');
  385. showErrorMsg(e.responseText);
  386. }
  387. });
  388. }
  389. function upload_addonFieldExt_courseware_oss(obj)
  390. {
  391. var file = $("#courseware_file")[0].files[0]; //获取文件路径名
  392. var fileName = file.name;
  393. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  394. var ext = judgeExt(fileExt,1);
  395. if (ext==-1) {
  396. showErrorMsg('不支持选中的文件格式,可在附件设置中修改');
  397. return false;
  398. }
  399. var size = "{$upload_max_filesize}";
  400. if (file.size > size) {
  401. showErrorMsg('文件大小超过限制,可在附件设置中修改');
  402. return false;
  403. }
  404. $.ajax({
  405. type: 'POST',
  406. url: '__ROOT_DIR__/index.php?m=plugins&c=AliyunOss&a=oss_upload',
  407. data: {_ajax:1},
  408. dataType: "JSON",
  409. success: function(res1){
  410. if (1 == res1.code){
  411. fileName = res1.data.filePath + fileExt;
  412. //组装发送数据
  413. var request = new FormData();
  414. request.append("OSSAccessKeyId",res1.data.accessid);//Bucket 拥有者的Access Key Id。
  415. request.append("policy",res1.data.policy);//policy规定了请求的表单域的合法性
  416. request.append("Signature",res1.data.signature);//根据Access Key Secret和policy计算的签名信息,OSS验证该签名信息从而验证该Post请求的合法性
  417. request.append("key",fileName);//文件名字,可设置路径
  418. request.append("success_action_status",201);// 让服务端返回200,不然,默认会返回204
  419. request.append('file', file);//需要上传的文件 file
  420. $.ajax({
  421. url : res1.data.host, //上传阿里地址
  422. data : request,
  423. processData: false,
  424. cache: false,
  425. contentType: false,
  426. dataType: 'xml',
  427. type : 'post',
  428. xhr: function () { //获取ajaxSettings中的xhr对象,为它的upload属性绑定progress事件的处理函数
  429. myXhr = $.ajaxSettings.xhr();
  430. if (myXhr.upload) { //检查upload属性是否存在
  431. //绑定progress事件的回调函数
  432. myXhr.upload.addEventListener('progress', function(e){
  433. var curr = e.loaded;
  434. var total = e.total;
  435. var process = parseInt(curr / total * 100);
  436. $("#upload_addonFieldExt_courseware_oss").html('上传中...'+process+"%");
  437. });
  438. }
  439. return myXhr; //xhr对象返回给jQuery使用
  440. },
  441. success: function(res2){
  442. var res = $(res2).find('PostResponse');
  443. if (res) {
  444. var key = res.find('Key').text();
  445. $("#upload_addonFieldExt_courseware_oss").html('上传成功');
  446. setTimeout(function(){
  447. $('#upload_addonFieldExt_courseware_oss').html('oss上传');
  448. }, 2000 );
  449. var video_url = res1.data.domain+"/"+key;
  450. $("#addonFieldExt_courseware").val(video_url);
  451. }else{
  452. $("#upload_addonFieldExt_courseware_oss").html('上传失败');
  453. setTimeout(function(){
  454. $('#upload_addonFieldExt_courseware_oss').html('oss上传');
  455. }, 2000 );
  456. }
  457. },
  458. error: function(e){
  459. showErrorMsg(e.responseText);
  460. return false;
  461. }
  462. });
  463. }else{
  464. $("#courseware_file").val('');
  465. showErrorMsg(res1.msg);
  466. }
  467. },
  468. error: function(e){
  469. $("#courseware_file").val('');
  470. showErrorMsg(e.responseText);
  471. }
  472. });
  473. }
  474. function click_qiniu_sys(num)
  475. {
  476. $("#qiniu_click_sys_"+num).trigger("click");
  477. }
  478. function QiniuUpload(num)
  479. {
  480. var file = $("#qiniu_click_sys_"+num)[0].files[0]; //获取文件路径名
  481. var fileName = file.name;
  482. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  483. var ext = judgeExt(fileExt);
  484. if (ext==-1) {
  485. showErrorMsg('不支持选中的视频格式,可在附件设置中修改');
  486. return false;
  487. }
  488. var size = "{$upload_max_filesize}";
  489. if (file.size > size) {
  490. showErrorMsg('视频大小超过限制,可在附件设置中修改');
  491. return false;
  492. }
  493. $.ajax({
  494. type: 'POST',
  495. url: '__ROOT_DIR__/index.php?m=plugins&c=Qiniuyun&a=qiniu_upload',
  496. data: {_ajax:1},
  497. dataType: "JSON",
  498. success: function(res1){
  499. if (1 == res1.code){
  500. var token = res1.data.token;
  501. var formData = new FormData();
  502. formData.append('file', file);
  503. formData.append('token', token);
  504. fileName = res1.data.filePath + fileExt;
  505. formData.append('key', fileName);
  506. $.ajax({
  507. url: res1.data.uphost,
  508. type: 'POST',
  509. dataType: 'JSON',
  510. data: formData,
  511. timeout: 1200000,
  512. cache: false, //默认是true,但是一般不做缓存
  513. processData: false, //用于对data参数进行序列化处理,这里必须false;如果是true,就会将FormData转换为String类型
  514. contentType: false, //一些文件上传http协议的关系,自行百度,如果上传的有文件,那么只能设置为false
  515. xhr: function () { //获取ajaxSettings中的xhr对象,为它的upload属性绑定progress事件的处理函数
  516. myXhr = $.ajaxSettings.xhr();
  517. if (myXhr.upload) { //检查upload属性是否存在
  518. //绑定progress事件的回调函数
  519. // myXhr.upload.addEventListener('progress', progressHandlingFunction, false);
  520. myXhr.upload.addEventListener('progress', function(e){
  521. var curr = e.loaded;
  522. var total = e.total;
  523. process = parseInt(curr / total * 100);
  524. $("#qiniu_upload_video_sys_"+num).text('上传中...'+process+"%");
  525. });
  526. }
  527. return myXhr; //xhr对象返回给jQuery使用
  528. },
  529. success: function(res2){
  530. $("#qiniu_upload_video_sys_"+num).text('上传成功');
  531. setTimeout(function(){
  532. $('#qiniu_upload_video_sys_'+num).text('七牛云上传');
  533. }, 2000 )
  534. var video_url = res1.data.domain+"/"+res2.key;
  535. $("#video_url_sys_"+num).val(video_url);
  536. $("#video_mime_sys_"+num).val('');
  537. $("#video_name_sys_"+num).val(res2.key);
  538. var rx=/^https?:\/\//i;
  539. if (!rx.test(video_url)) {
  540. video_url = 'http:'+video_url;
  541. }
  542. $.ajax({
  543. type: 'GET',
  544. url: video_url+"?avinfo",
  545. data: {},
  546. dataType: "JSON",
  547. success: function (res3) {
  548. $("#video_time_sys_"+num).val(parseInt(res3.format.duration));
  549. $("#video_size_sys_"+num).val(res3.format.size);
  550. }
  551. })
  552. },
  553. error: function(e){
  554. showErrorMsg(e.responseText);
  555. return false;
  556. }
  557. });
  558. }else{
  559. $("#qiniu_click_sys_"+num).val('');
  560. showErrorMsg(res1.msg);
  561. }
  562. },
  563. error: function(e){
  564. $("#qiniu_click_sys_"+num).val('');
  565. showErrorMsg(e.responseText);
  566. }
  567. });
  568. }
  569. function click_oss_sys(num)
  570. {
  571. $("#oss_click_sys_"+num).trigger("click");
  572. }
  573. function OssUpload(num)
  574. {
  575. var file = $("#oss_click_sys_"+num)[0].files[0]; //获取文件路径名
  576. //获取视频时长start
  577. var url = URL.createObjectURL(file);
  578. var oVideo = document.createElement('video');
  579. var duration = 0;
  580. oVideo.setAttribute('src',url);
  581. oVideo.oncanplay = ()=>{
  582. duration = parseInt(oVideo.duration);
  583. }
  584. //获取视频时长end
  585. var fileName = file.name;
  586. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  587. var ext = judgeExt(fileExt);
  588. if (ext==-1) {
  589. showErrorMsg('不支持选中的视频格式,可在附件设置中修改');
  590. return false;
  591. }
  592. var size = "{$upload_max_filesize}";
  593. if (file.size > size) {
  594. showErrorMsg('视频大小超过限制,可在附件设置中修改');
  595. return false;
  596. }
  597. $.ajax({
  598. type: 'POST',
  599. url: '__ROOT_DIR__/index.php?m=plugins&c=AliyunOss&a=oss_upload',
  600. data: {_ajax: 1},
  601. dataType: "JSON",
  602. success: function(res1){
  603. if (1 == res1.code){
  604. fileName = res1.data.filePath + fileExt;
  605. //组装发送数据
  606. var request = new FormData();
  607. request.append("OSSAccessKeyId",res1.data.accessid);//Bucket 拥有者的Access Key Id。
  608. request.append("policy",res1.data.policy);//policy规定了请求的表单域的合法性
  609. request.append("Signature",res1.data.signature);//根据Access Key Secret和policy计算的签名信息,OSS验证该签名信息从而验证该Post请求的合法性
  610. request.append("key",fileName);//文件名字,可设置路径
  611. request.append("success_action_status",201);// 让服务端返回200,不然,默认会返回204
  612. request.append('file', file);//需要上传的文件 file
  613. $.ajax({
  614. url : res1.data.host, //上传阿里地址
  615. data : request,
  616. processData: false,
  617. cache: false,
  618. contentType: false,
  619. dataType: 'xml',
  620. type : 'post',
  621. xhr: function () { //获取ajaxSettings中的xhr对象,为它的upload属性绑定progress事件的处理函数
  622. myXhr = $.ajaxSettings.xhr();
  623. if (myXhr.upload) { //检查upload属性是否存在
  624. //绑定progress事件的回调函数
  625. myXhr.upload.addEventListener('progress', function(e){
  626. var curr = e.loaded;
  627. var total = e.total;
  628. var process = parseInt(curr / total * 100);
  629. $("#oss_upload_video_sys_"+num).text('上传中...'+process+"%");
  630. });
  631. }
  632. return myXhr; //xhr对象返回给jQuery使用
  633. },
  634. success : function(data) {
  635. var res = $(data).find('PostResponse');
  636. if (res) {
  637. var key = res.find('Key').text();
  638. $("#oss_upload_video_sys_"+num).text('上传成功');
  639. setTimeout(function(){
  640. $('#oss_upload_video_sys_'+num).text('oss上传');
  641. }, 2000 )
  642. var video_url = res1.data.domain+"/"+key;
  643. $("#video_url_sys_"+num).val(video_url);
  644. $("#video_mime_sys_"+num).val('');
  645. $("#video_name_sys_"+num).val(key);
  646. $("#video_time_sys_"+num).val(duration);
  647. $("#video_size_sys_"+num).val(file.size);
  648. }else{
  649. $("#oss_upload_video_sys_"+num).text('上传失败');
  650. setTimeout(function(){
  651. $('#oss_upload_video_sys_'+num).text('oss上传');
  652. }, 2000 )
  653. }
  654. },
  655. error : function(e) {
  656. console.log(e.responseText);
  657. }
  658. });
  659. }else{
  660. $("#oss_click_sys_"+num).val('');
  661. showErrorMsg(res1.msg);
  662. }
  663. },
  664. error: function(e){
  665. $("#oss_click_sys_"+num).val('');
  666. showErrorMsg(e.responseText);
  667. }
  668. });
  669. }
  670. /*腾讯云COS上传代码 --- 陈风任 --- 2021-02-03*/
  671. function click_cos_sys(num) {
  672. $("#cos_click_sys_"+num).trigger("click");
  673. }
  674. // 上传视频
  675. function CosUpload(num) {
  676. // 获取文件路径名
  677. var file = $("#cos_click_sys_"+num)[0].files[0];
  678. // 获取视频时长start
  679. var url = URL.createObjectURL(file);
  680. var oVideo = document.createElement('video');
  681. var duration = 0;
  682. oVideo.setAttribute('src', url);
  683. oVideo.oncanplay = ()=>{
  684. duration = parseInt(oVideo.duration);
  685. }
  686. // 获取视频时长end
  687. var fileName = file.name;
  688. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  689. var ext = judgeExt(fileExt);
  690. if (ext == -1) {
  691. showErrorMsg('不支持选中的视频格式,可在附件设置中修改');
  692. return false;
  693. }
  694. var size = "{$upload_max_filesize}";
  695. if (file.size > size) {
  696. showErrorMsg('视频大小超过限制,可在附件设置中修改');
  697. return false;
  698. }
  699. var formData = new FormData();
  700. formData.append('file', file);
  701. formData.append('file_ext', fileExt);
  702. $.ajax({
  703. type: 'post',
  704. url: '__ROOT_DIR__/index.php?m=plugins&c=Cos&a=cos_upload&_ajax=1',
  705. data: formData,
  706. contentType: false,
  707. processData: false,
  708. dataType: 'json',
  709. xhr: function () {
  710. myXhr = $.ajaxSettings.xhr();
  711. if (myXhr.upload) {
  712. myXhr.upload.addEventListener('progress', function(e){
  713. var curr = e.loaded;
  714. var total = e.total;
  715. process = parseInt(curr / total * 100);
  716. if (100 == process) {
  717. process = 99;
  718. layer_loading('上传腾讯云');
  719. }
  720. $("#cos_upload_video_sys_"+num).text('上传中...'+process+"%");
  721. });
  722. }
  723. return myXhr;
  724. },
  725. success: function(res) {
  726. layer.closeAll();
  727. if (1 == res.code) {
  728. $("#video_url_sys_" + num).val(res.data.url);
  729. $("#video_title_sys_" + num).val(res.data.name);
  730. $("#video_time_sys_" + num).val(duration);
  731. $("#video_size_sys_" + num).val(res.data.size);
  732. $("#cos_upload_video_sys_"+num).text('上传成功');
  733. } else {
  734. $("#cos_upload_video_sys_"+num).text('上传失败');
  735. }
  736. setTimeout(function(){
  737. $('#cos_upload_video_sys_'+num).text('cos上传');
  738. }, 2000);
  739. },
  740. error: function(e){
  741. layer.closeAll();
  742. $("#cos_click_sys_"+num).val('');
  743. showErrorMsg(e.responseText);
  744. }
  745. });
  746. }
  747. /* 批量导入视频信息 end */
  748. function urlToStr() {
  749. var video = [];
  750. $("#url-box_sys tr").each(function(){
  751. var n = $(this).attr('data-num');
  752. var arr ={};
  753. arr.file_url = $("#video_url_sys_"+n).val();
  754. if (!arr.file_url) {
  755. return true;
  756. }
  757. arr.file_title = $("#video_title_sys_"+n).val();
  758. arr.file_name = $("#video_name_sys_"+n).val();
  759. arr.file_time = $("#video_time_sys_"+n).val();
  760. arr.file_size = $("#video_size_sys_"+n).val();
  761. arr.file_mime = $("#video_mime_sys_"+n).val();
  762. var gratis_checked = $("#video_gratis_sys_"+n).is(':checked');
  763. if (gratis_checked == true){
  764. arr.gratis = 1;
  765. } else{
  766. arr.gratis = 0;
  767. }
  768. video.push(arr);
  769. });
  770. video = JSON.stringify(video)
  771. $("#video").val(video)
  772. }
  773. //获取文件类型
  774. function judgeExt(ext,i) {
  775. var type = '';
  776. if (i==1){
  777. type = "{$file_type}";
  778. }else{
  779. type = "{$media_type}";
  780. }
  781. var extArr = [];
  782. extArr = type.split("|");
  783. var ext = ext.replace(".","");
  784. return extArr.indexOf(ext);
  785. }
  786. //删除
  787. function media_del(num) {
  788. var media_url = $("#video_url_sys_"+num).val();
  789. if (media_url) {
  790. del_media_file(media_url);
  791. }
  792. $(".media_del_1586481014_"+num).remove();
  793. }
  794. function del_media_file(path){
  795. var url = '';
  796. {if isset($channelRow.data.qiniuyun_open) && $channelRow.data.qiniuyun_open == 1}
  797. url = "{:url('plugins/Qiniuyun/deleteQny')}";
  798. {elseif isset($channelRow.data.oss_open) && $channelRow.data.oss_open == 1}
  799. url = "{:url('plugins/AliyunOss/deleteOss')}";
  800. {elseif isset($channelRow.data.cos_open) && $channelRow.data.cos_open == 1}
  801. url = "{:url('plugins/Cos/deleteCos')}";
  802. {else/}
  803. url = "{:url('user/Uploadify/del_local')}";
  804. {/if}
  805. $.ajax({
  806. type: 'GET',
  807. url: url,
  808. data: {_ajax: 1, filenames: path},
  809. success: function (res1) {
  810. }
  811. });
  812. }
  813. </script>