1.安装Django(下载慢的时候用MaxVPN)

  pip3 install django

2.Django处理流程

  新建project(mysite),执行dj(mysite),然后在console界面中运行 D:\Python\django_project>python manage.py startapp cmdb,创建cmdb的APP。

3.Django采用MTV框架。M=Modals(数据库),T=Template(HTML模板),V=Views(用户处理逻辑)

  在配置文件urls.py中指定路由关系

from cmdb import views

urlpatterns = [
#url(r'^admin/', admin.site.urls),
url(r'^index/', views.index),
]

  在views.py中定义用户的处理逻辑

def index(request):
return (HttpResponse(''))

  这样,在执行了dj(site)之后,可以通过IE访问到我们编写的程序逻辑:http://127.0.0.1:8000/index/

4.进一步我们需要返回自己编写的HTML的时候,而不是通过HttpResponse返回。我们需要新建一个templates文件夹,在里面新建index.html文件,然后写上自定义的HTML文件:

<body>
<table border="1 solid red">
<tr>
<th>TITLE1</th>
<th>TITLE2</th>
<th>TITLE3</th>
</tr>
<tr>
<td>星期一</td>
<td>星期二</td>
<td>星期三</td>
</tr>
</table>
</body>

  然后,改写用户逻辑里面的views.py

def index(request):
# return (HttpResponse('123'))
return render(request,'index.html')

  这样再通过http://127.0.0.1:8000/index/访问的时候,就可以访问到在template文件夹下定义的index.html文件了。

  如果在执行程序的时候,报找不到template的错误,那么是settings里面定义的路径的问题

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')]
,
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]

5.导入静态文件

  在mysite下面建立文件夹static

  在views.py里面添加引用

<script src="/fff/jquery-1.12.4.js"></script>

  在settings.py里面定义静态文件的路径

STATIC_URL = '/fff/'

STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static'),
)

  注意这里静态文件的URL要与src引入的路径相匹配,然后通过http://127.0.0.1:8000/fff/jquery-1.12.4.js访问JQuery成功。

6.表单的提交

  在index.html里定义HTML模板

    <h1>用户输入</h1>
<form action="/index/" method="POST">
<input type="text" name="user"/>
<input type="text" name="email"/>
<input type="submit" value="提交"/>
</form>

  在views.py中获取到表单的数据

def index(request):
# return (HttpResponse('123'))
if(request.method == "POST"):
user = request.POST.get("user",None);
email = request.post.get("email",None)
print (user,email)
return render(request,'index.html')

  执行的时候报错:

Forbidden (403)
CSRF verification failed. Request aborted.
You are seeing this message because this site requires a CSRF cookie when submitting forms. This cookie is required for security reasons, to ensure that your browser is not being hijacked by third parties.
If you have configured your browser to disable cookies, please re-enable them, at least for this site, or for 'same-origin' requests.

  在settings.py文件中找到MIDDLEWARE,并注释其中一行:

MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'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',
]

  提交表单数据,可以看到结果:

[28/Oct/2016 01:58:56] "GET /index/ HTTP/1.1" 200 655
aa bb
[28/Oct/2016 01:59:00] "POST /index/ HTTP/1.1" 200 655

  这样显示数据不行,必须要在网页文件中显示才行,因此,我们需要改写views.py文件

USER_INPUT=[
{'user':'u1','email':'e1'},
{'user':'u2','email':'e2'},
] def index(request):
# return (HttpResponse('123'))
if(request.method == "POST"):
user = request.POST.get("user",None)
email = request.POST.get("email",None)
temp = {'user':user,'email':email}
USER_INPUT.append(temp)
print (user,email)
return render(request,'index.html',{'data':USER_INPUT})

  同时,我们定义显示HTML的格式:

    <h1>数据展示</h1>
<table border="1">
{% for item in data %}
<tr>
<td>{{ item.user }}</td>
<td>{{ item.email }}</td>
</tr>
{% endfor %}
</table>

  并且,在HTML文件中{% %}的写法会自动循环表单中提交的数据,然后将其显示出来。Django后台帮我们把这个循环改写成了python的循环,item.user和item.email就相当于字典的key值。

  这样操作以后,执行http://127.0.0.1:8000/index/,然后通过前台就可以添加数据并且实时的显示了。

