1、设置配置文件
[[email protected] blog_project]# mkdir uploads 新建目录专门处理文件上传
[[email protected] blog_project]# vim blog_project/settings.py
MEDIA_URL = ‘/uploads/‘
MEDIA_ROOT = os.path.join(BASE_DIR, ‘uploads‘)
[[email protected] blog_project]# vim blog_project/urls.py
from django.conf import settings
urlpatterns = patterns(‘‘,
url(r‘^$‘, ‘blog.views.index‘),
url(r"^uploads/(?P<path>.*)$", \
"django.views.static.serve", \
{"document_root":settings.MEDIA_ROOT,}),
url(r‘^admin/‘, include(admin.site.urls)),
[[email protected] blog_project]# vim static/js/kindeditor-4.1.7/config.js
KindEditor.ready(function(K) {
K.create(‘textarea[name=content]‘,{
width:800,
height:200,
uploadJson:‘/admin/upload/kindeditor‘,
});
});
通过此次操作,可以执行上次头像变更操作。
2、掌握方法
研究下里面的serve方法
[[email protected] blog_project]# cat /usr/lib/python2.6/site-packages/django/views/static.py
def serve(request, path, document_root=None, show_indexes=False):
3、web端操作:
用户—root—添加头像
查看效果(这些效果均跟数据库创建的user相关)
生成目录:[[email protected] blog_project]# ls uploads/avatar/201610/2.jpg
浏览器设置:http://192.168.1.179:8000/uploads/avatar/201610/2.jpg
二、文本添加图片上传:
1、准备文件
[[email protected] blog_project]# vim blog/upload.py
编辑器需要特定的json格式。
#{"error":1, "message":"出错信息"}
#{"error":0, "url":"图片地址"}br/>@csrf_exempt装饰器:不做远程表单csrf认证,省去验证
files = request.FILES.get("imgFile",None)这个文件需要配合前端F12查询获得。
2、添加url
[[email protected] blog_project]# vim blog_project/urls.py
from blog.upload import upload_image
url(r‘^admin/upload/(?P<dir_name>[^/]+)$‘, upload_image, name=‘upload_image‘),
3、编辑工具添加一行
[[email protected] blog_project]# vim static/js/kindeditor-4.1.7/config.js
KindEditor.ready(function(K) {
K.create(‘textarea[name=content]‘,{
width:‘800px‘,
height:‘200px‘,
uploadJson:‘/admin/upload/kindeditor‘,
});
});
4、上传成功,展示效果:
后台生成目录并存有照片
[[email protected] blog_project]# ls uploads/kindeditor/2016/10/ae9f8ba8-9023-11e6-b639-000c29875ae0.jpg
原文地址:http://blog.51cto.com/10227140/2159045