Django01
1.创建django project
2.创建app
在一个project下可以创建多个app,比如运维系统这个project下面包含监控app、cmdb app等等,这些app共享project里的数据。
假如项目创建在/home/django/mysite下,则进入该目录,然后python manage.py startapp cmdb新建了一个app,在/home/django/mysite目录下会出现一个cmdb的目录,里面包含很多.py文件。
3.创建web服务器实现基本请求
修改mysite下的urls.py,
from cmdb import views urlpatterns = [
#url(r'^admin/', admin.site.urls),
url(r'^index/', views.index),
]
修改cmdb下的views.py,
from django.shortcuts import render
from django.shortcuts import HttpResponse
# Create your views here. # 通过request参数接收用户的页面请求,所以此处是request
def index(request):
# 不能直接return字符串,需要借助HttpResponse()方法
return HttpResponse('')
重启django进入浏览器即可查看到效果。
4.导入静态文件(js,css,图片等)、给用户返回html
4.1 返回html
1.在cmdb的同级目录下新建一个templates目录,在templates目录里新建一个index.html,在html里写入内容。
2.修改cmdb的views.py
from django.shortcuts import render
from django.shortcuts import HttpResponse
# Create your views here. def index(request):
#return HttpResponse('123')
return render(request,'index.html')
3.修改mysite下的settings.py
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
#添加模板目录,让django到DIRS的目录下找对应的html文件。
#BASE_DIR就是settings.py的父目录的父目录。
'DIRS': [os.path.join(BASE_DIR,'templates')],
4.2 引入静态文件
.修改settings.py
#STATIC_URL就是一个访问前缀。
STATIC_URL = '/qianzhui/'
STATICFILES_DIRS=(
#最后必须加个“,”,不然会提示不是元组,找不到静态文件
os.path.join(BASE_DIR,'statics'),
) .修改html
<body>
<h1>,test.</h1>
<script src="/qianzhui/jquery-1.12.4.js"></script>
</body>
5. 实现表单提交
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>123</title>
</head>
<body>
<h1>123,test.</h1> <form action="/index/" method="POST">
<input type="text" name="username" />
<input type="password" name="password" />
<!--input type="email" name="email" /-->
<input type="submit" /> </form> <h1>DATA:</h1>
<table border="">
#接收到django传过来的数据data,循环data,将数据在html上展示
{% for item in data %}
<tr>
<td>{{ item.user }}</td>
<td>{{ item.pass }}</td> </tr>
{% endfor %}
</table> <script src="/qianzhui/jquery-1.12.4.js"></script> <script>
<!--alert('');--> </script>
</body>
</html>
views.py
from django.shortcuts import render
from django.shortcuts import HttpResponse
# Create your views here. USER_INPUT=[
{'user':'user1','pass':'pass1'},
{'user':'user2','pass':'pass2'}
] def index(request):
if(request.method == "POST"):
#如果request.POST.get()里面的参数没有对应值,会报错,所以这里指定了一个None,如果没有就返回None,确保不会报错。
user = request.POST.get('username',None)
password = request.POST.get('password',None)
temp = {'user':user,'pass':password}
USER_INPUT.append(temp)
#return HttpResponse('123')
return render(request,'index.html',{'data':USER_INPUT})
settings.py
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
#下面这一行必须暂时注释,不然django会报错,暂时不知道什么意思。
# 'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
上面html表格里的数据是存储在内存里的,重启页面就会消失,如果想让数据永久保存,就需要将数据写入数据库,往下看。
6. 数据保存到sqlite
cmdb→models.py,
#创建类就等于是建表了;类必须继承models.Model
class UserInfo(models.Model):
user = models.CharField(max_length=32)
passwd = models.CharField(max_length=32)
mysite→settings.py,
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
#注册APP
'cmdb',
]
创建表,
python manage.py makemigrations
python manage.py migrate
views.py,
from django.shortcuts import render
from django.shortcuts import HttpResponse
#导入models
from cmdb import models
# Create your views here. def index(request):
if(request.method == "POST"):
u = request.POST.get('username',None)
p = request.POST.get('password',None) #执行了这行代码,数据库里就有数据了。
models.UserInfo.objects.create(user=u,passwd=p)
#return HttpResponse('123')
#取出数据
data_list = models.UserInfo.objects.all()
return render(request,'index.html',{'data':data_list})
index.html,
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>123</title>
</head>
<body>
<h1>123,test.</h1> <form action="/index/" method="POST">
<input type="text" name="username" />
<input type="password" name="password" />
<!--input type="email" name="email" /-->
<input type="submit" /> </form> <h1>DATA:</h1>
<table border="">
<tr>
<th>
yonghuming
</th>
<th>
mima
</th> </tr>
{% for item in data %}
<tr>
<td>{{ item.user }}</td>
<td>{{ item.passwd }}</td> </tr>
{% endfor %}
</table> <script src="/qianzhui/jquery-1.12.4.js"></script> <script>
<!--alert('');--> </script>
</body>
</html>
如此,数据就存储到django的默认数据库sqlite里了,重启django或者浏览器,html里的数据依然存在。
Django01的更多相关文章
- Django-01
知识预览 Django基本命令 二 路由配置系统(URLconf) 三 编写视图 四 Template 五 数据库与ORM admin的配置 一 什么是web框架? 框架,即framework,特指为 ...
- Django01 web http 基础
一.内容回顾 1.python基础 2.网络编程 3.并发编程 4.前端 5.数据库(MySQL) 二.今日概要 1.了解Web应用程序的本质 2.Django简介及安装使用 三.今日详细 1.最简单 ...
- Python-Django进阶
1. 路由系统 浏览器会自动给url后加一个"/" django会自动给路由的正则表达式前面加一个"/" django会给任何不带"/"结尾 ...
- python:前端(HTML)+后端(Django)+数据库(MySQL)
1.创建一个html文件用于简单的网页注册demo <!DOCTYPE html> <html lang="en"> <head> <me ...
- 饮冰三年-人工智能-Python-22 Python初识Django
1:一个简单的web框架 # 导包 from wsgiref.simple_server import make_server #自定义个处理函数 def application(environ,st ...
- django 基础框架学习 (一)
Django-01 Web框架 1.Web应⽤程序处理流程 : 2.Web框架的意义 1.⽤于搭建Web应⽤程序 2.免去不同Web应⽤相同代码部分的重复 ...
- 1.1Django简介和虚拟环境配置
MVC 大部分开发语言中都有MVC框架 MVC框架的核心思想是:解耦 降低各功能模块之间的耦合性,方便变更,更容易重构代码,最大程度上实现代码的重用 m表示model,主要用于对数据库层的封装 v表示 ...
- 前端(HTML)+后端(Django)+数据库(MySQL):用户注册及登录演示
1.创建一个html文件用于简单的网页注册demo <!DOCTYPE html> <html lang="en"> <head> <me ...
- Liunx之django项目部署
一.python web 项目部署 python django默认启动python3 manage.py runserver 0.0.0.0:8000这种方式调用wsgiref单机模块,性能较低,生产 ...
随机推荐
- jQuery Mobile学习日记之HelloWorld
这里是本人学习jQuery Mobile的过程,主要用于记录,过程中有不对的地方或不严谨的地方,欢予以指出纠正,非常感谢! 1.首先是下载安装以下文件: [Opera Mobile Emulator] ...
- css3动画参数解释
@keyframes规定动画.animation 所有动画属性的简写属性,除了 animation-play-state 属性. ----------------------------------- ...
- 内存分配与Segmentation fault
为了方便使用,我做了如下结构体的嵌套使用: struct operation{ int num; char name[100]; char owner[100]; char msg[100];}; s ...
- d3 scale 学习笔记
讲解scale 的好材料 https://www.dashingd3js.com/d3js-scales
- VC界面最前端显示
//显示在最前端 m_pMainWnd->SetWindowPos(&CWnd::wndTopMost, 0,0,0,0,SWP_NOMOVE|SWP_NOSIZE); if (m_pM ...
- 20145236 GDB调试汇编堆栈过程分析
GDB调试汇编堆栈过程分析 首先需要输入sudo apt-get install libc6-dev-i386安装一个库才能产生汇编代码,然后输入gcc - g example.c -o exampl ...
- 中文Locale
sudo apt-get install locales dpkg-reconfigure locales 查看当前已安装locale: locale -a 查看locale设置: locale
- MVC5 + EF6 完整入门教程三:EF来了
期待已久的EF终于来了 学完本篇文章,你将会掌握基于EF数据模型的完整开发流程. 本次将会完成EF数据模型的搭建和使用. 基于这个模型,将之前的示例添加数据库查询验证功能. 文章提纲 概述 & ...
- EF6 CodeFirst+Repository+Ninject+MVC4+EasyUI实践(八)
前言 本篇幅将对系统的菜单管理模块进行说明,系统的菜单采用树形结构,这样可以更好地方便层级设计和查看.本示例将说明如何通过EntityFramework读取递归的菜单树形结构,以及结合EasyUI的t ...
- 转 : Hibernate懒加载深入分析
懒加载可以提高性能吗? 不可以简单的说"能",因为hibernate的关系映射拖累了SQL的性能,所以想出懒加载来弥补.只是弥补而以,不会超越.所以大家不要想着使用了懒加载总体性能 ...