python+django快速实现文件上传


Posted in Python onOctober 24, 2016

对于web开来说,用户登陆、注册、文件上传等是最基础的功能,针对不同的web框架,相关的文章非常多,但搜索之后发现大多都不具有完整性,对于想学习web开发的新手来说就没办法一步一步的操作练习;对于web应用来说,包括数据库的创建,前端页面的开发,以及中间逻辑层的处理三部分。

本系列以可操作性为主,介绍如何通过django web框架来实现一些简单的功能。每一章都具有完整性和独立性。使用新手在动手做的过程中体会web开发的过程,过程中细节请参考相关文档。

本操作的环境:
===================
deepin linux 2013(基于ubuntu)
python 2.7
Django 1.6.2
===================

创建项目与应用                                                                                                             

#创建项目
fnngj@fnngj-H24X:~/djpy$ django-admin.py startproject mysite2
fnngj@fnngj-H24X:~/djpy$ cd mysite2
#在项目下创建一个disk应用
fnngj@fnngj-H24X:~/djpy/mysite2$ python manage.py startapp disk

目录结构如下:

python+django快速实现文件上传

打开mysite2/mysite2/settings.py文件,将disk应用添加进去:

# Application definition

INSTALLED_APPS = (
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'disk',
)

设计Model(数据库)                                                                         

打开mysite2/disk/models.py文件,添加如下内容

from django.db import models

# Create your models here.
class User(models.Model):
 username = models.CharField(max_length = 30)
 headImg = models.FileField(upload_to = './upload/')

 def __unicode__(self):
  return self.username

创建两个字段,username 用户存放用户名,headImg 用户存放上传文件的路径。

下面进行数据库的同步

fnngj@fnngj-H24X:~/djpy/mysite2$ python manage.py syncdb
Creating tables ...
Creating table django_admin_log
Creating table auth_permission
Creating table auth_group_permissions
Creating table auth_group
Creating table auth_user_groups
Creating table auth_user_user_permissions
Creating table auth_user
Creating table django_content_type
Creating table django_session
Creating table disk_user

You just installed Django's auth system, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): yes 输入yes/no

Username (leave blank to use 'fnngj'):  用户名(默认当前系统用户名)
Email address: fnngj@126.com  邮箱地址
Password: 密码
Password (again): 确认密码
Superuser created successfully.
Installing custom SQL ...
Installing indexes ...
Installed 0 object(s) from 0 fixture(s)

最后生成的 disk_user 表就我是我们models.py 中所创建的类。Django 提供了他们之间的对应关系。

创建视图                                                                                               
1、打开mysite2/disk/views.py 文件

from django.shortcuts import render,render_to_response

# Create your views here.
def register(request):
 return render_to_response('register.html',{})

 2、创建注册页面

先在mysite2/disk/目录下创建templates目录,接着在mysite2/disk/templates/目录下创建register.html 文件:

<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
 <title></title>
</head>
<body>
<h1>register</h1>
</body>
</html>

3、设置模板路径

打开mysite2/mysite2/settings.py文件,在底部添加:

#template
TEMPLATE_DIRS=(
 '/home/fnngj/djpy/mysite2/disk/templates'
)

4、设置URL

from django.conf.urls import patterns, include, url

from django.contrib import admin
admin.autodiscover()

urlpatterns = patterns('',
 # Examples:
 # url(r'^$', 'mysite2.views.home', name='home'),
 # url(r'^blog/', include('blog.urls')),

 url(r'^admin/', include(admin.site.urls)),
 url(r'^disk/', 'disk.views.register'),
)

5、启动服务

fnngj@fnngj-H24X:~/djpy/mysite2$ python manage.py runserver
Validating models...

0 errors found
May 20, 2014 - 13:49:21
Django version 1.6.2, using settings 'mysite2.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

6、访问http://127.0.0.1:8000/disk/

python+django快速实现文件上传

注册页面可以正常打开说明整个过程已经走通。这也是Django开发的基本套路。读者一定要熟练理解这个基本套路。

完善表单提交                                                                                            
通过上面的过程,我们只是把过程串了起来,细心你一定发现,我们的register.html 文件,并没有创建用户提交的表单,views.py文件中也并没有对用户提交的信息做处理。下面我们就针对这两个文件进一步的补充。

打开mysite2/disk/templates/register.html 文件:

<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
 <title></title>
</head>
<body>
<h1>register</h1>
<form method="post" enctype="multipart/form-data" >
{{uf.as_p}}
<input type="submit" value="ok"/>
</form>
</body>
</html>

打开mysite2/disk/views.py 文件:

from django.shortcuts import render,render_to_response
from django import forms
from django.http import HttpResponse
# Create your views here.

class UserForm(forms.Form):
 username = forms.CharField()
 headImg = forms.FileField()

def register(request):
 if request.method == "POST":
  uf = UserForm(request.POST,request.FILES)
  if uf.is_valid():
   return HttpResponse('upload ok!')
 else:
  uf = UserForm()
 return render_to_response('register.html',{'uf':uf})

再次刷新http://127.0.0.1:8000/disk/ 页面

python+django快速实现文件上传

填写用户名,选择本地上传文件,点击“ok”

python+django快速实现文件上传

抛出一个错误,这个错误比较友好,所以不是我们操作过程中的小错误。

 打开mysite2/mysite2/settings.py文件,将下面一行代码注释:

MIDDLEWARE_CLASSES = (
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 #'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware',
)

再次刷新http://127.0.0.1:8000/disk/ 页面,我们就可以正常将用户名和文件提交了!

