zoukankan      html  css  js  c++  java
  • web框架-(二)Django基础

    上面我们已经知道Python的WEB框架有Django、Tornado、Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM、模型绑定、模板引擎、缓存、Session等诸多功能。今天就一起来学习下Django;

    一、准备工作

    1)打开cmd,进入到python安装路径下的Scripts;
    2)使用pip安装:pip install Django
    3)添加环境变量:python安装路径下的Scripts;

    二、基本配置

    1. 创建django程序

    • 终端命令:django-admin startproject sitename
    • IDE创建Django程序时,本质上都是自动执行上述命令

    目录结构如下:

    2. 配置文件

    1)数据库:

    DATABASES = {
        'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME':'dbname',
        'USER': 'root',
        'PASSWORD': 'xxx',
        'HOST': '',
        'PORT': '',
        }
    }
    

    2)模板:

    TEMPLATE_DIRS = (
            os.path.join(BASE_DIR,'templates'),
        )
    

    3)静态文件:

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

    三、功能分类

    1. 创建APP

    # 切换到Django项目目录,执行命令
    python manage.py startapp cmdb
     
    # 目录结构
    - cmdb
        - migrations  #数据库操作记录(只是修改表结构的记录)
        - init      #表示python数据包(python3中有无均可)
        - admin      #Django为我们提供的后台管理
        - apps      #配置当前app
        - models     #创建数据库表结构,写指定的类,通过命令可以创建数据库结构
        - tests      #单元测试
        - views      #写业务逻辑代码,最重要的就是这个文件了

    2. 简单实例

    1)登录实例

    templates下生成html文件,如login.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            label{
                 80px;
                text-align: right;
                display: inline-block;
            }
        </style>
        <link rel="stylesheet" href="/static/commons.css"/>
    </head>
    <body>
        <form action="/login/" method="post">
            <p>
                <label for="username">用户名:</label>
                <input id="username" type="text" name="user"/>
            </p>
            <p>
                <label for="password">密码:</label>
                <input id="password" type="text" name="pwd"/>
                <input type="submit" value="提交" style="cursor:pointer"/>
                <span style="color: red;font-size:15px;">{{error_msg}}</span>
            </p>
        </form>
    </body>
    </html>

    修改url文件,定义路由规则

    from django.conf.urls import url
    from django.contrib import admin
    from cmdb import views
    
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        url(r'^login', views.login),
    ]
    

    定义视图函数:app下views.py

    from django.shortcuts import render
    
    # Create your views here.
    from django.shortcuts import HttpResponse
    from django.shortcuts import render
    from django.shortcuts import redirect
    import time
    USER_LIST=[
        {'username':'alex','email':'lei10@qq.com','gender':'男'},
        {'username':'cc','email':'lei12@qq.com','gender':'男'},
        {'username':'tt','email':'lei13@qq.com','gender':'女'}
    ]
    def home(request):
        if request.method=="POST":
            u = request.POST.get("username");
            e = request.POST.get("email");
            g = request.POST.get("gender");
            temp = {'username':u,'email':e,"gender":g}
            USER_LIST.append(temp)
        return render(request,"home.html",{"user_list":USER_LIST})
    def login(request):
        error_msg=""
        if request.method=="POST":
            user = request.POST.get('user',None);
            pwd = request.POST.get('pwd',None);
            if user=="root" and pwd=="111111":
                return redirect("/home/")
            elif user=="":
                error_msg="用户名不能为空!"
            elif pwd == "":
                error_msg = "密码不能为空!"
            else:
                error_msg="用户名或密码错误!";
        return render(request,"login.html",{'error_msg':error_msg})
    

    浏览器访问http://127.0.0.1:8000/login显示login.html写的登录页面,可输入登录信息查看页面显示

    通过上面的例子我们可以知道Django的生命周期:

    -> URL对应关系(匹配) -> 视图函数 -> 返回用户字符串
    -> URL对应关系(匹配) -> 视图函数 -> 打开一个HTML文件,读取内容

    2)其他

    request.GET.get('',None) # 获取get请求发来的数据
    request.POST.get('',None) # 获取post请求发来的数据
    return HttpResponse("字符串")
    return render(request, "HTML模板的路径")
    return redirect('/只能填URL')

    3. 模板

    上面实例中的login.html就是模板;对于模版,其实就是读取模版(其中嵌套着模版标签),然后将 Model 中获取的数据插入到模版中,最后将信息返回给用户。

    模板中也有自己的语言,该语言可以实现数据展示

    • {{ item }}
    • {% for item in item_list %}  <a>{{ item }}</a>  {% endfor %}
    •   forloop.counter
    •   forloop.first
    •   forloop.last 
    • {% if ordered_warranty %}  {% else %} {% endif %}
    • 母板:{% block title %}{% endblock %}
    • 子板:{% extends "base.html" %}
    •    {% block title %}{% endblock %}
    • 帮助方法:
    • {{ item.event_start|date:"Y-m-d H:i:s"}}
    • {{ bio|truncatewords:"30" }}
    • {{ my_list|first|upper }}
    • {{ name|lower }}
  • 相关阅读:
    网络银行木马DYRE知多少(1)
    搭建LVS+Keepalived负载均衡集群
    Android中@+id和@id的差别
    LeetCode258——Add Digits
    hive 报错/tmp/hive on HDFS should be writable. Current permissions are: rwx--x--x
    java 调用 库文件错误查找方法
    如何使用安信可 ESP 系列一体化开发环境【转】
    如何安装安信可一体化开发环境【转】
    ESP8266串口模块的基本使用【转】
    WIFI模块ESP8266的使用指南【转】
  • 原文地址:https://www.cnblogs.com/cocc/p/6147931.html
Copyright © 2011-2022 走看看