以前用web.py(另外一款轻量级web开发框架)做一个监控管理平台,没有做特别的记录就不好拾起来。最近做一个日志聚合系统,使用的是django,这次就记下来,方便查询。
Django是一个高效的web开发框架,上手容易,便于调试和发布。
设计模式
它的设计遵循经典的web设计架构-MVC(Model-view-controller),一个应用分为四部分:
- models.py:文件主要用一个 Python 类来描述数据表。 称为 模型(model) 。本文不对model做详细介绍,数据库的存取是单装了mysql,自己做的dao。
- views.py:文件包含了页面的业务逻辑。是模板和模型间的桥梁,接收前端url请求,进行业务逻辑实现,最后返回数据(结果或模板)。
- urls.py:一个配置文件,用于映射 URL到视图。
- xxx.html: html 模板,它描述了页面设计,支持简单的模板语言。
环境准备
python & django,本文使用的是python-2.7.9,django-1.7.6
模板语言
在html中使用模板语言定义页面框架和内容,后台由模板引擎渲染成完整的html。{% %}用于逻辑控制,{{}}用于变量引用
模板间关系
- include:{% include 'nav.html' %},引入布局单元
- 模板继承:定义一个基础模板(定义页面框架),由子模板来继承(填充个性化页面子块)。基础模板使用block标签-{% block %},每个block下的这一块内容将有可能被子模板覆盖。子模板用extends标签来继承基础模板{% extends "base.html" %}。
//base.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
<html lang="en">
<head>
<title><strong>{% block</strong> title <strong>%}{% endblock %}<</strong>/title>
</head>
<body>
<h1>My helpful timestamp site</h1>
{% block content %}{% endblock %}
{% block footer %}
<hr>
<p>Thanks for visiting my site.</p>
{% endblock %}
</body>
</html>
//子模板 current.html
<strong>{% extends "base.html" %} {% block title %}</strong>The current time<strong>{% endblock %}</strong> {% block content %}
<p>It is now {{ current_date }}.</p>{% endblock %}
基本控制标签
- {% if %} {% else %} {% endif %}:支持and/or/not关键字,不支持and/or组合,不支持用圆括号来组合比较操作,不支持 elif
- {% for %}{% endfor %}:循环语法是 for X in Y
- {% ifequal %}{% endifequal %}或者ifnotequal:只有模板变量,字符串,整数和小数可以作为 {% ifequal %} 标签的参数
- {{var|op}}:模板过滤器,在变量被显示前修改它的值。op有lower/upper/length/join等操作
补充:python中空列表、空元组、空字典、空字符串、0、None对象、False对象代表布尔值假,其余都是真布尔值。
相关技术点
前端页面:HTML、JavaScript、HTML DOM、JQuery、ajax、JSON
后端逻辑:python
页面模板:建议网上找基于bootstrap的网页模板
实例流程
项目创建
django-admin.py startproject tulip
获得如下的目录,manage.py/__init__.py/wsgi.py不需要修改,另外手动创建static目录用于保存js/css,创建templates用于保存html模板,创建lib用于保存依赖库
tulip/
manage.py
tulip/
__init__.py
settings.py
urls.py
wsgi.py
static/
templates/
配置修改
我们新增templates/static目录,在模板中想要正确引用,需要修改下django settings.py
BASE_DIR = os.path.dirname(__file__)
STATIC_URL = '/static/'
STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static').replace('\\','/'),
)
TEMPLATE_DIRS = (
os.path.join(BASE_DIR, 'templates').replace('\\','/'),
)
TIME_ZONE = 'Asia/Shanghai' #语言指定为中文
在页面中就可以如下引用js或者css
<script src="/static/js/jquery-1.10.2.js"></script>
<link href="/static/css/bootstrap.css" rel="stylesheet">
python返回html也可以直接写html文件名,不用加templates
逻辑实现
写页面
//search.html
<select id="servicename" class="form-control" onchange="getServiceInfo()">
<option value="">应用服务</option>
{% for service in servicenames %}
<option>{{ service }}</option>
{% endfor %}
</select>
配置urls.py
from django.conf.urls import patterns, include, url
urlpatterns = patterns('tulip',//tulip是模块名,作为后续映射路径的共同前缀
url(r'^$', 'searchText.index'),
)
视图逻辑
//searchText.py
from django.shortcuts import render_to_response
from django.http import HttpResponse
def index(request):
dao = TulipDao()
servicenames = dao.getServicenames()
return render_to_response('search.html', locals())
#或者return render_to_response('search.html',{'servicenames':servicenames})
#locals()返回的字典包含所有局部变量的名称与值的映射
启动应用
python manage.py runserver 0.0.0.0:8000 //0.0.0.0允许任意非本地连接,不指定ip则仅监听本地连接
文章太长了,再分一篇吧,下一篇记录一些技巧和参考资料