python+django快速实现文件上传

将数据写入数据库         

虽然已经实现了数据的提交,但用户名与文件并没有真正的写入到数据库。我们来进一步的完善mysite2/disk/views.py 文件:

#coding=utf-8
from django.shortcuts import render,render_to_response
from django import forms
from django.http import HttpResponse
from disk.models import User

# Create your views here.
class UserForm(forms.Form):
 username = forms.CharField()
 headImg = forms.FileField()

def register(request):
 if request.method == "POST":
  uf = UserForm(request.POST,request.FILES)
  if uf.is_valid():
   #获取表单信息
   username = uf.cleaned_data['username']
   headImg = uf.cleaned_data['headImg']
   #写入数据库
   user = User()
   user.username = username
   user.headImg = headImg
   user.save()
   return HttpResponse('upload ok!')
 else:
  uf = UserForm()
 return render_to_response('register.html',{'uf':uf})

再次刷新http://127.0.0.1:8000/disk/ 页面,完成文件的上传。

python+django快速实现文件上传

那数据库中保存的是什么呢?

fnngj@fnngj-H24X:~/djpy/mysite2$ sqlite3 db.sqlite3 
SQLite version 3.7.15.2 2013-01-09 11:53:05
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> select * from disk_user;
1 | Alen | upload/desk.jpg
sqlite>

通过查看数据库发现,我们数据库中存放的并非用户上传的文件本身,而是文件的存放路径。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现115网盘自动下载的方法
Sep 30 Python
pygame学习笔记(6):完成一个简单的游戏
Apr 15 Python
Python的pycurl包用法简介
Nov 13 Python
使用Python来开发Markdown脚本扩展的实例分享
Mar 04 Python
快速实现基于Python的微信聊天机器人示例代码
Mar 03 Python
Python表示矩阵的方法分析
May 26 Python
tensorflow: variable的值与variable.read_value()的值区别详解
Jul 30 Python
Pandas中resample方法详解
Jul 02 Python
python 实现将多条曲线画在一幅图上的方法
Jul 07 Python
如何创建一个Flask项目并进行简单配置
Nov 18 Python
为2021年的第一场雪锦上添花:用matplotlib绘制雪花和雪景
Jan 05 Python
python线程优先级队列知识点总结
Feb 28 Python
python实现简单爬虫功能的示例
Oct 24 #Python
简单谈谈Python中的反转字符串问题
Oct 24 #Python
Python 内置函数complex详解
Oct 23 #Python
Python检测生僻字的实现方法
Oct 23 #Python
python 写入csv乱码问题解决方法
Oct 23 #Python
解决Python中字符串和数字拼接报错的方法
Oct 23 #Python
python 读写txt文件 json文件的实现方法
Oct 22 #Python
You might like
php调用google接口生成二维码示例
2014/04/28 PHP
PHP学习笔记之字符串编码的转换和判断
2014/05/22 PHP
thinkphp3.2嵌入百度编辑器ueditor的实例代码
2017/07/13 PHP
Laravel框架实现利用中间件进行操作日志记录功能
2018/06/06 PHP
php实例化一个类的具体方法
2019/09/19 PHP
JavaScript Eval 函数使用
2010/03/23 Javascript
获取3个数组不重复的值的具体实现
2013/12/30 Javascript
JavaScript中创建对象和继承示例解读
2014/02/12 Javascript
javascript原生和jquery库实现iframe自适应高度和宽度
2014/07/18 Javascript
Javascript学习笔记之相等符号与严格相等符号
2014/11/23 Javascript
jQuery中die()方法用法实例
2015/01/19 Javascript
jQuery实现网页顶部固定导航效果代码
2015/12/24 Javascript
关于Javascript中defer和async的区别总结
2016/09/20 Javascript
angular中的cookie读写方法
2017/08/02 Javascript
微信小程序事件 bindtap bindinput代码实例
2019/08/26 Javascript
JavaScript函数IIFE使用详解
2019/10/21 Javascript
在vue中把含有html标签转为html渲染页面的实例
2019/10/28 Javascript
在Vue mounted方法中使用data变量详解
2019/11/05 Javascript
微信sdk实现禁止微信分享(使用原生php实现)
2019/11/15 Javascript
基于javascript的无缝滚动动画1
2020/08/07 Javascript
[03:53]2016国际邀请赛中国区预选赛第三日TOP10精彩集锦
2016/06/29 DOTA
python使用在线API查询IP对应的地理位置信息实例
2014/06/01 Python
python执行scp命令拷贝文件及文件夹到远程主机的目录方法
2019/07/08 Python
python多线程实现代码(模拟银行服务操作流程)
2020/01/13 Python
python exit出错原因整理
2020/08/31 Python
容易被忽略的Python内置类型
2020/09/03 Python
CSS3 @media的基本用法总结
2019/09/10 HTML / CSS
Lands’ End官网:经典的美国生活方式品牌
2016/08/14 全球购物
Chicco婴儿用品美国官网:汽车座椅、婴儿推车、高脚椅等
2018/11/05 全球购物
大学军训感言800字
2014/02/27 职场文书
大学生学习计划书
2014/09/15 职场文书
学校重阳节活动总结
2015/03/24 职场文书
2015小学语文教师个人工作总结
2015/05/20 职场文书
2016党性教育学习心得体会
2016/01/21 职场文书
css布局巧妙技巧之css三角示例的运用
2022/03/16 HTML / CSS
vue配置型表格基于el-table拓展之table-plus组件
2022/04/12 Vue.js