前端上传图片的三种方法

前端上传图片的三种方法

Django框架下,在前端上传文件,保存在数据库,并在前端不刷新页面显示上传图片。

  • 利用XMLHttpRequest 对象和FormData对象上传文件
  • Ajax上传文件
  • 基于form表单和iframe自己实现ajax请求

1、首先创建数据库表

class Img(models.Model):
    path = models.CharField(max_length=128)

更新数据库

>python manage.py makemigrations

>python manage.py migrate

2、在Django后台views中定义函数

#前端上传文件,保存在数据库,并在前端不刷新页面显示上传图片
import os,json
@csrf_exempt
def upload(request):
    if request.method == ‘GET‘:
        img_list = models.Img.objects.all()
        return render(request,‘upload.html‘,{‘img_list‘: img_list})
    elif request.method == "POST":
        user = request.POST.get(‘user‘)
        fafafa = request.POST.get(‘fafafa‘)
        obj = request.FILES.get(‘fafafa‘)

        file_path = os.path.join(‘static‘,‘upload‘,obj.name)
        f = open(file_path, ‘wb‘)
        for chunk in obj.chunks():
            f.write(chunk)
        f.close()

        models.Img.objects.create(path=file_path)

        ret = {‘status‘: True, ‘path‘: file_path}

        return HttpResponse(json.dumps(ret))

3、添加urls路径

url(r‘^upload.html$‘, views.upload),

4、前端文件上传的三种方法

第一种、XML的方式上传文件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .container img{
            width: 200px;
            height:200px;
        }
    </style>
</head>
<body>
<h1>图片列表</h1>
    <div class="container" id="imgs">
        {% for img in img_list %}
            <img src="/{{ img.path }}"/>
        {% endfor %}
    </div>

    <input type="file" id="img">
    <input type="button" value="提交XML" onclick="UploadXML()"/>
    <input type="button" value="提交JQ" onclick="Uploadjq()"/>

