FileUpload.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. <?php
  2. /**
  3. * 文件上传
  4. * User: Mike
  5. * Email: m@9026.com
  6. * Date: 2016/6/21
  7. * Time: 11:45
  8. */
  9. namespace App\Widget\Tools;
  10. class FileUpload {
  11. /**
  12. * 单个文件上传
  13. * @param $folder
  14. * @param string $position
  15. * @param array $option
  16. */
  17. public function single($folder, $id, $name = "data[file]", $file = "", $option = [], $param = [])
  18. {
  19. $file_types = 'jpg|jpeg|gif|png|bmp|doc|docx|xls|xlsx|ppt|htm|html|php|txt|zip|rar|gz|bz2|pdf';
  20. $option['position'] = isset($option['position']) ? $option['position'] : "alioss";
  21. $option['placeholder'] = isset($option['placeholder']) ? $option['placeholder'] : "";
  22. $option['button_class'] = isset($option['button_class']) ? $option['button_class'] : "";
  23. //扩展参数
  24. $extParam = '';
  25. if($param){
  26. foreach($param AS $key => $val){
  27. $extParam .= $key . ":" . $val . ',';
  28. }
  29. }
  30. $token = csrf_token();
  31. $html = <<<EOF
  32. <link href="/base/webuploader/webuploader.css" rel="stylesheet">
  33. <script src="/base/webuploader/webuploader.min.js"></script>
  34. <div class="WebUploader">
  35. <div class="WebUploader_button">
  36. <div class="input-group">
  37. <input type="text" class="form-control input-uploadfile" id="pdfUpload" value="{$file}" name="{$name}" placeholder="{$option['placeholder']}" readonly>
  38. <div class="input-group-btn">
  39. <div id="{$id}" class="btn-xs {$option['button_class']}">上传文件</div>
  40. <input type="button" class="btn btn-danger" onclick="del('{$file}')" style="margin-right:20px;" value="删除">
  41. </div>
  42. </div>
  43. </div>
  44. </div>
  45. <script type="text/javascript">
  46. function webUpload{$id}() {
  47. var uploaderthis="#{$id}";
  48. var uploader = WebUploader.create({
  49. auto: true,
  50. pick: {
  51. id: uploaderthis,
  52. multiple: false,
  53. },
  54. accept: {
  55. title: 'Files',
  56. extensions: "{$file_types}",
  57. },
  58. swf: "/base/webuploader/uploader.swf",
  59. server: "/admin/Base/Attachment/webupload",
  60. fileNumLimit: 300,
  61. fileSizeLimit: 20 * 1024 * 1024,
  62. fileSingleSizeLimit: 20 * 1024 * 1024,
  63. });
  64. uploader.option("formData", {
  65. $extParam
  66. _time: Math.random(),
  67. _token : "{$token}",
  68. _position : "{$option['position']}",
  69. elementid : "",
  70. file_type : "file",
  71. folder : "{$folder}"
  72. });
  73. uploader.on("error",function(type){
  74. if(type=='F_EXCEED_SIZE'){
  75. layer.msg("上传的文件不大于20MB", {icon: 2});
  76. return false;
  77. }else if(type=="Q_TYPE_DENIED"){
  78. layer.msg("请上传格式正确的文件", {icon: 2});
  79. return false;
  80. }else {
  81. layer.msg("服务器繁忙请稍候再试", {icon: 2});
  82. return false;
  83. }
  84. });
  85. uploader.on("uploadProgress",function(file,percentage){
  86. var re = /([0-9]+\.[0-9]{2})[0-9]*/;
  87. aNew = parseFloat(percentage*100).toFixed(0);
  88. $(uploaderthis).parent().parent().find(".webuploader-pick").html(aNew+"%");
  89. if(percentage==1){
  90. $(uploaderthis).parent().parent().find(".webuploader-pick").html('保存中...');
  91. }
  92. });
  93. uploader.on('uploadSuccess', function( file, response ) {
  94. uploader.removeFile( file );
  95. if(response.code == 200){
  96. $(uploaderthis).parent().parent().find(".input-uploadfile").val(response.fileurl);
  97. $(uploaderthis).parent().parent().find(".webuploader-pick").html('上传完成');
  98. }else{
  99. layer.msg(response.message, {icon: 2});
  100. $(uploaderthis).parent().parent().find(".webuploader-pick").html('上传失败');
  101. }
  102. });
  103. }
  104. webUpload{$id}();
  105. </script>
  106. EOF;
  107. return $html;
  108. }
  109. /**
  110. * 单个文件上传
  111. * @param $folder
  112. * @param string $positions
  113. * @param array $option
  114. */
  115. public function singles($folder, $id, $name = "data[file]", $file = "", $id_order , $token,$option = [], $param = [])
  116. {
  117. $file_types = 'jpg|jpeg|gif|png|bmp|doc|docx|xls|xlsx|ppt|htm|html|php|txt|zip|rar|gz|bz2|pdf';
  118. $option['position'] = isset($option['position']) ? $option['position'] : "alioss";
  119. $option['placeholder'] = isset($option['placeholder']) ? $option['placeholder'] : "";
  120. $option['button_class'] = isset($option['button_class']) ? $option['button_class'] : "";
  121. //扩展参数
  122. $extParam = '';
  123. if($param){
  124. foreach($param AS $key => $val){
  125. $extParam .= $key . ":" . $val . ',';
  126. }
  127. }
  128. $token = csrf_token();
  129. $html = <<<EOF
  130. <link href="/base/webuploader/webuploader.css" rel="stylesheet">
  131. <script src="/base/webuploader/webuploader.min.js"></script>
  132. <div id="{$id_order}">
  133. <input type="hidden" class="form-control input-uploadfile" id="pdfUpload" value="{$file}" name="{$name}" placeholder="{$option['placeholder']}" readonly>
  134. <button id="{$id}" class="btn btn-primary {$option['button_class']}">上传</button>
  135. </div>
  136. <script type="text/javascript">
  137. function webUpload{$id}() {
  138. var uploaderthis="#{$id}";
  139. var uploader = WebUploader.create({
  140. auto: true,
  141. pick: {
  142. id: uploaderthis,
  143. multiple: false,
  144. },
  145. accept: {
  146. title: 'Files',
  147. extensions: "{$file_types}",
  148. },
  149. swf: "/base/webuploader/uploader.swf",
  150. server: "/admin/Base/Attachment/webupload",
  151. fileNumLimit: 300,
  152. fileSizeLimit: 20 * 1024 * 1024,
  153. fileSingleSizeLimit: 10 * 1024 * 1024,
  154. });
  155. uploader.option("formData", {
  156. $extParam
  157. _time: Math.random(),
  158. _token : "{$token}",
  159. _position : "{$option['position']}",
  160. elementid : "",
  161. file_type : "file",
  162. folder : "{$folder}"
  163. });
  164. uploader.on("error",function(type){
  165. if(type=='F_EXCEED_SIZE'){
  166. layer.msg("上传的文件不大于10MB", {icon: 2});
  167. return false;
  168. }else if(type=="Q_TYPE_DENIED"){
  169. layer.msg("请上传格式正确的文件", {icon: 2});
  170. return false;
  171. }else {
  172. layer.msg("服务器繁忙请稍候再试", {icon: 2});
  173. return false;
  174. }
  175. });
  176. uploader.on("uploadProgress",function(file,percentage){
  177. var re = /([0-9]+\.[0-9]{2})[0-9]*/;
  178. aNew = parseFloat(percentage*100).toFixed(0);
  179. $(uploaderthis).parent().parent().find(".webuploader-pick").html(aNew+"%");
  180. if(percentage==1){
  181. $(uploaderthis).parent().parent().find(".webuploader-pick").html('保存中...');
  182. }
  183. });
  184. uploader.on('uploadSuccess', function( file, response ) {
  185. uploader.removeFile( file );
  186. if(response.code == 200){
  187. $(uploaderthis).parent().parent().find(".input-uploadfile").val(response.fileurl);
  188. $(uploaderthis).parent().parent().find(".webuploader-pick").html('上传完成');
  189. }else{
  190. layer.msg(response.message, {icon: 2});
  191. $(uploaderthis).parent().parent().find(".webuploader-pick").html('上传失败');
  192. }
  193. var token = "<?php echo csrf_token(); ?>";
  194. alert(token);
  195. });
  196. }
  197. webUpload{$id}();
  198. </script>
  199. EOF;
  200. return $html;
  201. }
  202. public function single2($folder, $id, $name="data", $file="", $option=[]){
  203. $folder = urlencode($folder);
  204. $imgHtml = "";
  205. $option['callback'] = isset($option['callback']) ? $option['callback'] : "";
  206. if(!$option['callback'] && !empty($file)) {
  207. // $imgHtml .= " <li><em class=\"close\" onclick='$(this).parent().remove()'>×</em>
  208. // <a href='{$file}' class='cc_file' target='_blank'> <img src=\"/base/plugins/imguploader/img/file.jpg\" alt=\"{$file}\"></a>
  209. // <p class=\"rate\" style=\"display: none;\"><span style=\"width: 100%;\"></span></p>
  210. // <p class=\"yes\" style=\"display: none;\"></p>
  211. // <p class=\"no\"></p>
  212. // <input type=\"hidden\" name=\"{$name}\" value=\"{$file}\">
  213. // </li>";
  214. $iconImage = in_array(fileExt($img['url']), ['jpg', 'png' , 'gif' , 'jpeg' , 'bmp']) ? " <div class='image'><img src=\"{$img['url']}\" alt= /></div>" : "<div class='icon'><i class='fa fa-file'></i></div>";
  215. $imgHtml .="<li >
  216. <div class=\"file\">
  217. <span class=\"corner\"></span>
  218. {$iconImage}
  219. <div class=\"file-name\">
  220. <p>{$img['alt']}</p>
  221. <small></small>
  222. </div>
  223. </div>
  224. <em class=\"close\" onclick=\"$(this).parent().remove()\" >×</em>
  225. <input type=\"hidden\" name=\"{$name}[alt][]\" value=\"{$img['alt']}\">
  226. <input type=\"hidden\" name=\"{$name}[url][]\" value=\"{$img['url']}\">
  227. </li>";
  228. }
  229. $html = <<<EOF
  230. <script type="text/javascript" src="/base/plugins/imguploader/uploader.js"></script>
  231. <div class="layout_upload">
  232. <ul class="ullit">
  233. $imgHtml
  234. <li>
  235. <a class="layout_upload_but" id="$id">&nbsp;</a>
  236. </li>
  237. <div class="ov_h"></div>
  238. </ul>
  239. </div>
  240. <script type="text/javascript">
  241. /*
  242. UploaderPick:"#", //绑定按钮id
  243. UploaderUrl:"", //百度插件地址
  244. UploaderServer:"", //上传api
  245. UploaderMax:1 //现在最大上传个数
  246. UploadHiddenField:"" //隐藏域name
  247. */
  248. new uploadFile({
  249. UploaderPick:"#$id",
  250. UploaderMax:0,
  251. UploadHiddenField:"$name",
  252. UploaderServer:"/api/attachment/webupload?elementid=&folder=$folder&_time=" + Math.random(),
  253. UploaderSingle:true
  254. });
  255. </script>
  256. EOF;
  257. return $html;
  258. }
  259. public function multi2($folder, $id, $name="data[image]", $files=[], $option=[]){
  260. $folder = urlencode($folder);
  261. $imgHtml = "";
  262. $option['callback'] = isset($option['callback']) ? $option['callback'] : "";
  263. $option['max'] = isset($option['max']) ? $option['max'] : 200;
  264. $option['max'] = $option['max']-count($files);
  265. if(!$option['callback'] && !empty($files)) {
  266. foreach($files as $key=>$val) {
  267. if(is_string($val)) {
  268. $file['url'] = $val;
  269. $file['alt'] = '';
  270. }else{
  271. $file = $val;
  272. }
  273. /*$imgHtml .= " <li><em class=\"close\" onclick='$(this).parent().remove()'>×</em>
  274. <a href='{$file['url']}' title='{$file['alt']}' target='_blank'> <img src=\"/base/plugins/imguploader/img/file.jpg\" alt=\"{$file['alt']}\"></a>
  275. <p class=\"rate\" style=\"display: none;\"><span style=\"width: 100%;\"></span></p>
  276. <p class=\"yes\" style=\"display: none;\"></p>
  277. <p class=\"no\"></p>
  278. <input type=\"hidden\" name=\"{$name}[alt][]\" value=\"{$file['alt']}\">
  279. <input type=\"hidden\" name=\"{$name}[url][]\" value=\"{$file['url']}\">
  280. </li>";*/
  281. $iconImage = in_array(fileExt($file['url']), ['jpg', 'png' , 'gif' , 'jpeg' , 'bmp']) ? " <div class='image'><img src=\"{$file['url']}\" alt= /></div>" : "<div class='icon'><i class='fa fa-file'></i></div>";
  282. $imgHtml .="<li >
  283. <div class=\"file\">
  284. <span class=\"corner\"></span>
  285. {$iconImage}
  286. <div class=\"file-name\">
  287. <p>{$file['alt']}</p>
  288. <small></small>
  289. </div>
  290. </div>
  291. <em class=\"close\" onclick=\"$(this).parent().remove()\" >×</em>
  292. <input type=\"hidden\" name=\"{$name}[alt][]\" value=\"{$file['alt']}\">
  293. <input type=\"hidden\" name=\"{$name}[url][]\" value=\"{$file['url']}\">
  294. </li>";
  295. }
  296. }
  297. $html = <<<EOF
  298. <script type="text/javascript" src="/base/plugins/imguploader/uploader.js"></script>
  299. <div class="layout_upload">
  300. <ul class="ullit">
  301. $imgHtml
  302. <li>
  303. <a class="layout_upload_but" id="$id">&nbsp;</a>
  304. </li>
  305. <div class="ov_h"></div>
  306. </ul>
  307. </div>
  308. <script type="text/javascript">
  309. /*
  310. UploaderPick:"#", //绑定按钮id
  311. UploaderUrl:"", //百度插件地址
  312. UploaderServer:"", //上传api
  313. UploaderMax:5 //现在最大上传个数
  314. UploadHiddenField:"" //隐藏域name
  315. */
  316. new uploadFile({
  317. UploaderPick:"#$id",
  318. UploaderMax:{$option['max']},
  319. UploaderServer:"/api/attachment/webupload?elementid=&folder=$folder&_time=" + Math.random(),
  320. UploadHiddenField:"$name"
  321. });
  322. </script>
  323. EOF;
  324. return $html;
  325. }
  326. }