ajax上传图片的本质

简介:

1.图片上传到服务器。

2.后台将图片地址传到html页面,以图片形式展现。

3.后天将图片地址加入到input表单中,表单处于隐藏状态。

4.前端删除图片,通过js操作,移除图片与表单数据。

5.图片上传表单,是单独的。不能嵌套在总的表单中。

6.牛逼的图片上传,可以对图片进行处理。压缩,加水印等。

7.点击btn,触发图片点击,图片改变之后,触发图片表单提交。

  • 点击按钮
<div id="up_status" style="display:none"><img src="{sh::PUB}/img/loader.gif" alt="uploading"/></div>
 <div id="up_btn" class="carousel-btn">
   <span>添加图片</span> 
 </div>
<div id="carousel-preview"></div>
  • 上传表单
<form id="imageform" class="hidden" method="post" enctype="multipart/form-data" action="{sh::U('Goods/carouselUpload')}">
    <input id="carousel-photoimg" type="file" name="photoimg">
</form>
  • 触发事件
$("#up_btn").click(function () {
            $("#carousel-photoimg").click();
        });
$('#carousel-photoimg').on('change', function(){
            var status = $("#up_status");
            var btn = $("#up_btn");
            $("#imageform").ajaxForm({
                target: '#carousel-preview', 
                beforeSubmit:function(){ // 提交前,用加载的图片显示
                    status.show();
                    btn.hide();
                }, 
                success:function(){ // 提交后,加载的图片显示
                    status.hide();
                    btn.show();
                }, 
                error:function(){
                    status.hide();
                    btn.show();
            } }).submit();
        });
  • 后端验证与处理
 function carouselUpload() {
        $path = "Uploads/Store/goods/".date("Ymd").'/';
        if (!file_exists($path)) {
            mkdir($path, 0777, true);
        }
        $extArr = array("jpg", "png", "gif","jpeg");

        if(isset($_POST) and $_SERVER['REQUEST_METHOD'] == "POST"){
            $name = $_FILES['photoimg']['name'];
            $size = $_FILES['photoimg']['size'];
            
            if(empty($name)){
                echo '请选择要上传的图片';
                exit;
            }
            $ext = $this->extend($name);
            if(!in_array($ext,$extArr)){
                echo '图片格式错误!';
                exit;
            }
            if($size>(2000*1024)){
                echo '图片大小不能超过2M';
                exit;
            }
            $image_name = time().rand(100,999).".".$ext;
            $tmp = $_FILES['photoimg']['tmp_name'];
            if(move_uploaded_file($tmp, $path.$image_name)){
                echo '<div class="carousel-container" onclick="deleteImg(this);">
                <img src="'.PUB.'img/delete.png" class="carousel-container-del">
                <input name="goodsimg[]" value="'.$path.$image_name.'" type="hidden">
                <img src="'.$path.$image_name.'"  class="preview">
                </div>';
            }else{
                echo '上传出错了!';
            }
            exit;
        }
        exit;
    }


    function extend($file_name){
        $extend = pathinfo($file_name);
        $extend = strtolower($extend["extension"]);
        return $extend;
    }
  • 删除图片文件
function deleteImg(obj) {
        $(obj).remove();
        // ajax 删除图片文件
        var src = $(obj).data('src');
        $.ajax({
           type: "POST",
           url: "{sh::U('Goods/deleteImg')}",
           data: "src="+src,
           success: function(msg){}
        });
    }
// 删除图片,避免造成空间不足
    public function deleteImg() {
        if (IS_AJAX) {
            $src = $this->_post('src');
            if(!unlink($src))
            {
                echo "文件{$src}删除失败";
            }
            else
            {
                echo "文件{$src}删除成功";
            }
        }
    }

本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/5245205.html,如需转载请自行联系原作者

相关文章
|
Web App开发 JavaScript 前端开发
前端接收数据流实现图片预览效果--ajax 请求二进制流 图片 文件 XMLHttpRequest 请求并处理二进制流数据 之最佳实践
本文为转载文章 原文链接:https://www.cnblogs.com/cdemo/p/5225848.html 首先要谢谢这位大神的无私贡献!解决了我的问题也完美表达了我当时的心路历程 ajax 请求二进制流 图片 文件 XMLHttpRequest 请求并处理二进制流数据 之最佳实践 写在前面 :从提出需求到完美的解决问题,实现过程是曲折的。
8118 0
|
7月前
jq+ajax上传图片信息
jq+ajax上传图片信息
31 1
|
8月前
|
前端开发 JavaScript
使用ajax上传图片
使用ajax上传图片
33 0
|
前端开发
ajax 通过move_uploaded_file函数上传图片获取$_FILES['file']对象的属性内容
ajax 通过move_uploaded_file函数上传图片获取$_FILES['file']对象的属性内容
58 0
|
前端开发
使用SpringMvc跨服务器上传图片,Ajax异步刷新图片框显示图片功能请求不到后台,onChange事件没有激活的源码?
使用SpringMvc跨服务器上传图片,Ajax异步刷新图片框显示图片功能请求不到后台,onChange事件没有激活的源码?
107 0
使用SpringMvc跨服务器上传图片,Ajax异步刷新图片框显示图片功能请求不到后台,onChange事件没有激活的源码?
|
开发框架 移动开发 前端开发
ASP.NET MVC中使用jQuery Ajax通过FormData对象异步提交图片文件到服务端保存并返回保存的图片路径
ASP.NET MVC中使用jQuery Ajax通过FormData对象异步提交图片文件到服务端保存并返回保存的图片路径
296 0
|
前端开发
ajax图片上传
ajax图片上传
163 0
|
JSON 前端开发 JavaScript
ajax实现异步上传图片
ajax方法的使用,多文件的上传,
6673 0
|
JavaScript 前端开发 .NET