<script src="/static/jquery-2.1.4.min.js"></script>
    <script>
        //XML的方式上传文件,并在页面不刷新显示图片
        function UploadXML(){
            var dic = new FormData();
            dic.append(‘user‘, ‘v1‘);
            dic.append(‘fafafa‘,document.getElementById(‘img‘).files[0]);

            var xml = new XMLHttpRequest();
            xml.open(‘post‘, ‘/upload.html‘,true);
            xml.onreadystatechange = function () {
                if (xml.readyState == 4){
                    var obj = JSON.parse(xml.responseText);
                    if (obj.status){
                        var img = document.createElement(‘img‘);
                        img.src = "/" + obj.path;
                        $(‘#imgs‘).append(img);
                    }
                }
            };
            xml.send(dic);
        }
    </script>
</body>
</html>

第二种、ajax方式上传文件,并异步显示

      <input type="file" id="img">
    <input type="button" value="提交XML" onclick="UploadXML()"/>
    <input type="button" value="提交JQ" onclick="Uploadjq()"/>

    <script src="/static/jquery-2.1.4.min.js"></script>
    <script>     

       //ajax方式上传文件,并异步显示
        function Uploadjq(){
            var dic = new FormData();
            dic.append(‘user‘, ‘v1‘);
            dic.append(‘fafafa‘,document.getElementById(‘img‘).files[0]);
            $.ajax({
                url:‘/upload.html‘,
                type:‘POST‘,
                data:dic,
                processData:false,// tell jQuery not to process the data  默认情况下jquary会对数据做处理
                contentType:false,   // tell jQuery not to set contentType
                dataType:‘JSON‘,
                success: function (arg) {
                    if (arg.status){
                        var img = document.createElement(‘img‘);
                        img.src = "/" + arg.path;
                        $(‘#imgs‘).append(img);
                    }
                }
                })
        }

第三种、基于form表单和iframe自己实现ajax请求

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .container img{
            width: 200px;
            height:200px;
        }
    </style>
</head>
<body>
    <h1>测试iframe功能</h1>
    <input type="text" id="url"/>
    <input type="button" value="点我" onclick="iframChange()">
    <iframe id="ifr" src=""></iframe>
    <hr/>
    <h1>基于ifram实现form提交</h1>
    <form action="/upload.html" method="post" target="iframe_1" enctype="multipart/form-data">
        <iframe style="display: none" id="iframe_1" name="iframe_1" src="" onload="loadIframe()"></iframe>
        <input type="text" name="user"/>
        <input type="file" name="fafafa"/>
        <input type="submit" value="确定"/>
    </form>
    <h1>图片列表</h1>
    <div class="container" id="imgs">
        {% for img in img_list %}
            <img src="/{{ img.path }}"/>
        {% endfor %}
    </div>

<script src="/static/jquery-2.1.4.min.js"></script>
    <script>

 //测试
        function iframChange(){
            var url = $(‘#url‘).val();
            $(‘#ifr‘).attr(‘src‘,url);

        }
        //基于form表单和iframe自己实现ajax请求
        function loadIframe(){
            console.log(2);
            // 获取iframe内部的内容
            var str_json = $(‘#iframe_1‘).contents().find(‘body‘).text();
            var obj = JSON.parse(str_json);
            if (obj.status){
                var img = document.createElement(‘img‘);
                img.src = "/" + obj.path;
                $(‘#imgs‘).append(img);
            }
        }

    </script>
</body>
</html>

原文地址:https://www.cnblogs.com/11wayne/p/9242770.html

时间: 2024-10-26 09:52:42

前端上传图片的三种方法的相关文章

Javascript定义类(class)的三种方法

注:本文转自阮一峰,觉得此篇文章对我对大家有帮助,因此转过来. 将近20年前,Javascript诞生的时候,只是一种简单的网页脚本语言.如果你忘了填写用户名,它就跳出一个警告. 如今,它变得几乎无所不能,从前端到后端,有着各种匪夷所思的用途.程序员用它完成越来越庞大的项目.Javascript代码的复杂度也直线上升.单个网页包含10000行Javascript代码,早就司空见惯.2010年,一个工程师透露,Gmail的代码长度是443000行! 编写和维护如此复杂的代码,必须使用模块化策略.目

Node.JS的表单提交及OnceIO中接受GET/POST数据的三种方法

OnceIO 是 OnceDoc 企业私有内容(文档)管理系统的底层Web框架,它可以实现模板文件.静态文件的全缓存,运行起来完全不需要I/O操作,并且支持客户端缓存优化,GZIP压缩等(只压缩一次),拥有非常好的性能,为您节约服务器成本.它的模块化功能,可以让你的Web进行分布式存储,在一个扩展包里即可包含前端.后端和数据库定义,只需通过添加/删除目录的方式就可实现功能删减,实现真正的模块化扩展.目前 OnceIO 已经开源,本文主要介绍node.js语言中的表单提交及OnceIO中接受GET

AJAX实现跨域的三种方法

转 由于在工作中需要使用AJAX请求其他域名下的请求,但是会出现拒绝访问的情况,这是因为基于安全的考虑,AJAX只能访问本地的资源,而不能跨域访问. 比如说你的网站域名是aaa.com,想要通过AJAX请求bbb.com域名中的内容,浏览器就会认为是不安全的,所以拒绝访问. 会出现跨域问题的几种情况: 后台在百度上寻找解决方案解决了这个问题,一共总结出三种方案:代理.JSONP.XHR2(XMLHttpRequest Level 2). 第一种方法 代理:这种方式是通过后台(ASP.PHP.Ja

用旭日图展示数据的三种方法

什么是旭日图? 旭日图(Sunburst Chart)是一种现代饼图,它超越传统的饼图和环图,能表达清晰的层级和归属关系,以父子层次结构来显示数据构成情况.旭日图中,离远点越近表示级别越高,相邻两层中,是内层包含外层的关系. 在实际项目中使用旭日图,可以更细分溯源分析数据,真正了解数据的具体构成.而且,旭日图不仅数据直观,而且图表用起来特别炫酷,分分钟拉高数据汇报的颜值!很多数据场景都适合用旭日图,比如,在销售汇总报告中,方便看到每个店铺的销售业绩分布(如下图): 做旭日图的三种方法 1. 用E

实现滚动定位的三种方法

Web页面的定位,据我所知,有三种:一.锚点定位:二.通过js的window.scroll(x,y)或window.scrollTo(x,y):三.通过js的window.scrollBy(x,y). 锚点定位,缺点: 定位不准确,而且有兼容性问题. 所以,大多数情况下用第二种或第三种方法. 注:以下两种方法的代码均可以直接使用,不依赖于任何第三方库或框架. 下面分析下第二种方法的实现原理: 核心:window对象的两个属性:scrollTop, offsetTop. 看下这两个属性的区别: 该

Struts2关于Action的系统训练6关于action接收参数的三种方法

我们知道,action在web开发中起到了控制器的作用,通过接收客户端传来的参数,执行不同的模块才实现操作,所以说接收参数是很重要的一环,只有接收前端的参数,才能执行数据库的操作等后台业务逻辑,那么就开始一一展示这三种方法吧(只用看action类的编写即可) 1第一种方式:UserAction.java package com.bjsxt.struts2.user.action; import com.opensymphony.xwork2.ActionSupport; public class

SpringMVC的请求转发的三种方法

SpringMVC请求转发的三种方法 首先明白请求转发是一次请求,地址栏不会发生变化,区别于重定向.springmvc环境自行配置. 以下举例中存在如下文件/WEB-INF/pages/success.jsp 请求转发的第一种情况:请求转发经过视图解析器 前端页面 <a href="${pageContext.request.contextPath}/forwardMvcView">请求转发经过视图解析器</a> 后台代码 @RequestMapping(&qu

分区自动挂载的三种方法

一.修改/etc/rc.local配置文件追加类似命令:mount /dev/sda1  /sda1 到配置文件最后一行 二,修改/etc/fstab配置文件追加类似命令:/dev/sda1   /sda1  ext4   defaults   0  0 到配置文件中 三,安装autofs服务yum install autofs 追加类似命令:sda1   -fstype=ext4  :/dev/sda1 到配置/etc/autofs.misc文件中重启服务: service autofs re

VMWARE虚拟机不能上网三种方法分析

bridged(桥接模式). NAT(网络地址转换模式) host-only(主机模式). 理论理解: 1.bridged(桥接模式) 在这处模式下,虚拟机等同于网络内的一台物理主机,可对手动设置IP,子网掩码,DNS,且IP地址要和主机的IP在同一网段内.这样,虚拟机就和主机如同连在一个HUB上的两台计算机,只要主机能上网,虚拟机也会在这种模式下上网. 2.host-only(主机模式) 在host-only模式中,所有的虚拟系统是可以相互通信的,但虚拟系统和真实的网络是被隔离开的. 提示:在