PHP+jQuery+Ajax实现多图片上传介绍

PHP+jQuery+Ajax实现多图片上传介绍:

本文中用到一个Ajax表单提交插件:jqery.form.js,有高人修改了几行代码并改名为:jquery.wallform.js,直接拿来用。

下面就来就来介绍一下这一款功能强大的插件的使用,需要的朋友可以做一下参考.

在不刷新页面的前提下,使用PHP+jQuery+Ajax实现多图片上传的效果。用户只需要点击选择要上传的图片,然后图片自动上传到服务器上并展示在页面上,效果图如下:

一.HTML代码:

在页面上放置一个form表单,使用post提交到后台php处理程序upload.php,注意enctype属性设置要支持文件上传。#preview用来显示上传完毕后的图片。关于css样式设置本文不加说明,请参照下载包的源码.

<form id="imageform" method="post" enctype="multipart/form-data" action="upload.php">
  <div id="up_status" style="display:none"><img src="loader.gif" alt="uploading"/></div>
  <div id="up_btn" class="btn"> <span>添加图片</span>
    <input id="photoimg" type="file" name="photoimg">
  </div>
</form>
<p>最大100KB,支持jpg,gif,png格式。</p>
<div id="preview"></div>

二.jQuery代码:

本实例基于jQuery,因此必须在页面中载入jquery库以及jquery.wallform.js。

<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="jquery.wallform.js"></script>

当点击按钮“添加图片”后,弹出选择文件对话框,选择要上传的图片后,触发change事件。

然后表单#imageform调用jquery.wallform.js的ajaxForm()方法,将表单数据提交给后台PHP处理,并根据返回结果处理页面元素的展示。如果上传成功,图片会一张张排列显示在页面上。关于ajaxForm()的使用可以参照本站文章:Ajax表单提交插件jqery form。

$(function(){
  $(‘#photoimg‘).die(‘click‘).live(‘change‘, function(){
    var status = $("#up_status");
    var btn = $("#up_btn");
    $("#imageform").ajaxForm({
      target: ‘#preview‘,
      beforeSubmit:function(){
        status.show();
        btn.hide();
      },
      success:function(){
        status.hide();
        btn.show();
      },
      error:function(){
        status.hide();
        btn.show();
      }
        }).submit();
  });
});

三.php代码:

upload.php处理图片上传,并将上传好的图片保存在uploads/目录,注意该目录要有写权限。

首先需要检测是否为POST方式提交,然后判断图片格式、图片大小是否符合要求,然后使用move_uploaded_file()上传图片,并将图片重命名,格式为:time().rand(100,999)。

$path = "uploads/";
$extArr = array("jpg", "png", "gif");
if(isset($_POST) and $_SERVER[‘REQUEST_METHOD‘] == "POST"){
  $name = $_FILES[‘photoimg‘][‘name‘];
  $size = $_FILES[‘photoimg‘][‘size‘];
  if(empty($name)){
    echo ‘请选择要上传的图片‘;
    exit;
  }
  $ext = extend($name);
  if(!in_array($ext,$extArr)){
    echo ‘图片格式错误!‘;
    exit;
  }
  if($size>(100*1024)){
    echo ‘图片大小不能超过100KB‘;
    exit;
  }
  $image_name = time().rand(100,999).".".$ext;
  $tmp = $_FILES[‘photoimg‘][‘tmp_name‘];
  if(move_uploaded_file($tmp, $path.$image_name)){
    echo ‘<img src="‘.$path.$image_name.‘"  class="preview">‘;
  }
  else{
    echo ‘上传出错了!‘;
  }
  exit;
}
//获取文件类型后缀
function extend($file_name){
  $extend = pathinfo($file_name);
  $extend = strtolower($extend["extension"]);
  return $extend;
}

原文地址:http://www.51texiao.cn/jqueryjiaocheng/2015/0525/2456.html

最原始地:http://www.softwhy.com/forum.php?mod=viewthread&tid=17183

时间: 2024-10-09 05:46:43

PHP+jQuery+Ajax实现多图片上传介绍的相关文章

在 PHP 中结合 Ajax 技术进行图片上传

