php + layui 文件上传 以及 拖拽上传
HTML:
<div id="box">
<div id="drop_area">将文件拖拽到此区域</div>
<div id="area_img"> <img src="../images/tzsc.png" id="img_upfiles" style="cursor: pointer"/> </div>
</div>
<div class="layui-form-item">
<div class="layui-input-block">
<div class="layui-upload" style="margin-left: 730px">
<button type="button" class="layui-btn layui-btn-normal" id="upfiles"> <i class="layui-icon"></i> 文件上传 </button>
<span style="color: #666"></span>
</div>
<table id="tabl1" class="layui-table" style="width: 850px;margin-top: -38px;margin-left: -110px;">
<colgroup>
<col width="300"><col width="80"><col width="160"><col width="300">
</colgroup>
<thead>
<tr>
<th>文件名称</th><th>类型</th><th>操作</th><th>备注</th>
</tr>
</thead>
<tbody id="fileList"></tbody>
</table>
</div>
</div>
JS:
XMLhttpReuest.js
function ajaxFunction()
{
var xmlHttp;
try
{
// Firefox, Opera 8.0+, Safari
xmlHttp=new XMLHttpRequest();
}
catch (e)
{
// Internet Explorer
try
{
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e)
{
try
{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e)
{
alert("您的浏览器不支持AJAX!");
return false;
}
}
}
return xmlHttp;
}
{?*拖拽上传*?}
<script>
window.onload = function () {
var box = document.getElementById('box');
box.ondragenter = function (e) {
e.preventDefault();
}
box.ondragover = function (e) {
e.preventDefault();
}
box.ondragleave = function (e) {
e.preventDefault();
}
box.ondrop = function (e) {
e.preventDefault();
var file = e.dataTransfer.files[0];
var formData = new FormData();
formData.append('file', file); var xml = ajaxFunction();
xml.open("post", './ajax.files.upload.php?MID={?$lev.MID?}&upfilecode={?$upfilecode?}&path=djyp_file', true);
xml.send(formData);
xml.onreadystatechange = function () {
console.log(xml.readyState);
console.log(xml.status);
if(xml.readyState == 4 && xml.status==200){
var res=JSON.parse(xml.responseText);
if(res.code > 0){
layer.msg(res.msg);
}else {
var tr = $(['<tr>'
, ' <td><input type="text" autocomplete="off" placeholder="请输入文件名称" value="' + res.old_name + '" name="old_name[' + res.id + ']"></td>'
, '<td>' + res.file_ext + '</td>'
, '<td>'
, '<a class="layui-btn layui-btn-warm layui-btn-xs fileread" href="' + res.path + res.new_name +'.'+ res.file_ext + '" target="_blank"> <i class="layui-icon layui-icon-read"></i>查看 </a>'
, '<button type="button" class="layui-btn layui-btn-xs filedel" style="background: #ff5722;"> <i class="layui-icon layui-icon-delete"></i>删除 </button>'
, '</td>'
, ' <td><input type="text" autocomplete="off" placeholder="请输入备注" name="old_name1[' + res.id + ']"></td>'
, '</tr>'].join(''));
//删除
tr.find('.filedel').on('click', function () {
$.post('ajax.attach.file.del.php?MID={?$lev.MID?}',{id:res.id},function(data){
if (data.code > 0)
parent.layer.msg(data.msg, {offset: '0px', icon: 2, time: 1000});
else
tr.remove();
}); });
$("#fileList").append(tr); var title = $("#title");
if(title.val() == '')
title.val(res.old_name);
}
}
}
}
}
</script>
php:
ajax.files.upload.php
header("Content-Type:text/html;charset=UTF-8");$CODE = $_GET['upfilecode'];
$PATH = $_GET['path']; $a = new UPFILE($CODE, $PATH, $_FILES['file'], $pl); class UPFILE
{
public $pl = '';
public $file = ''; public function __construct($code, $path, $file, $pl)
{
if ($code == '')
$this->ExtFrm(1, "缺少上传编码");
if ($path == '')
$this->ExtFrm(2, "缺少上传路径");
if (!$file)
$this->ExtFrm(3, "找不到上传文件");
if ($file['size'] > 1024 * 1024 * 50) {
$this->ExtFrm(3, "上传失败,文件大小超过限制(文件大小:50MB)");
}
$size=round($file['size']/1024/1024, 2);
$this->pl = $pl;
$this->file = $file;
$this->type = $path; $filePath = $this->createFile($path);
$fileOld = $this->verifyFile();
$this->fileupload($code, $filePath, $fileOld,$size);
} /**
* Method:createFile
* Desc:创建文件路径
*/
public function createFile($path)
{
$Ym = date('Ym');
$filepath = $Ym . ($path != "" ? "/" : "") . $path;
$fullpath = '../upfiles/' . $filepath;
if (!is_dir($fullpath)) {
$res = mkdir($fullpath, 0777, true);
}
return array($filepath . "/", $fullpath . "/");
} /**
* Method:verifyFile
* Desc:验证文件格式
*/
public function verifyFile()
{
$pinfo = pathinfo($this->file["name"]);
$extension = strtolower($pinfo['extension']);
switch ($this->type) {
case 'message_img': //消息推送 - 富文本 图片上传
$file_format = array("jpg", "jpeg", "gif", "png");
if (!in_array($extension, $file_format)) {
$this->ExtFrm(4, "上传失败,文件格式不正确(支持:jpg,gif,png)");
}
break;
default:
$file_format = array("jpg", "jpeg", "gif", "png", "rar", "zip", "doc", "docx", "xls", "xlsx", "pdf", "txt", "ppt", "pptx", "tif",'mp4');
if (!in_array($extension, $file_format)) {
$this->ExtFrm(4, "上传失败,文件格式不正确(支持:jpg,gif,png,rar,zip,doc,docx,xls,xlsx,pdf,txt,ppt,pptx,tif,mp4)");
}
break;
}
return array("filename" => $pinfo['filename'], "extension" => $extension);
} /**
* Method:fileupload
* Desc:上传文件
*/
public function fileupload($code, $filepath, $fileold,$size)
{
$old_name = $fileold['filename'];
$new_name = time() . rand(0, 500000) . dechex(rand(0, 10000));
move_uploaded_file($this->file['tmp_name'], $filepath[1] . $new_name . "." . $fileold['extension']); if ($this->type != 'message_img') {
$sql = "insert into system_attach (`BM`,`YFJMC`,`XFJMC`,`WJLJ`,`WJLX`,`CJSJ`,`CJRID`,`CJRMC`,`SIZE`) values (:BM,:YFJMC,:XFJMC,:WJLJ,:WJLX,:CJSJ,:CJRID,:CJRMC,:SIZE)";
$this->pl->query($qry, $sql, array(
":BM" => $code,
":YFJMC" => $old_name . ".",
":XFJMC" => $new_name . "." . $fileold['extension'],
":WJLJ" => $filepath[0],
":WJLX" => $fileold['extension'],
":CJSJ" => date("Y-m-d H:i:s"),
":CJRID" => $_SESSION['UID'],
":CJRMC" => $_SESSION['NAME'],
":SIZE" => $size,
));
$id = $this->pl->insert_id();
}
$this->ExtFrm(0, "上传成功", $id, $filepath[1], $new_name, $old_name, $fileold['extension']);
} /**
* Method:extFrm
* Desc:结果返回
*/
public function extFrm($code, $msg, $id = 0, $filepath = "", $new_name = '', $old_name = '', $file_ext = "")
{
if ($code > 0) {
$ExtFrm = array("code" => $code, "msg" => $msg);
} else if ($this->type == 'message_img') {
$title = $new_name . "." . $file_ext;
$ExtFrm = array("code" => $code, "msg" => $msg, "data" => array("src" => $filepath . $title, "title" => $title));
} else {
$ExtFrm = array("code" => $code, "msg" => $msg, "id" => $id, "path" => $filepath, "new_name" => $new_name, "old_name" => $old_name, "file_ext" => $file_ext);
}
exit(json_encode($ExtFrm));
}
} ?>
php + layui 文件上传 以及 拖拽上传的更多相关文章
- js拖拽上传 文件上传之拖拽上传
由于项目需要上传文件到服务器,于是便在文件上传的基础上增加了拖拽上传.拖拽上传当然属于文件上传的一部分,只不过在文件上传的基础上增加了拖拽的界面,主要在于前台的交互, 从拖拽的文件中获取文件列表然后调 ...
- 图片上传插件ImgUploadJS:用HTML5 File API 实现截图粘贴上传、拖拽上传
一 . 背景及效果 当前互联网上传文件最多的就是图片文件了,但是传统web图片的截图上传需要:截图保存->选择路径->保存后再点击上传->选择路径->上传->插入. 图片 ...
- bat cmd dos 通过拖拽参数 上传 截取拖拽上传文件名
echo off setlocal enabledelayedexpansion :: L 小写 for /l %%i in (1,1,10000) do ( :con set /p a= selec ...
- 用HTML5 File API 实现截图粘贴上传、拖拽上传
<!DOCTYPE html><html><head> <title>test chrome paste image</title> < ...
- 基于 jq 实现拖拽上传 APK 文件,js解析 APK 信息
技术栈 jquery 文件上传:jquery.fileupload,github 文档 apk 文件解析:app-info-parser,github 文档 参考:前端解析ipa.apk安装包信息 - ...
- 实现拖拽上传文件的一款小控件——dropzone
由于专注所以专业.非常多小巧的东西乍一看非常不起眼,却在特定的领域表现不俗,就是由于集中了热情. dropzone就是这样一款小控件,实现拖拽上传.它不依赖于其他像jquery等JS库.并且支持多方面 ...
- Dropzone.js实现文件拖拽上传
dropzone.js是一个开源的JavaScript库,提供 AJAX 异步文件上传功能,支持拖拽文件.支持最大文件大小.支持设置文件类型.支持预览上传结果,不依赖jQuery库. 使用Dropzo ...
- HTML5应用之文件拖拽上传
使用HTML5的文件API,可以将操作系统中的文件拖放到浏览器的指定区域,实现文件上传到服务器.本文将结合实例讲解HTML5+jQuery+PHP实现拖拽上传图片的过程,来看下HTML5的魅力吧. H ...
- [开源应用]利用HTTPHandler+resumableJs+HTML5实现拖拽上传[大]文件
前言: 大文件传输一直是技术上的一大难点.文件过大时,一些性提交所有的内容进内存是不现实的.大文件带来问题还有是否支持断点传输和多文件同时传输. 本文以resumableJs为例,介绍了如何在ASP. ...
- html5 文件拖拽上传
本文首先发表在 码蜂笔记 : http://coderbee.net/index.php/web/20130703/266 html5 文件拖拽上传是个老话题了,网上有很多例子,我一开始的代码也是网 ...
随机推荐
- KingbaseES R3 集群pcp_attach_node 更新show pool_nodes中节点状态
系统环境: 操作系统: [kingbase@node2 bin]$ cat /etc/centos-release CentOS Linux release 7.2.1511 (Core) 数据库: ...
- JavaWeb核心篇(2)——Request和Response
JavaWeb核心篇(2)--Request和Response 上篇文章中提及到了Servlet,在Servlet中我们主要继承了HTTPServlet类,在HTTPServlet类中我们会接触到两个 ...
- 目标检测-SSD算法从零实现
1. 几个工具函数 def box_corner_to_center(boxes): """从(左上,右下)转换到(中间,宽度,高度)""" ...
- 好书推荐之Mysql三剑客 :《高性能Mysql》、《Mysql技术内幕》、《数据库索引设计与优化》
Mysql三剑客系列书籍: 大佬推荐 首先推荐<高性能 MySQL>,这本书是 MySQL 领域的经典之作,拥有广泛的影响力.不但适合数据库管理员(DBA)阅读,也适合开发人员参考学习.不 ...
- Elasticsearch 主从同步之跨集群复制
文章转载自:https://mp.weixin.qq.com/s/alHHxXont6XFm_m9PfsGfw 1.什么是跨集群复制? 跨集群复制(Cross-cluster replication, ...
- Portainer安装,配置自定义镜像仓库拉取镜像
Portainer介绍 Portainer是Docker的图形化管理工具,提供状态显示面板.应用模板快速部署.容器镜像网络数据卷的基本操作(包括上传下载镜像,创建容器等操作).事件日志显示.容器控制台 ...
- 使用Fluentd进行简单流处理
在某些日志采集场景中,我们需要对数据流进行一些转换.比如,我们可能需要从日志记录中提取某些字段以进行错误告警,或向日志记录中插入新的字段用以后续的分析. 本文简单介绍一下使用Fluentd进行数据操作 ...
- PAT (Basic Level) Practice 1029 旧键盘 分数 20
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及实际被输入的文字,请你列出肯定坏掉的那些键. 输入格式: 输入在 2 行中分别给出应该输入的文字.以及 ...
- 数据火器库八卦系列之瑞士军刀随APP携带的SQLite
来源:云数据库技术 数据库打工仔喃喃自语的八卦历史 1. 为导弹巡洋舰设计,用在手机上的数据库 2. Small and Simple, and Better 3. 如何看出是自己的娃:产品定位,特点 ...
- LOJ139 树链剖分
题目 感觉这已经不能说是模板了吧...... 解析: 难点在于换根后对子树进行的操作,设rt为当前根节点,u为操作子树: u=rt时,就是对整棵树操作,没事么好说的. rt不在u的子树范围内,操作对象 ...