Thinkphp5+uploadify实现的文件上传功能示例
2018-05-26 11:39
1051 查看
初次接触服务器端开发,边学习边试着做一个OTA后台服务器,费了好大劲才实现了文件上传和进度条显示。
遇到几个问题:
1. 大文件上传失败
2.上传取消X 符合显示不出来
3. 不知道如何传递变量值给后台php
记录下过程:
1. 下载uploadify 代码到工程里,如public\plug-ins\uploadify 下。
2. 前端脚本如下,
客户端在formData 中传递版本号,请看version_id 赋值方法,需要先在控制器里给它assign。
取消符合显示不了,需要修改uploadify.css 里面的
background: url('uploadify-cancel.png')
注意uploadify 中uploader的写法
<form enctype="multipart/form-data" method="post" > <input type="file" name="uploadify" id="uploadify" multiple="true" /> </form> <script type="text/javascript"> <?php $timestamp = time();?> var maxSize = 1024 * 1024*1024;//1G $(function() { $('#uploadify').uploadify({ 'debug' : false, <span style="white-space:pre"> </span> 'fileSizeLimit ': maxSize, 'formData' : { 'timestamp' : '<?php echo $timestamp;?>', 'token' : '<?php echo md5('unique_salt' . $timestamp);?>', <span style="white-space:pre"> </span>'version_id': "{$version_id}" }, 'swf' : '/public/plug-ins/uploadify/uploadify.swf', <span style="white-space:pre"> </span>'cancelImg':'/public/plug-ins/uploadify/uploadify-cancel.png', 'uploader' : '{:url("Package/upload")}', <span style="white-space:pre"> </span>'fileTypeDesc' : 'zip文件', <span style="white-space:pre"> </span>'fileTypeExts' : '*.zip', <span style="white-space:pre"> </span> 'multi': false }); }); </script>
3. 后端脚本对应控制器 Package 的upload函数
注意上传文件的获取方法,不能使用Thinkphp5 官方文档那种获取方式。
保存文件名不能带特殊符号
修改php.ini:
upload_max_filesize = 1024M
post_max_size=48重启服务
public function upload(){ $verifyToken = md5('unique_salt' . $_POST['timestamp']); if (!empty($_FILES) && $_POST['token'] == $verifyToken) { $tempFile = $_FILES['Filedata']['tmp_name']; /* $targetFolder = '/public/uploads'; // Relative to the root $targetPath = $_SERVER['DOCUMENT_ROOT'] . $targetFolder; $targetFile = rtrim($targetPath,'/') . '/' . $_FILES['Filedata']['name']; // Validate the file type $fileTypes = array('jpg','jpeg','gif','png','zip'); // File extensions $fileParts = pathinfo($_FILES['Filedata']['name']); if (in_array($fileParts['extension'],$fileTypes)) { move_uploaded_file($tempFile,$targetFile); echo '1'; } else { echo 'Invalid file type.'; }*/ $version = model("Version")->retrieve_by_version($_POST['version_id']); if($version){ $file = new File($tempFile,'rw'); $hash_code = $file->hash(); $time = date("Y-m-d-i-s",$_POST['timestamp']); $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads'.DS.$version['project_name'].DS.$version['version_name'],'update_'.$time.'.zip'); if($info){ // 成功上传后 获取上传信息 echo $info->getExtension(); echo $info->getSaveName(); echo $info->getFilename(); }else{ // 上传失败获取错误信息 echo $file->getError(); } }else{ echo '找不到对应版本'; } } }
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
您可能感兴趣的文章:
- ThinkPHP文件上传实例教程
- ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法
- Thinkphp多文件上传实现方法
- thinkPHP3.2简单实现文件上传的方法
- 封装ThinkPHP的一个文件上传方法实例
- ThinkPHP实现带验证码的文件上传功能实例
- Thinkphp3.2简单解决多文件上传只上传一张的问题
- layui框架实现文件上传及TP3.2.3(thinkPHP)对上传文件进行后台处理操作示例
- 使用ThinkPHP+Uploadify实现图片上传功能
- 解决ThinkPHP下使用上传插件Uploadify浏览器firefox报302错误的方法
- 基于ThinkPHP+uploadify+upload+PHPExcel 无刷新导入数据
- Thinkphp+smarty+uploadify实现无刷新上传
相关文章推荐
- thinkphp5.0 实现单文件上传功能
- 使用Uploadify插件在struts2中实现多文件上传示例
- ThinkPHP实现带验证码的文件上传功能实例
- thinkPHP实现上传图片及生成缩略图功能示例
- JS实现的文件拖拽上传功能示例
- layui框架实现文件上传及TP3.2.3(thinkPHP)对上传文件进行后台处理操作示例
- JavaWeb实现文件上传下载功能实例解析以及项目工程示例下载
- 使用thinkphp实现上传文件(uploadify插件)
- PHP实现通过CURL上传文件功能示例
- Thinkphp5+uploadify 文件上传实现
- 在MVC中利用uploadify插件实现上传文件的功能
- ThinkPHP实现带验证码的文件上传功能实例
- ajax实现文件异步上传并回显文件相关信息功能示例
- SpringMVC(24):使用springmvc+spring+jdbc 优化订单管理系统的示例(多文件上传功能的实现)
- PHP使用curl请求实现post方式上传图片文件功能示例
- PHP实现文件上传功能及ThinkPHP上传扩展
- 用thinkphp实现上传文件到数据库的功能并且文件内容不可以重复
- Golang+Android基于HttpURLConnection实现的文件上传功能示例
- 利用laravel+ajax实现文件上传功能方法示例
- Asp.net 2.0 用 FileUpload 控件实现多文件上传 用户控件(示例代码下载)