7.上面表单的提交在页面刷新以后就没有了,因为内容是存放在缓存中的,现在,我们需要将数据存放在数据库当中,改写之前的代码。

  在models.py中创建UserInfo的类:

class UserInfo(models.Model):
user = models.CharField(max_length=32)
email = models.CharField(max_length=32)

  在settings.py中注册cmdb,并且查看DATABASES的设置:

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'cmdb',
]

  执行命令创建数据库,表

D:\Python\mysite>python manage.py makemigrations
Migrations for 'cmdb':
cmdb\migrations\0001_initial.py:
- Create model UserInfo D:\Python\mysite>python manage.py migrate
Operations to perform:
Apply all migrations: admin, auth, cmdb, contenttypes, sessions
Running migrations:
Applying contenttypes.0001_initial... OK
Applying auth.0001_initial... OK
Applying admin.0001_initial... OK
Applying admin.0002_logentry_remove_auto_add... OK
Applying contenttypes.0002_remove_content_type_name... OK
Applying auth.0002_alter_permission_name_max_length... OK
Applying auth.0003_alter_user_email_max_length... OK
Applying auth.0004_alter_user_username_opts... OK
Applying auth.0005_alter_user_last_login_null... OK
Applying auth.0006_require_contenttypes_0002... OK
Applying auth.0007_alter_validators_add_error_messages... OK
Applying auth.0008_alter_user_username_max_length... OK
Applying cmdb.0001_initial... OK
Applying sessions.0001_initial... OK

  在用户逻辑views.py中需要引入models操作数据库

from cmdb import models

def index(request):

    if(request.method == "POST"):
u = request.POST.get("user",None)
e = request.POST.get("email",None)
models.UserInfo.objects.create(user=u,email=e)
data_list = models.UserInfo.objects.all()
# for item in data_list:
# print (item.user,item.email)
return render(request, 'index.html',{'data':data_list})

  在显示页面上index.html显示数据库中提取的数据:

<body>
<table border="1 solid red">
<tr>
<th>TITLE1</th>
<th>TITLE2</th>
<th>TITLE3</th>
</tr>
<tr>
<td>星期一</td>
<td>星期二</td>
<td>星期三</td>
</tr>
</table>
<script src="/fff/jquery-1.12.4.js"></script> <h1>用户输入</h1>
<form action="/index/" method="POST">
<input type="text" name="user"/>
<input type="text" name="email"/>
<input type="submit" value="提交"/>
</form> <h1>数据展示</h1>
<table border="1">
<tr>
<th>用户名</th>
<th>邮箱</th>
</tr>
{% for item in data %}
<tr>
<td>{{ item.user }}</td>
<td>{{ item.email }}</td>
</tr>
{% endfor %}
</table> </body>
MIDDLEWARE

