Django项目中使用plupload插件实现上传图片功能
首先下载plupload插件放在static静态文件下面,官方地址:https://www.plupload.com/
项目根目录下创建media文件夹用来存放上传的图片,配置settings文件,添加media的文件路径
MEDIA_ROOT = os.path.join(BASE_DIR,'media')
先写前端html页面
{# 引入插件#}
<script src="/static/plupload/moxie.js"></script>
<script src="/static/plupload/plupload.min.js"></script> {#定义上传图片的按键和显示位置#}
<div class="sbox f_l"><span>上传图片</span>
{% for i in img %}
<img src="{{ i.src }}" alt="">
{% endfor %}
<h2><a id="upload_image_name" src="javascript:;"><input type="button" value="上传图片"></a></h2>
<ul id="image_name_list"></ul>
{# <a href="/" class="read">点击阅读</a>#}
</div>
写前端js语法
{#上传图片#}
<script language="JavaScript"> var msgLayero_upload_image_name;
var index_upload_image_name;
var layer_upload_image_name = 1;
//实例化一个plupload上传对象
var uploader_upload_image_name = new plupload.Uploader({
browse_button: 'upload_image_name', //触发文件选择对话框的按钮,为那个元素id
url: '/apply/upload/', //服务器端的上传页面地址
flash_swf_url: '/static/plupload/Moxie.swf', //swf文件,当需要使用swf方式进行上传时需要配置该参数
silverlight_xap_url: '/static/plupload/Moxie.xap', //silverlight文件,当需要使用silverlight方式进行上传时需要配置该参数
multipart_params: {
type: 'image_name',
csrfmiddlewaretoken: "{{ csrf_token }}"
},
resize: {
width: 800//指定压缩后图片的宽度,如果没有设置该属性则默认为原始图片的宽度
//height: , //指定压缩后图片的高度,如果没有设置该属性则默认为原始图片的高度
//crop: false //是否裁剪图片
},
filters: {
max_file_size: '4mb'
},
init: {
//选择文件
FilesAdded: function (up, files) {
//加载层
index_upload_image_name = layer.msg('上传中...', {
icon: 16, time: 0,
shade: 0.01,
success: function (layero, index) {
msgLayero_upload_image_name = layero;//是加载层的div
}
});
//layer_upload_image_name = layer.msg('上传中...', {time: 0}); //不自动关闭
uploader_upload_image_name.start();
},
UploadProgress: function (up, file) { //上传中,显示进度条
var percent = file.percent;
msgLayero_upload_image_name.find('.layui-layer-content').html('<i class="layui-layer-ico layui-layer-ico1"></i>上传中...' + percent + '%'); },//单个文件上传完成
FileUploaded: function (up, file, responseObject) {
console.log($.parseJSON(responseObject.response));//成功回调函数 {# $('#image_name_list').html('');#}
var result = $.parseJSON(responseObject.response);
if (result.status == 1) {
//上传成功
var htmls = '<li class="img_upload" style="position:relative;margin:0 10px -10px 0;">';
htmls += '<input type="hidden" name="image_name[]" value="' + result.file + '">'; //隐藏域,是为了把图片地址入库。。
htmls += ' <img src="' + result.file + '" width="250" >';
htmls += '<span style="position:absolute;top:-8px;right:-6px;background-color:#fff;border-radius:10px;"><a href=javascript:; class="delImg" data-val="' + result.file + '"> <img src="/static/images/del.png" width="15" /></a></span>';
htmls += '</li>';
{# $('#image_name_list').append(htmls);为可同时上传多张图片,$('#image_name_list').html(htmls);为一次智能上传一张图片#}
$('#image_name_list').append(htmls);
//上传成功的弹出框
msgLayero_upload_image_name.find('.layui-layer-content').html('<i class="layui-layer-ico layui-layer-ico1"></i>' + result.message); } else {
//上传失败的弹出框
msgLayero_upload_image_name.find('.layui-layer-content').html('<i class="layui-layer-ico layui-layer-ico2"></i>' + result.message); }
setTimeout(function () {
layer.close(index_upload_image_name);
}, 2000); },
//全部文件上传完成
UploadComplete: function (up, files) {
setTimeout(function () {
layer.close(index_upload_image_name);
}, 2000);
},
//返回错误
Error: function (up, err) {
msgLayero_upload_image_name.find('.layui-layer-content').html('<i class="layui-layer-ico layui-layer-ico2"></i>' + result.message);
setTimeout(function () {
layer.close(index_upload_image_name);
}, 2000);
}
}
}); uploader_upload_image_name.init(); {# 删除准备上传的图片#}
$(document).on('click', '.delImg', function () {
_this = this;
$.post('{% url "apply:delimg/" %}', {
path: $(_this).data("val"),
csrfmiddlewaretoken: "{{ csrf_token }}"
}, function (json) {
if (json.status == 1) {
layer.msg("删除成功", {
time: 2000 //2s后自动关闭
});
$(_this).parent().parent().remove();
} else {
layer.msg("删除失败", {
time: 2000 //2s后自动关闭
});
}
}, 'json');
});
</script>
django后台,先创建路由
from django.urls import path,include,re_path
from apply.views import apply urlpatterns = [
path('index/',apply.index,name='index/'),
path('about/',apply.about,name='about/'),
path('info/',apply.info,name='info/'),
path('list/',apply.list,name='list/'),
path('time/',apply.time,name='time/'),
path('fanyi/',apply.fanyi,name='fanyi/'),
# 上传图片
path('upload/',apply.upload,name='upload/'),
# 删除准备上传的图片
path('delimg/',apply.delimg,name='delimg/'), ]
写方法。
from django.shortcuts import render,redirect,HttpResponse
from apply.utils import function
from blacker import settings
import os
import json
from apply.models import *
# 上传图片
def upload(request):
img_obj = request.FILES.get("file") # 通过前台提交过来的图片资源 img_obj.name avatar.jpg
range_num = function.range_num(15) # 生成一个15位随机数 print(img_obj.name)
img_type = os.path.splitext(img_obj.name)[1] # .jpg 获取文件名后缀
new_img_path = os.path.join(settings.MEDIA_ROOT,
range_num + img_type) # E:\ftp\code\www\pro\media\add_article_img\676161546271228.jpg #/media/add_article_img/123456.jpg
print(new_img_path)
img_type2 = img_type.replace(".", "") # png with open(new_img_path, "wb") as f:
for line in img_obj:
f.write(line)
response = {
"status": 1,
"message": "上传成功",
'file': '/media/'+range_num + img_type+'/',
'file_type': img_type2
}
res = Media.objects.create(src='/media/'+range_num + img_type+'/')
return HttpResponse(json.dumps(response))
# 删除正在上传的图片
def delimg(request):
print(12)
img_path = request.POST.get('path') # /media/add_article_img/722264423391172.jpg
# img_name = os.path.split(img_path)[-1] # 获取图片名称 722264423391172.jpg
img_name = img_path.split('/')[-2] # 获取图片名称 722264423391172.jpg
img_new_path = os.path.join(settings.MEDIA_ROOT,img_name) # E:\ftp\code\www\pro\media\add_article_img\722264423391172.jpg
if not os.remove(img_new_path):
response = {
"status": 1,
"message": "删除成功"
}
return HttpResponse(json.dumps(response))
方法里面有用到function.range_num函数,这是一个封装的产生随机数函数,在应用目录下创建utils文件夹,并创建function.py文件,内容如下
import random
# 随机数
def range_num(num):
# 定义一个种子,从这里面随机拿出一个值,可以是字母
seeds = ""
# 定义一个空列表,每次循环,将拿到的值,加入列表
random_num = []
# choice函数:每次从seeds拿一个值,加入列表
for i in range(num):
random_num.append(random.choice(seeds))
# 将列表里的值,变成四位字符串
return "" . join(random_num)#
上传发现图片上传成功,但是页面不能正常显示;
需要再配置路由,
from django.contrib import admin
from django.urls import path,include,re_path
from apply.views import apply
from django.views.static import serve
from blacker import settings
urlpatterns = [
re_path(r'^media/(?P<path>.*)', serve, {"document_root":settings.MEDIA_ROOT}),
path('',apply.index,name='index/'),
path('admin/', admin.site.urls),
path('apply/',include(('apply.urls','apply')))
]
配置后在上传图片如图所示
同时图片已写入数据库,从数据库获取数据并写在页面上;
done。
Django项目中使用plupload插件实现上传图片功能的更多相关文章
- django项目中使用bootstrap插件的分页功能。
官网下载bootstrap插件放到项目中的static文件中 路由 path('blog-fullwidth/', login.fullwidth,name='fullwidth'), 前端页面引入 ...
- 项目中使用ECharts插件实现统计功能
一.前端界面 // 界面中定义一个div,放图表 <div id="box" style="width: 600px;height:400px;padding: 1 ...
- Django项目中模板标签及模板的继承与引用【网站中快速布置广告】
Django项目中模板标签及模板的继承与引用 常见模板标签 {% static %} {% for x in range(x) %}{% endfor %} 循环的序号{% forloop %} 循环 ...
- django项目中遇到要实现定时任务
django项目中遇到要实现定时任务,所以选用了简单易用的django-crontab插件. 1.安装 django-crontab pip install django-crontab 2.定时要执 ...
- [翻译]在Django项目中添加谷歌统计(Google Analytics)
原文:<Google Analytics tracking code into Django projects, the easy way> 对我来说,制作一个可扩展的Django应用随时 ...
- Django项目中使用Redis
Django项目中使用Redis DjangoRedis 1 redis Redis 是一个 key-value 存储系统,常用于缓存的存储.django-redis 基于 BSD 许可, 是一个使 ...
- 擦他丫的,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了!
擦 ,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了! 问题在于我使用的谷歌浏览器,默认使用了缓存,导致每次访问同一个url时,都返回的是缓存里面的东西.通过谷歌 ...
- django 项目中使用多数据库 multiple databases
假如在一个django项目中使用到了不只一个数据库, 其实这在大一点的工程中很常见,比如主从库 那么会涉及到如下一些东西 1, 定义 在settings中的DATABASE中定义会使用到的数据,比如除 ...
- django 项目中的 favicon.ico 处理
django 项目中的 favicon.ico 处理 (django == 2.0.6) 1. 引入模块: from django.views.generic.base import Redirec ...
随机推荐
- python之 小甲鱼教程 Easygui 篇
博客转自 https://blog.csdn.net/bestallen/article/details/51933427 终于有点实质性可以看到摸到的界面了,搜了一下虽然easygui用的不多,但是 ...
- Java byte和hex十六进制字符串转换
在Java中字符串由字符char组成, 一个char由两个byte组成, 而一个byte由八个bit组成, 一个十六进制字符(0-F)实际上由4个字节byte即可表达, 因此, 从字节数组到十六进制字 ...
- LRU缓存实现
LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高” 在java中可以采用Linke ...
- Java开发笔记(一百四十七)通过JDBC管理数据库
前面介绍了如何通过JDBC获取数据库连接,可是Connection对象不能直接执行SQL语句,需要引入Statement报告对象才能操作SQL.Statement对象由Connection的creat ...
- DRF框架(二)——解析模块(parsers)、异常模块(exception_handler)、响应模块(Response)、三大序列化组件介绍、Serializer组件(序列化与反序列化使用)
解析模块 为什么要配置解析模块 1)drf给我们提供了多种解析数据包方式的解析类 form-data/urlencoded/json 2)我们可以通过配置来控制前台提交的哪些格式的数据后台在解析,哪些 ...
- Python之路【第十六篇】:Python并发编程|进程、线程
一.进程和线程 进程 假如有两个程序A和B,程序A在执行到一半的过程中,需要读取大量的数据输入(I/O操作), 而此时CPU只能静静地等待任务A读取完数据才能继续执行,这样就白白浪费了CPU资源. 是 ...
- Jmeter相关参数
一.线程组 线程组主要包含三个参数:线程数.准备时长(Ramp-Up Period(in seconds)).循环次数. 线程数:虚拟用户数.一个虚拟用户占用一个进程或线程.设置多少虚拟用户数在这里也 ...
- kibana内存设置
kibana是一个基于NodeJS的单页web应用.而NodeJS则是基于Chrome V8引擎的.V8引擎对于内存的使用是有限制的,默认情况下,64位系统下约为1.4GB,32位系统下约为0.7GB ...
- flask 与 SQLAlchemy的使用
flask 与 SQLAlchemy的使用 安装模块 pip install flask-sqlalchemy 在单个python中与flask使用 # 文件名:manage.py from flas ...
- tf.reduce_max的运用
a=np.array([[[[1],[2],[3]],[[4],[25],[6]]],[[[27],[8],[99]],[[10],[11],[12]]],[[[13],[14],[15]],[[16 ...