4 django系列之HTML通过form标签来同时提交表单内容与上传文件
preface
我们知道提交表单有2种方式,一种直接通过submit页面刷新方法来提交,另一种通过ajax异步局部刷新的方法提交,上回我们说了通过ajax来提交文件到后台,现在说说通过submit来提交文件到后台。
看看代码
我们前端使用html语言写的时候,要注意每一个input、select标签需要有name属性,这样我们后端在在获取值的时候,就以name作为key来获取对应value。
首先看看前端html页面
<form id="updatecode" method="post" action="/BatchM/apply_update.html/apply" enctype="multipart/form-data" role="form"> # 申明加密类型,上传文件必须这样。
{% csrf_token %}
<label for="exampleInputEmail1">请选择归属项目</label>
<div>
<select name="flow_project" id="flow_project" class="form-control"> # 都设置了name属性
{% for project in projects %}
<option value="{{ project }}" >{{ project }}</option>
{% endfor %}
</select>
</div>
<label for="exampleInputEmail1">请选择归属应用</label>
<div>
<select id="flow_app" name="flow_app" class="form-control"> # 都设置了name属性
{% for app in apps %}
<option value="{{ app }}" >{{ app }}</option>
{% endfor %}
</select>
</div>
<div class="form-group">
<label for="exampleInputEmail1">哪台服务器需要更新</label>
<!-- <input type="email" class="form-control" id="exampleInputEmail1" placeholder="Enter email"> -->
<input type="text" name="target_host" class="form-control" id="target_host" placeholder="请输入主机ip/域名"> # 都设置了name属性
</div>
<div class="form-group">
<label for="exampleInputFile">附件上传</label>
<input type="file" name="file" id="file_upload"> onclick="FileUpload()">开始上传附件</button> --> # 都设置了name属性
</div>
'''''省略一堆类似的代码'''''
<button type="submit" class="btn btn-success" >提交工单</button>
</form>
我们看看后台,处理这里提交数据的逻辑代码,django作为web框架。
def apply_update_apply(request):
'''
显示申请更新到页面
:param request:
:return:
'''
if request.method == 'GET':
apps = models.TypeOfApp.objects.all()
projects = models.TypeOfProject.objects.all()
return render(request,'apply_update.html',{'btitle':'申请更新','apps':apps,'projects':projects})
elif request.method == "POST": # 提交数据
file_obj = request.FILES.get('file') # 使用这个 request.FILES.get方法来获取上传文件的句柄
upload_file = None
if file_obj: # 处理附件上传到方法
accessory_dir = settings.accessory_dir # 获取上传路径,在settings配置好的
if not os.path.isdir(accessory_dir): # 判断是否有这个目录,没有就创建
os.mkdir(accessory_dir)
upload_file = "%s/%s" % (accessory_dir, file_obj.name) # 拼接上传路径
with open(upload_file, 'wb') as new_file: # 开始写入文件
for chunk in file_obj.chunks(): # 必须使用chunks方法,因为文件上传采用块上传
new_file.write(chunk)
project_name = request.POST.get('flow_project') # 获取表单里input标签的参数,所有get的key都是name指定的
flow_project = models.TypeOfProject.objects.get(name_of_project=project_name)
app_name=request.POST.get('flow_app')
flow_app = models.TypeOfApp.objects.get(app_name=app_name)
order_id = time.strftime("%Y%m%d%H%M%S", time.localtime())
#print('usernane',request.user.username) #打印用户到名字
#print('email',request.user.email) # 打印用户的邮箱地址
request_set = { # 做成一个字典,方便下一步入库,所有get的值都是在html页面通过input标签的name属性指定的。
'OrderId':order_id,
'username': request.user.email, # 通过这个方法获取登陆用户的email
'flow_project':flow_project,
'flow_app':flow_app,
'target_host':request.POST.get('target_host'),
'code_source':request.POST.get('code_source'),
'configfile_path':request.POST.get('configfile_path'),
'configfile_content':request.POST.get('configfile_content'),
'sql_command':request.POST.get('sql_command'),
'crond_task':request.POST.get('crondtab_task'),
'system_env_change':request.POST.get('change_sys_env'),
'update_of_reason':request.POST.get('Upreason'),
'accessory_path': upload_file
}
email_issend = core.selfmail(request_set) # 调用发送邮件的功能,发送到指定到地址,成功返回True,失败返回False
request_set['email_issend']= email_issend
data_obj = models.WorkOrderOfUpdate(**request_set)
data_obj.save() # 保存数据
return HttpResponseRedirect('/BatchM/apply_update.html/search/%s'%order_id) # 返回数据给前端
这样我们在前端提交的文本框数据以及文件都可以同时被后台处理啦。。。
4 django系列之HTML通过form标签来同时提交表单内容与上传文件的更多相关文章
- php使用jquery Form ajax 提交表单,并上传文件
在html5中我们通过FormData就可以ajax上传文件数据,不过因为兼容问题.我们选用jquery.form.min.js来进行ajax的表单提交. 一.jquery.form.js下载地址 ...
- Django框架 之 Form表单和Ajax上传文件
Django框架 之 Form表单和Ajax上传文件 浏览目录 Form表单上传文件 Ajax上传文件 伪造Ajax上传文件 Form表单上传文件 html 1 2 3 4 5 6 7 <h3& ...
- $_FILES参数详解及简单<form>表单无刷新上传文件
$_FILES:经由 HTTP POST 文件上传而提交至脚本的变量,类似于旧数组$HTTP_POST_FILES 数组(依然有效,但反对使用)详细信息可参阅 POST方法上传 $_FILES数组内容 ...
- <button>标签也能提交表单问题
如何避免<button>标签也能提交表单的问题: 只需加上一个属性:type='button'即可:如<button type="button"> < ...
- FastAPI框架入门 基本使用, 模版渲染, form表单数据交互, 上传文件, 静态文件配置
安装 pip install fastapi[all] pip install unicorn 基本使用(不能同时支持,get, post方法等要分开写) from fastapi import Fa ...
- SpringMVC 使用Form标签库制作登录表单
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...
- 使用jQuery.form库中ajaxSubmit提交表单时遇到的一些问题
初入前端,网上找的很多资料都不够详细,导致遇到很多问题,现记录如下: 1.首先引入 <script src="~/Scripts/jquery-1.10.2.js">& ...
- Liferay 6.2 改造系列之十九:修改站点设置的表单内容
在/portal-master/portal-impl/src/portal.properties文件中,有如下配置: # # Input a list of sections that will b ...
- 实现简单的django上传文件
本文用django实现上传文件并保存到指定路径下,没有使用forms和models,步骤如下: 1.在模板中使用form表单,因为这个表单使用于上传文件的,所以method属性必须设置为post,而且 ...
随机推荐
- JavaScript学习笔记4之 ByClass&json
一.通过class获取标签 var out=document.getElementsByClassName(‘out’);IE 6 7 8 不支持 getElementsName 是否有办法既能通过c ...
- android 自定义控件——(四)圆形进度条
----------------------------------↓↓圆形进度条(源代码下有属性解释)↓↓---------------------------------------------- ...
- iOS开发:创建真机调试证书及描述文件
iOS开发:创建真机调试证书及描述文件 关于苹果iOS开发,笔者也是从小白过来的,经历过各种困难和坑,其中就有关于开发证书,生产证书,in_house证书,add_Hoc证书申请过程中的问题,以及上架 ...
- React Native APP结构探索
APP结构探索 我在Github上找到了一个有登陆界面,能从网上获取新闻信息的开源APP,想来研究一下APP的结构. 附上原网址:我的第一个React Native App 具体来讲,就是研究一个复杂 ...
- Mysql Join
在前面的博文中,我们已经学会了如果在一张表中读取数据,这是相对简单的,但是在真正的应用中经常需要从多个数据表中读取数据. 本章节我们将向大家介绍如何使用 MySQL 的 JOIN 在两个或多个表中查询 ...
- C#语言学习记录
1.&& || ! 与或非-逻辑运算符,&&的优先级大于||.
- Hadoop技巧(02):时间同步
阅读目录 序 时间同步 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 在实际部署 ...
- 由Photoshop高反差保留算法原理联想到的一些图像增强算法。
关于高反差保留的用处说明呢,从百度里复制了一段文字,我觉得写得蛮好的: 高反差保留就是保留图像的高反差部分,再说得真白些,就是保留图像上像素与周围反差比较大的部分,其它的部分都变为灰色.拿一个人物照片 ...
- Month Scheme
新的一个月,我要给自己立FLAG了, ABCDEFG HIJKLMN 天下事有难易乎,为之,则难者亦易矣,不为,则易者亦难矣. 这次采取的策略是,每完成一项work回来补充内容.希望能把这篇blog补 ...
- ultraiso制作大于4GB的镜像的启动盘
ultraiso这个软件用来做启动盘很方便, 一般linux啦, windows啦, 神马的都用他来做, 但是, 因为ubuntu一般只有1-2GB, win桌面版一般也就3GB左右, 所以不必考虑这 ...