Python 之Django的更多相关文章

  1. [Python] 利用Django进行Web开发系列(一)

    1 写在前面 在没有接触互联网这个行业的时候,我就一直很好奇网站是怎么构建的.现在虽然从事互联网相关的工作,但是也一直没有接触过Web开发之类的东西,但是兴趣终归还是要有的,而且是需要自己动手去实践的 ...

  2. [Python] 利用Django进行Web开发系列(二)

    1 编写第一个静态页面——Hello world页面 在上一篇博客<[Python] 利用Django进行Web开发系列(一)>中,我们创建了自己的目录mysite. Step1:创建视图 ...

  3. VIM for Python and Django Development

    VIM for Python and Django Development VIM-PyDjango created by Programmer for Programmer who work on ...

  4. Window环境下Python和Django的安装

    转载地址:http://blog.csdn.net/haoni123321/article/details/7593821 1.下载python,本文使用python-2.7.2.msi 2.下载dj ...

  5. Python和Django在Windows上的环境搭建

    作为一个.NET程序员,真心不喜欢Python以及PHP这种松散的语法.有人说,程序员应该多学几门语言,本想学习Java,无奈感觉Java的语法太啰嗦了.很多人都推荐Python,说它的语法简洁,执行 ...

  6. 【Python】django安装

    官方下载:https://www.djangoproject.com/download/ 报错 [root@test Django-]# python setup.py install Traceba ...

  7. Python和Django的Third Libraby分类汇总

    这些第三方包与Python和Django一起构成了强大的生态系统,自己在开发时大大减小工作难度和工作量, 这些包基本上能满足我们的大部分需求.人与人的差距,其中一点是你知道的比他多,这样你就能大大提高 ...

  8. 用Python和Django实现多用户博客系统(二)——UUBlog

    这次又更新了一大部分功能,这次以app的形式来开发. 增加博客分类功能:博客关注.推荐功能(ajax实现) 增加二级频道功能 更多功能看截图及源码,现在还不完善,大家先将就着看.如果大家有哪些功能觉的 ...

  9. Django中国|Django中文社区——python、django爱好者交流社区

    Django中国致力于成为Python和Django框架等技术的中文开发者学习交流平台. 内容涵盖python教程.python基础.Django教程.python入门.web.py教程.linux教 ...

  10. Python 学习笔记13:Python + wsgi + django 配置。坑爹的python3和wsgi不兼容的解决

    今人不见古时月,今月曾经照古人.生命是如此的美丽与短暂! 学习Python已经两个月了,Python的语法通过做简单的语法题和看Python语法介绍,有了初步的了解.但上班还是要做别的事情,所以感觉学 ...

随机推荐

  1. 第十三周学习笔记(编辑器选错了重发了这一个 原博客的确周天晚上提交了orz)

    并发:逻辑控制流在时间上的重叠. 构造并发程序的方法: 进程 I/O多路复用 线程 基于进程的并发编程 假设我们有两个客户端和一个服务器,服务器正在监听一个监听表述符上的请求.现在假设服务器接受了客户 ...

  2. sed命令的基本使用

    sed(Stream Editor):流编辑器 一次只读取一行 模式空间 1.sed语法: sed [option] "script" FILE... 2.选项: -n:静默模式, ...

  3. Bean

    1. Bean配置项 1.1. ID 在整个IOC容器中Bean的唯一标识 1.2. Class 具体要实例化的类 1.3. Scope 范围,作用域 1.4. Constructor argumen ...

  4. SCRUM项目 5.0

    5.0--------------------------------------------------- 1.团队成员完成自己认领的任务. 2.燃尽图:理解.设计并画出本次Sprint的燃尽图的理 ...

  5. IDEA 中 显示 *.properties 为中文

      效果:  

  6. server.transfer 用法

    server.transfer 特点: 1:大家熟悉的一个特点,用server.transfer 跳转到新页面时,浏览器的地址是没有改变的(因为重定向完全在服务器端进行,浏览器根本不知道服务器已经执行 ...

  7. python 之post、get与cookie实战

    项目名称:登陆考勤管理系统爬取个人考勤信息并写入excel表格 编写目的: 公司经常要统计员工的考勤信息,而员工每次都要登陆考勤系统,再复制相关信息出来,贴到EXCEL,再转给统计人员,统计人员再挨个 ...

  8. Document types require more than xhtml1.0

    这个东西只会在比较低版本的浏览器中会出现,比如IE7及以下会出这个错误. 错误的根源是html页面没有考虑浏览器兼容性问题. 在页面头部加入下面的内容即可解决标题中的问题 <!DOCTYPE h ...

  9. Linux重定向相关(转载帖,供自己cookbook)

    Linux重定向是指修改原来默认的一些东西,对原来系统命令的默认执行方式进行改变,比如说简单的我不想看到在显示器的输出而是希望输出到某一文件中就可以通过Linux重定向来进行这项工作.  Linux默 ...

  10. eclipse导入github项目

    以jeesite为例, github上面的项目大都是基于git方式进行版本控制以及使用maven构建的项目. 1 使用时,需先用eclipse的以git方式从github上下载代码. 下载后得到mav ...