Django 数据传递
在前面的访问数据库中,我们是这样来插入数据的:
[root@localhost web]$ cat web/urls.py
urlpatterns = patterns('',
....
url(r'^db/$', 'blog.views.db'), # 先定义访问的URL,然后再根据URL定义视图文件
)
[root@localhost web]$ cat blog/views.py
from django.shortcuts import render
from django.http import HttpResponse
from django.template import loader, Context
from blog.models import Host def db(request):
h = Host()
h.hostname = 'node04' # 这里直接把数据写死了
h.ip = '192.168.1.4'
h.save()
return HttpResponse("OK")

我们可以通过 POST 或 GET 方法来传递数据:
GET 是直接以网址形式打开,网址中包含了所有的参数,浏览器会把 http header 和 data 一并发送出去,服务器响应200(返回数据)
POST 是浏览器先发送 http header,服务器响应100 continue,浏览器再发送 data,服务器响应200 ok(返回数据),具体用什么方法是由服务器来决定的
[root@localhost web]$ cat blog/views.py
....
from blog.models import Host # 加载数据模型 def db(request):
if request.POST:
hostname = request.POST.get('hostname') # 从POST数据中获取主机名
ip = request.POST.get('ip') # 从POST数据中获取IP地址
host = Host() # 实例化数据模型
host.hostname = hostname # 插入主机名数据
host.ip = ip # 插入IP地址数据
host.save() # 保存数据到数据库
return HttpResponse('OK') # 最后返回一个结果给页面
elif request.GET:
hostname = request.GET.get('hostname')
ip = request.GET.get('ip')
host = Host()
host.hostname = hostname
host.ip = ip
host.save()
return HttpResponse('OK')
else:
return HttpResponse('No Data!')
[root@localhost web]$ cat web/settings.py
...... MIDDLEWARE_CLASSES = (
......
#'django.middleware.csrf.CsrfViewMiddleware', # 注释掉该项,如果不注释掉,那么发送POST请求需要字符串验证
)
通过 POST 方法传递数据(第一种方式):
[root@localhost web]$ curl -d hostname='node05' -d ip='192.168.1.5' http://192.168.216.128:8000/db/
OK
通过 POST 方法传递数据(第二种方式):
#!/usr/bin/env python
#-*- coding:utf-8 -*- import urllib, urllib2 data = {
'hostname': 'node05',
'ip': '192.168.1.5',
} url = 'http://192.168.216.128:8000/db/'
response = urllib2.urlopen(url, urllib.urlencode(data))
print response.read()
通过 GET 方法传递数据(第一种方式):

通过 GET 方法传递数据(第二种方式):
#!/usr/bin/env python
#-*- coding:utf-8 -*- import urllib, urllib2 data = {
'hostname': 'node06',
'ip': '192.168.1.6',
} url = 'http://192.168.216.128:8000/db/' + urllib.urlencode(data)
response = urllib2.urlopen(url)
print response.read()
Django 数据传递的更多相关文章
- Django 前后台的数据传递示列
Django 前后台的数据传递的方法 Django 从后台往前台传递数据时有多种方法可以实现. 最简单的后台是这样的: ? 1 2 3 4 from django.shortcuts import r ...
- Django与JS交互的示例代码-django js 获取 python 字典-Django 前后台的数据传递
Django与JS交互的示例代码 Django 前后台的数据传递 https://www.cnblogs.com/xibuhaohao/p/10192052.html 应用一:有时候我们想把一个 li ...
- EXTJS中grid的数据特殊显示,不同窗口的数据传递
//EXTJS中grid的数据特殊显示renderer : function(value, metaData, record, rowIndex, colIndex, store, view) { v ...
- Activity系列讲解---数据传递
在Android中,不同的Activity实例可能运行在一个进程中,也可能运行在不同的进程中.因此需要一种特别的机制帮助我们在Activity之间传递消息.Android中通过Intent对象来表示一 ...
- vue2.0 组件之间的数据传递
组件间的数据传递// 父组件<template><div class="order"><dialog-addpro v-on:closedialog= ...
- ASP.NET MVC3中Controller与View之间的数据传递总结
一. Controller向View传递数据 1. 使用ViewData传递数据 我们在Controller中定义如下: ViewData["Message_ViewData& ...
- ASP.NET MVC3中Controller与View之间的数据传递
在ASP.NET MVC中,经常会在Controller与View之间传递数据,因此,熟练.灵活的掌握这两层之间的数据传递方法就非常重要.本文从两个方面进行探讨: 一. Controller向Vie ...
- 七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递
通过第一天的学习之后,我们相信您已经对MVC有一些基本了解. 本节所讲的内容是在上节的基础之上,因此需要确保您是否掌握了上一节的内容.本章的目标是在今天学习结束时利用最佳实践解决方案创建一个小型的MV ...
- MVC数据传递
一.数据传递 1.ViewData[]: 用法:action中:ViewData["key"]="aaa";,V层接收ViewData["key&qu ...
随机推荐
- paoding分词
Paoding 详细介绍 庖丁中文分词库是一个使用Java开发的,可结合到Lucene应用中的,为互联网.企业内部网使用的中文搜索引擎分词组件.Paoding填补了国内中文分词方面开源组件的空白,致力 ...
- Tensorflow不显示log
import os os.environ['TF_CPP_MIN_LOG_LEVEL'] = '3'
- ZBar与ZXing使用后感觉
[原]ZBar与ZXing使用后感觉(上) 2014-3-18阅读2011 评论1 最近对二维码比较感兴趣,还是那句老话,那么我就对比了一下zxing和zbar 如果对于这两个的背景不了解的话,可以看 ...
- e870. 获取默认外观的数据
This example demonstrates how to retrieve all the default values for the current look and feel. // G ...
- 一个简单的perl程序
和朋友聊天,说perl的神奇,最主要的是一行代码搞定所有. 想想用python3写的测试脚本,觉得还是有点多的,真的用几行代码写一个测试脚本,可以节约不少时间. 当然,网上黑perl的还是很多,不过自 ...
- Python——errno
该模块实现标准的 errno 系统符号,每一个对应于一个整数,名称和描述借鉴了 linux/include/errno.h. errno.errorcode 包含从 errno 到底层系统中错误名称 ...
- 回想sql语句中的各种连接
1. 内连接(Inner Join) 内连接是最常见的一种连接,它页被称为普通连接,而E.FCodd最早称之为自然连接. 以下是ANSI SQL-92标准 select * from t_ins ...
- vue input 赋值无效
1.js代码如下 var vm = new Vue({ el:'#rrapp', data:{ q:{ name: null }, dict: {} }, }); 2.文本框代码如下 <inpu ...
- T4 好用的Vs扩展
- VueJs中 Class 与 Style 绑定
绑定 HTML Class 尽管可以用 Mustache 标签绑定 class,比如 class="{{ className }}",但是我们不推荐这种写法和 v-bind:cla ...