thinkphp 下多图ajax上传图片
碰到一个项目,有一个比较繁琐的功能6个ajax上传,基本上每个上传逻辑多不一样,记录一下
thinkphp的view页面:
id方便找到这个元素 name一定要加 [ ]
<div class="btns">
<a href="javascript:;" class="a-upload">
<input type="file" id="fileaq" name="fileaq[]" data-filesType="words" class="uploadInput" multiple="multiple" />
<i class="iconfont icon-shangchuan"></i>上传附件
</a>
<a href="javascript:void(0)" class="submit" id="aq_sub">发布</a>
</div>
点击发布先判定一下,然后在把需要的参数传递给doUploadFiles函数
//发布案情 $('#aq_sub').click(function() {
var guanxi = 'many_one';
var type_file = 'file';
var type_name = 'fileaq';
var anqing = $('#anqing').val();
if ($.trim(anqing).length == 0) {
layer.alert('请输入内容!\n');
$('#anqing').focus();
return false;
} else {
var cate_id = 3;
doUploadFiles(cate_id, type_file, type_name, guanxi, anqing);
}
})
参数说明
cate_id:多个上传的识别id
type_file: 判断是图片还是文件上传(nofiley:有的文件不需要上传)
type_name:上传文件的id
guanxi:关系 项目需要 参数分为many_one,many_many,one_one(多个用户每人一条数据,多个用户每人多条数据,多个用户一人一条数据)
content:内容
function doUploadFiles(cate_id, type_file, type_name, guanxi, content) {
var guanxi = arguments[3] ? arguments[3] : 'many_one'; //设置关系
var formData = new FormData();
var fangchan_id = $('#fangchan_id').val();
formData.append("fangchan_id", fangchan_id);
formData.append("cate_id", cate_id);
formData.append("guanxi", guanxi);
formData.append("content", content);
if(type_file !='nofile'){
formData.append("type_file", type_file);
formData.append("file_length", $("#"+type_name)[0].files.length);
for(var i=0; i<$("#"+type_name)[0].files.length;i++){
formData.append('file[]',$("#"+type_name)[0].files[i]);
}
} $.ajax({
url: '/Property/jindiaoHandle',
type: 'POST',
data: formData,
dataType: "json",
async: false,
cache: false,
contentType: false,
processData: false,
success: function(data) {
console.log('上传:',data)
if (data.status == 200) {
layer.msg(data.msg, { icon: 1 });
window.location.reload();
} else {
layer.msg(data.msg, { icon: 1 });
return false;
} } }); }
php代码比较长
/**
* 提交房源尽调
*/
public function jindiaoHandle()
{
$user_id = session('user_id');
$fangchan_id = I('post.fangchan_id');
$cate_id = I('post.cate_id');
$cate_arr = array('6','7','8');
$content = I('post.content');
$type_file = I('post.type_file');
$file_length = I('post.file_length'); //判断是否上传文件
//many_one 多个用户存在一条 many_many 多个用户存在多条 one_one 只能催在一条数据
$guanxi = I('post.guanxi');
$guanxi?$guanxi:'many_one';
$content?$content:'0';
if(empty($user_id)){
$ret = ['status' => '1001', 'msg' => '请先登录!'.$user_id, 'data' => ''];
$this->ajaxReturn($ret, 'json');
}else{
$level = M('users')->where(['user_id' => $user_id])->getField('level');
//判断是不是法拍经理
if ($level != 2) {
$ret = ['status' => '1002', 'msg' => '您没有权限填写!', 'data' => ''];
$this->ajaxReturn($ret);
}
}
if(empty($fangchan_id))
{
$ret = ['status' => '1003', 'msg' => '找不到此房源!', 'data' => ''];
$this->ajaxReturn($ret);
}
if(empty($cate_id))
{
$ret = ['status' => '1004', 'msg' => '找不到此尽调类型!', 'data' => ''];
$this->ajaxReturn($ret);
}
if(empty($content))
{
$ret = ['status' => '1005', 'msg' => '内容不能为空!', 'data' => ''];
$this->ajaxReturn($ret); } $fc_user_id = M('fangchan')->where(['fangchan_id' => $fangchan_id])->getField('user_id');
//判断是不是该房产的法拍经理
if ($fc_user_id == $user_id) {
$data = [
'fangchan_id' => $fangchan_id,
'user_id' => $user_id,
'cate_id' => $cate_id,
'content' => $content,
'res_num' => $file_length,
'add_time' => time(),
'is_user' => 1,
'is_show' => '1',
];
} else {
if(!in_array($cate_id,$cate_arr))
{
$fc_add_time = M('fangchan')->where(['fangchan_id' => $fangchan_id])->getField('add_time'); //获取添加时间
if ((time() - $fc_add_time) < (12 * 60 * 60)) {
$arr = ['status' => '1006', 'msg' => '请于24小时候后来发布!', 'data' => ''];
$this->ajaxReturn($arr, 'json');
}
}
$data = [
'fangchan_id' => $fangchan_id,
'user_id' => $user_id,
'cate_id' => $cate_id,
'content' => $content,
'res_num' => $file_length,
'add_time' => time(),
'is_user' => 0,
'is_show' => '1',
];
} if($guanxi=='many_one')
{
$fc_jindiao_data = M('fangchan_jindiao')
->where(['fangchan_id'=>$fangchan_id,'user_id'=>$user_id,'cate_id'=>$cate_id])
->getField('jindiao_id');
//判断房产尽调是修改还是添加
if($fc_jindiao_data){
$res_edit = M('fangchan_jindiao')->where('jindiao_id='.$fc_jindiao_data)->save($data);
}else{
$res_add = M('fangchan_jindiao')->add($data);
}
}elseif($guanxi=='one_one')
{
$fc_jindiao_data = M('fangchan_jindiao')
->where(['fangchan_id'=>$fangchan_id,'cate_id'=>$cate_id])
->getField('jindiao_id');
//判断房产尽调是修改还是添加
if($fc_jindiao_data){
$res_edit = M('fangchan_jindiao')->where('jindiao_id='.$fc_jindiao_data)->save($data);
}else{
$res_add = M('fangchan_jindiao')->add($data);
}
}elseif($guanxi=='many_many')
{
$res_add = M('fangchan_jindiao')->add($data);
} //判断是否有文件
if(!empty($file_length) || $file_length!=0)
{
$result = self::uploadFile($type_file);
if($result['status'] == -1){
exit(json_encode(array("status"=>-1,"msg"=>$result['msg'],'result'=>'')));
} $add_time = time();
if(!empty($res_edit))
{
$where=array('user_id' => $user_id,'fangchan_id' => $fangchan_id,'cate_id'=> $cate_id);
$r_info = M('fangchan_jindiao')->where($where)
->getField('jindiao_id'); if($r_info)
{
foreach ($result['result'] as $v)
{
if($type_file=='file')
{
$data=array('user_id' => $user_id,'fangchan_id' => $fangchan_id,'cate_id'=> $cate_id,'add_time'=> $add_time,'jindiao_id'=> $r_info,'file'=>$v);
$ziyuan_info = M("fangchan_jdresources")->data($data)->add();
}elseif($type_file=='image')
{
$data=array('user_id' => $user_id,'fangchan_id' => $fangchan_id,'cate_id'=> $cate_id,'add_time'=> $add_time,'jindiao_id'=> $r_info,'images'=>$v);
$ziyuan_info = M("fangchan_jdresources")->data($data)->add();
} } if($ziyuan_info)
{
$ret =[
'status'=>200,
'msg'=>'上传成功',
'data'=> $data
];
}else{
$ret =[
'status'=>1009,
'msg'=>'上传资源失败',
'data'=> ''
];
}
}else{
$ret =[
'status'=>1008,
'msg'=>'上传资源失败',
'data'=> ''
];
}
}elseif(!empty($res_add))
{
foreach ($result['result'] as $v)
{
if($type_file=='file')
{
$data=array('user_id' => $user_id,'fangchan_id' => $fangchan_id,'cate_id'=> $cate_id,'add_time'=> $add_time,'jindiao_id'=> $res_add,'file'=>$v);
$ziyuan_info = M("fangchan_jdresources")->data($data)->add();
}elseif($type_file=='image')
{
$data=array('user_id' => $user_id,'fangchan_id' => $fangchan_id,'cate_id'=> $cate_id,'add_time'=> $add_time,'jindiao_id'=> $res_add,'images'=>$v);
$ziyuan_info = M("fangchan_jdresources")->data($data)->add();
} }
if($ziyuan_info)
{
$ret =[
'status'=>200,
'msg'=>'上传成功',
'data'=> $data
];
}else{
$ret =[
'status'=>1010,
'msg'=>'上传资源失败',
'data'=> ''
];
}
}else{
$ret =[
'status'=>1011,
'msg'=>'上传资源失败',
'data'=> ''
];
}
}elseif(empty($res_add) && empty($res_edit)){
$ret =[
'status'=>1007,
'msg'=>'上传失败',
'data'=> ''
];
}else{
$ret =[
'status'=>200,
'msg'=>'上传成功',
'data'=> ''
];
}
$this->ajaxReturn($ret);
} /* *多图上传 */
public function uploadFile($type='file'){ if($type=='file')
{
$type_info = array('doc', 'docx', 'xls', 'xlsx','zip','rar');
$type_path = '/Public/upload/jidiao/files/';
}elseif($type=='image'){
$type_info = array('jpg', 'gif', 'png', 'jpeg');
$type_path = '/Public/upload/jidiao/images/';
}
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 1 * 1024 * 1024;// 设置附件上传大小
$upload->exts = $type_info;// 设置附件上传类型
$upload->rootPath = '.'.$type_path; // 设置附件上传根目录
$upload->savePath = ''; // 设置附件上传(子)目录
$upload->subName = array('date','Y/m-d');
//上传文件
$info = $upload->upload();
$picurl = array();
if(!$info) {// 上传错误提示错误信息
return array('status'=>-1,'msg'=>$upload->getError(),'result'=>'');
}else{// 上传成功 获取上传文件信息
foreach($info as $file){
$picurl[] = $type_path.$file['savepath'].$file['savename'];
}
return array("status"=>1,"msg"=>'上传成功','result'=>$picurl); } }
doUploadFiles
thinkphp 下多图ajax上传图片的更多相关文章
- thinkphp下实现ajax无刷新分页
1.前言 作为一名php程序员,我们开发网站主要就是为了客户从客户端进行体验,在这里,thinkphp框架自带的分页类是每次翻页都要刷新一下整个页面,这种翻页的用户体验显然是不太理想的,我们希望每次翻 ...
- Ajax上传图片以及上传之前先预览
手头上有几个小项目用到了easyUI,一开始决定使用easyUI就注定了项目整体上前后端分离,基本上所有的请求都采用Ajax来完成.在文件上传的时候用到了Ajax上传文件,以及图片在上传之前的预览效果 ...
- thinkphp下通过页面链接传递的参数获取一次后失效
在thinkphp下通过页面链接传递的参数获取一次后失效,ajax内部无法再次使用.想要使用必须再次用js获取其值,通过ajax传递给后台使用. 1.通过页面链接传递参数给下一页 2.可以再下一页后台 ...
- ajaxfileUpload ajax 上传图片使用
前台html: <div class="b-mg15 img-text" room_id="<?= $items['id'] ?>"> ...
- jquery下php与ajax的互传数据(json格式)自我总结
研究了一整天的json数据与ajax的数据传输,现在进行一个小的自我总结,仅供参考 1.关于ajax的认识 $.ajax(),是jquery下包装好的一个函数:参考地址:http://www.w3sc ...
- ajax上传图片
选择文件后 ajax上传图片到后台,后台执行保存操作,返回上传的图片路径,显示到页面 需要引入ajaxfileupload.js js代码 <script type="text/jav ...
- 使用ajax上传图片,支持图片即时浏览,支持js图片压缩后上传给服务器
使用ajax上传图片,支持图片即时浏览,支持js图片压缩后上传给服务器 ajax上传主要使用了 var reader = new FileReader() 此方法 js图片压缩主要是利用canvas进 ...
- asp.net core 通过ajax上传图片及wangEditor图片上传
asp.net core 通过ajax上传图片 .net core前端代码,因为是通过ajax调用,首先要保证ajax能调用后台代码,具体参见上一篇.net core 使用ajax调用后台代码. 前端 ...
- vuejs使用FormData对象,ajax上传图片文件
我相信很多使用vuejs的朋友,都有采用ajax上传图片的需求,因为前后端分离后,我们希望都能用ajax来解决数据问题,传统的表单提交会导致提交成功后页面跳转,而使用ajax能够无刷新上传图片等文件. ...
随机推荐
- 《ArcGIS Runtime SDK for Android开发笔记》——(10)、ArcGIS Runtime SDK支持的空间数据类型
1.前言 移动端的数据来源非常重要,它决定了移动端功能的实现.早期的ArcGIS Android API中,主要以接入在线的数据源为主,因此主要实现在线的地图浏览.查询和路径分析.地理处理等从操作:在 ...
- font not embeded
转自:http://blog.csdn.net/chenyusiyuan/article/details/4078671,感谢分享! 装了半天adobe acrobat distiller 要泪崩,解 ...
- PHP time() date() strtotime()日期函数总结
日期函数总结—— 一.返回时间戳——若整体数值超出计算机能力范围,返回空. 1. time();返回当前的 Unix 时间戳 例:$a=time(); var_dump($a); //输出:int( ...
- log4j 配置详解
参考如下两个网址,讲的很详细,先看第一个再看第二个: log4j使用介绍:http://swiftlet.net/archives/683 java日志处理组件log4j--log4j.xml配置详解 ...
- ORACLE查询删除重复记录三种方法
本文列举了3种删除重复记录的方法,分别是rowid.group by和distinct,小伙伴们可以参考一下. 比如现在有一人员表 (表名:peosons) 若想将姓名.身份证号.住址这三个字段完 ...
- day008-File文件
1. File 文件和目录路径名的抽象表示形式. 一个File类对象就代表了一个文件或文件夹. 1.1 File类的作用 用来操作硬盘上的文件或文件夹 绝对路径:一般是以盘符开始的,比如:C:/Jav ...
- 【量产工具修复】U盘插上没反应,格式化提示有写保护
最近在实验室发现师兄留下的U盘,插上电脑后打不开,弹出格式化界面,格式化的时候又提示该u盘“被写保护无法格式化”,于是打算采用量产的方法. 第一步:使用chipgenius监测u盘的芯片制造商和型号 ...
- RAC共享磁盘挂载工具
待更新: oracleasm: udev: 自己搭建个存储服务器:
- 用一个实际例子理解Docker volume工作原理
要了解Docker Volume,首先我们需要理解Docker文件系统的工作原理.Docker镜像是由多个文件系统的只读层叠加而成.当一个容器通过命令docker run启动时,Docker会加载只读 ...
- 如何在Chrome development tool里查看C4C前台发送的请求细节
我们可以在Chrome development tool的network tab里观察到从前台UI发送到后台的HTTP请求: 更多Chrome Development Tool的使用工具请查看我的博客 ...