开发者社区> yaohong> 正文

Python的Web应用框架--Django

简介: 一:简介      python的web框架有很多,个人查了一下,有Django、Pylons、 Tornado、Bottle和Flask等,其中使用人数最多的是Django,而我学习Django也是因为openstack中使用的是django框架。
+关注继续查看

一:简介

     python的web框架有很多,个人查了一下,有Django、Pylons、 Tornado、Bottle和Flask等,其中使用人数最多的是Django,而我学习Django也是因为openstack中使用的是django框架。

     Django是一个开放源代码的Web应用框架,由Python写成,采用了MVC的软件设计模式,即模型M,视图V和控制器C。

二:安装

由于Django2.0以后便不再支持python2.x,所以在安装时一定要注意。

2.1.Python3.x+Django2.x

安装python-setuptools

yum install python-setuptools

下载Django安装包

easy_install django

2.2.Python2.x+Django1.x

安装python-setuptools

yum install python-setuptools

下载Django安装包

下载源码包:https://www.djangoproject.com/download/

点击历史版本中的1.11版本下载。

输入以下命令并安装:

tar xzvf Django-X.Y.tar.gz    # 解压下载包
cd Django-X.Y                 # 进入 Django 目录
python setup.py install       # 执行安装命令

2.3检验

[root@solar django]# python
Python 2.7.3 (default, May 15 2014, 14:49:08)
[GCC 4.8.0] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import django
>>> django.VERSION
(1, 6, 5, 'final', 0)
>>>

三:创建第一个项目

3.1创建并浏览器展示

这里要学会使用django-admin.py管理工具,来创建。

创建项目

django-admin.py  startproject  HelloWord

进入项目,查看目录结构

[root@localhost ~]# cd HelloWorld/
[root@localhost HelloWorld]# tree
.
├── HelloWorld          --------项目的容器
│   ├── __init__.py     --------一个空文件,告诉 Python 该目录是一个 Python 包
│   ├── settings.py     --------该djiango项目的设置、配置
│   ├── urls.py         --------该djiango项目的URL声明,一份由djiango驱动的网站“目录”
│   └── wsgi.py         --------一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。
└── manage.py           --------一个非常实用的管理工具,可以实现与django的各种交互

1 directory, 5 files
[root@localhost HelloWorld]# 

启动服务器

python manage.py runserver 0.0.0.0:8000

再在浏览器中输入服务器IP:8000 

此时要注意:

1:关闭防火墙,

2:如果出现“dango error:DisallowedHost: Invalid HTTP_HOST header: ''. You may need to add u'' to ALLOWED_HOST”错误,就修改settings.py文件中

     ALLOWED_HOSTS = [‘*‘]  #在这里请求的host添加了*

3.2修改视图内容

1.在HelloWorld/HelloWorld目录中创建一个新文件 view.py 文件,并输入代码:

from django.http import HttpResponse
 
def hello(request):
    return HttpResponse("Hello world ! ")

 

2.在 urls.py 文件中注释原来的代码,添加如下代码

from django.conf.urls import url

from . import view

urlpatterns = [
    url(r'^$', view.hello),
]

 

然后启动django,访问浏览器出现如下内容

 

3.3修改URL

 修改urls.py代码,在其中添加如下红色类似字符

from django.conf.urls import url

from . import view

urlpatterns = [
    url(r'^yaohong$', view.hello),
]

 

然后启动django服务

再输入原来的服务器IP:8000会出现如下报错

因为需要再在端口号后面加入刚刚添加的字符,如下图所示

四:模板

 4.1实现模板数据分离

1.创建模板文件

在HelloWorld下创建创建templates文件夹再在文件夹下创建hello.html,HelloWorld/templates/hello.html

[root@bogon HelloWorld]# tree
.
├── db.sqlite3
├── HelloWorld
│   ├── __init__.py
│   ├── __init__.pyc
│   ├── settings.py
│   ├── settings.pyc
│   ├── urls.py
│   ├── urls.pyc
│   ├── view.py
│   ├── view.pyc
│   ├── wsgi.py
│   └── wsgi.pyc
├── manage.py
└── templates
    └── hello.html

2 directories, 13 files

 

 在hello.html中添加如下代码

<h1>{{ hello }}</h1>

 

2.在settings.py中配置模板路径

修改 TEMPLATES 中的 DIRS 为 [BASE_DIR+"/templates",]

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'DIRS': [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',
            ],
        },
    },
]

 