前面几则日志中讲述了在 PHP 中上传文件,相信大家对 PHP 中如何进行文件上传已经初步掌握.本文来继续探讨在 PHP 中上传文件的技术,不同的是,本次上传将仅限于图片文件的上传,并且将采用 Ajax 技术. 本例将要实现这样的效果:当用户选择图片,开始上传后,后台上传完成时,随即会显示到当前页面.由于,从开始上传到上传完成,再到图片显示均在一个页面上 完成(从表面上看).所以使用 Ajax 技术是必须的.但如何使用这些操作在一个页面上来完成呢?考虑到这样的情况,当文件开始上传后,便开始打开

php:利用插件uploadify完成ajax效果的图片上传

可选项需要参数类型 参数名字 解释(布尔型) auto 当文件被添加到队列时,自动上传.(字符串) buttonImg 浏览按钮的背景图片路径.(字符串)   buttonText  默认在按钮上显示的文本.(字符串)  cancelImg    取消按钮的背景图片路径.(字符串)   checkScript   用以检查服务器上已存在文件的后台脚本的路径.[译者注:应该是ajax方式](字符串)   displayData   在上传过程中显示在队列里的数据类型.(字符串)   express

在php中使用jquery uploadify进行多图片上传

jquery uploadify是一款Ajax风格的批量图片上传插件,在PHP中使用jquery uploadify很方便,请按照本文介绍的方法和步骤,为你的PHP程序增加jquery uploadify插件的批量上传图片功能. 本文是以dilicms为基础,为其增加图片上传功能. 1.增加数据表dili_fieldtypes新字段:k=>image,V=>图片上传区域(VACHAR): 2.修改application/libraries/dili/Field_behavior.php,在sw

Jersey后端服务接收ajax前端的图片上传

近期的项目里需要在前端上传图片后端接收处理.前端JSP页面使用Ajax上传图片后端使用Jersey框架提供restful接口接收处理图片. 一.前端的处理 jsp页面中图片上传没有使用form表单而是直接使用file类型的input控件 <input type="file" name="file" class="inpTxtA" value="" id="appLogo"/> <input

jQuery AJAX 网页无刷新上传示例

新年礼,提供简单.易套用的 jQuery AJAX 上传示例及代码下载.后台对文件的上传及检查,以 C#/.NET Handler 处理 (可视需要改写成 Java 或 PHP). 有时做一个网站项目 (不论是否 ASP.NET),内附的 FileUpload 控件,功能不足 (页面必须刷新.不支援 AJAX),或外观太丑被用户嫌弃 (却无法透过 CSS 自定义外观).网路上虽已有许多可用的示例,如: jQuery File Upload,但功能太强大.外观复杂,欲仅取出部分功能来引用,反而不易

JQUERY AJAX无刷新异步上传文件

AJAX无刷新上传文件并显示 http://blog.csdn.net/gao3705512/article/details/9330637?utm_source=tuicool jQuery Form Plugin 官网地址:http://malsup.com/jquery/form/#tab7 基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用 http://www.cnblogs.com/wuhuacong/p/3343967.html

通过jQuery Ajax使用FormData对象上传文件

转自:http://www.cnblogs.com/labnizejuly/p/5588444.html FormData对象,是可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单". <form id="uploadForm" enctype="multipart/form-data"> <input id="file" type="file"

JavaWeb图片上传的几种方式

一.图片上传介绍 JavaWeb方向编程过程中,实现图片上传有三种方式: 1.传统的基于springMVC的MultipartFile类实现图片上传. 2.基于Ajax的图片上传. 3.基于Base64压缩的图片上传. 二.springMVC图片上传(springboot通用) 此方法的优点是可以将图片和其他的表单元素一起提交到服务器,服务器接受到的图片其实已经存储于容器的临时文件中,进行文件拷贝工作比较简单. 缺点是无法及时看到图片上传的预览效果,图片一旦选择错误只能重新提交. 注:红色代码为

summernote 图片上传

<script type="text/javascript"> $(document).ready(function () { function sendFile(file, editor, $editable) { var formData = new FormData(); formData.append('file', file); // XMLHttpRequest 对象 var xhr = new XMLHttpRequest(); xhr.open("