3.在 view.py中想模板提交数据

在view.py中加入如下代码,其中“hello”为模板中的变量,“Hello Word! my name is yaohong”为提交的数据

from django.shortcuts import render

def hello(request):
    context          = {}
    context['hello'] = 'Hello World! my name is yaohong'
    return render(request, 'hello.html', context)

 

4.启动服务器

python manage.py runserver 0.0.0.0:8000

 在浏览器中输入地址

4.2Django模板标签

if/else 标签

{% if condition1 %}
   ... display 1
{% elif condition2 %}
   ... display 2
{% else %}
   ... display 3
{% endif %}

 

for 标签

{% for athlete in athlete_list %}
    <h1>{{ athlete.name }}</h1>
    <ul>
    {% for sport in athlete.sports_played %}
        <li>{{ sport }}</li>
    {% endfor %}
    </ul>
{% endfor %}

ifequal/ifnotequal 标签

{% ifequal %} 标签比较两个值,当他们相等时,显示在 {% ifequal %} 和 {% endifequal %} 之中所有的值。

{% ifequal user currentuser %}
    <h1>Welcome!</h1>
{% endifequal %}

注释标签

{# 这是一个注释 #}

 

过滤器

#{{ name }} 变量被过滤器 lower 处理后,文档大写转换文本为小写
{{ name|lower }}
#将第一个元素并将其转化为大写。
{{ my_list|first|upper }}

 

include 标签

{% include "nav.html" %}

 

模板继承

 首先新建一个要被继承的文件,这里命名为base.html

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>继承的学习</title>
</head>
<body>
    <h1>Hello World!</h1>
    <p>我是继承过来的!!!</p>
    {% block mainbody %}
       <p>original</p>
    {% endblock %}
</body>
</html>

 

 再在hello.html继承base.html页面

{% extends "base.html" %}
<h1>{{ hello }}</h1>

{% block mainbody %}<p>继承了 base.html 文件</p>
{% endblock %}

 

 

五:模型

5.1安装mysql 

首先检查系统是否自带或者我们已经安装mysql,

rpm -qa | grep mysql

 

安装并启动mysql:

#非centos7版本
yum install mysql
yum install mysql-server
yum install mysql-devel
service mysqld start

 

#centos7版本执行如下
yum install mariadb-server mariadb

systemctl start mariadb  #启动MariaDB
systemctl enable mariadb  #设置开机启动

 

验证安装

执行下面语句会看到版本信息,如果没有任何输出,表示mysql没有安装成功

mysqladmin --version

 

设置用户

更改root密码

mysqladmin -u root password "new_password";

 

设置test用户密码

 mysql -u root -p
>GRANT ALL PRIVILEGES ON test.* TO 'test'@'localhost' \
    IDENTIFIED BY 'test123';
>GRANT ALL PRIVILEGES ON test.* TO 'test'@'%' \
    IDENTIFIED BY 'test123';

 

5.2修改相应配置

1.数据库配置

在HelloWorld/HelloWorld/settings.py下修改DATABASES{}如下:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', 
        'NAME': 'test',
        'USER': 'test',
        'PASSWORD': 'test123',
        'HOST':'localhost',
        'PORT':'3306',
    }
}

 

2.定义模型

创建APP

进入HelloWorld文件夹

django-admin.py startapp TestModel

 

创建完成后目录如下:

[root@localhost HelloWorld]# tree
.
├── db.sqlite3
├── HelloWorld
│   ├── __init__.py
│   ├── __init__.pyc
│   ├── settings.py
│   ├── settings.pyc
│   ├── testdb.py
│   ├── testdb.pyc
│   ├── urls.py
│   ├── urls.pyc
│   ├── view.py
│   ├── view.pyc
│   ├── wsgi.py
│   └── wsgi.pyc
├── manage.py
├── templates
│   ├── base.html
│   └── hello.html
└── TestModel
    ├── admin.py
    ├── admin.pyc
    ├── apps.py
    ├── __init__.py
    ├── __init__.pyc
    ├── migrations
    │   ├── 0001_initial.py
    │   ├── 0001_initial.pyc
    │   ├── __init__.py
    │   └── __init__.pyc
    ├── models.py
    ├── models.pyc
    ├── tests.py
    └── views.py

4 directories, 29 files

 

修改HelloWorld/TestModel/models.py:

创建模型

# models.py
from django.db import models
 
class Test(models.Model):
    name = models.CharField(max_length=20)

 

修改settings.py

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'TestModel',               # 添加此项
)

 

执行下列命令

$ python manage.py migrate   # 创建表结构

$ python manage.py makemigrations TestModel  # 让 Django 知道我们在我们的模型有一些变更
$ python manage.py migrate TestModel   # 创建表结构

 

数据库操作

修改HelloWorld/HelloWorld/urls.py

from django.conf.urls import *
from . import view,testdb
 
urlpatterns = [
    url(r'^hello$', view.hello),
    url(r'^testdb$', testdb.testdb),
]

创建HelloWorld/HelloWorld/testdb.py

# -*- coding: utf-8 -*-
 
from django.http import HttpResponse
 
from TestModel.models import Test
 
# 数据库操作
def testdb(request):
    test1 = Test(name='runoob')
    test1.save()
    return HttpResponse("<p>数据添加成功!</p>")

 

然后在浏览器中输入IP:8000/testdb

 

 

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Android应用框架之PackageManagerService
系统在启动的时候会启动一个叫做PackageManagerService的服务,顾名思义,这个服务主要管理安装在设备上的应用程序,其中最为重要的工作就是在在系统启动之后,PackageManagerService会扫描特定目录下地以apk为后缀的文件,然后将对应的应用安装到系统中。注意,这里的安装并不是我们平时所说的安装,它指的的是将存放在磁盘之上的静态应用程序文件进行解析,
2118 0
建立可扩展的silverlight 应用框架 step-4
通过外部配置文件加载模块module 在上一节中为项目引入了“Prism”框架,并建立了一个Hello Prism做测试。这里要把项目好好的整理一下。使其更加的合理和具有可扩展性。 我的目的是,在左侧的导航栏目里点击按钮,相应的右侧的主体部分显示不同的内容。
717 0
(四):C++分布式实时应用框架——状态中心模块
C++分布式实时应用框架——状态中心模块   上篇:(三):C++分布式实时应用框架——系统管理模块     技术交流合作QQ群:436466587 欢迎讨论交流     版权声明:本文版权及所用技术归属smartguys团队所有,对于抄袭,非经同意转载等行为保留法律追究的权利!     状态中心是分布式系统中不可或缺的部分。
1200 0
Android应用框架之BroadcastReceiver
广播机制是Android系统中的一种消息传播机制,通过观察者模式实现了消息发送者与消息接收者之间的解耦。BroadcastReceiver的使用方式有两种,一种是静态注册,即在Manifest文件中注册,然后在需要发送广播时调用context.sendBroadcast(intent);;第二种是动态注册。BroadcastReceiver的使用不是本文的重点,本文将着重讲解
1242 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
23628 0
建立可扩展的silverlight 应用框架 step-5
整理Module 在第三节里边,建立了一个最简单的Module。这里要对其再进行整理。之前我写过一篇《简练的视图模型 ViewModel》这里就讲述了一个最最基本的运用视图与模型的例子。用模型来控制视图的呈现在很早的时候就提出来了。
691 0
Android应用框架之Application&ActivityThread
不同于其他系统,在Android中Application并不是一个重要的概念,甚至开发人员在开发的过程中很少需要直接与Application打交道,其提供的也仅仅是一个上下文环境。至于为什么会这样,还是与设计者的设计思想有关。
1838 0
来了!闲鱼技术团队开源 Flutter 应用框架 Fish Redux
目前,跨平台、高性能的渲染引擎逐渐成为大前端领域的一个热点。作为其中的明星, Flutter有很大的机会成为下一代主流的跨端解决方案。
11527 0
建立可扩展的silverlight 应用框架 step-6
整理导航模块“LeftNav”   首先说一下我想要实现的效果。 我希望在左侧的导航点击了以后右侧的主体部分发声变化。   之前我在LeftNav模块用的控件是ToggleButton并为其制作了样式。
735 0
(一):C++分布式实时应用框架----整体介绍
C++分布式实时应用框架 (Cpp Distributed Real-time Application Framework) 版权声明:本文版权及所用技术归属smartguys团队所有,对于抄袭,非经同意转载等行为保留法律追究的权利!     在现今软件系统纷纷“云化”的浪潮下,各种支持“云化”的框架、工具层出不穷,但这些现成的工具大多基于JAVA,go等语言,且应用场景均为非实时系统。
1418 0
+关注
yaohong
云计算
127
文章
1
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载