zoukankan      html  css  js  c++  java
  • Django项目基础

    一、命令行搭建Django项目

    • 安装django
    # 在指定解释器环境下安装django 1.11.x
    # 在真实python3环境下: pip3 install django==1.11.x
    
    # 查看django版本: django-admin --version
    # 安装出错: 采用管理员命令行
    
    • 创建项目
    # 先前往目标路径
    # 创建项目: django-admin startproject proj_name
    
    • 创建应用
    # 进入项目根目录
    # 创建应用: python3 manage.py startapp app_name
    # 去项目的settings文件添加 应用名 到INSTALLED_APPS
    
    • 启动服务
    # 在项目根目录下: python3 manage.py runserver 127.0.0.1:8888
    

    二、项目及应用目录

    '''
    proj_name:项目目录,包含项目最基本的一些配置
    	-- __init__.py:模块的配置文件
    	-- settings.py:配置总文件
    	-- urls.py:url配置文件,django项目中的所有页面都需要对其配置url地址
    	-- wsgi.py:(web server gateway interface),服务器网关接口,python应用与web服务器直接通信的接口
    templates:模板文件夹,存放html文件的(页面),支持使用Django模板语言(DTL),也可以使用第三方(jinja2)
    manage.py:项目管理器,与项目交互的命令行工具集的入口,查看支持的所有命令python3 manage.py
    '''
    
    '''
    migrations:数据迁移(移植)模块,内容都是由Django自动生成
    	-- __init__.py
    __init__.py
    admin.py:应用的后台管理系统配置
    apps.py:django 1.9后,本应用的相关配置
    models.py:数据模型模块,使用ORM框架,类似于MVC模式下的Model层
    tests.py:自动化测试模块,可以写自动化测试脚本
    views.py:执行相应的逻辑代码模块
    '''
    

    三、配置文件简介

    • 项目目录下 setting.py 文件

    四、Pycharm搭建项目

    # 选择有django环境的解释器创建项目
    # Tools -> Run manage.py Task... -> startapp app_name
    # 正常运行项目来启动项目, 并不是执行某一个py文件
    

    五、项目响应请求

    完成 http://127.0.0.1:8888/index 请求的处理

    • 在项目的urls.py中配置路由
    # 项目下 urls.py 文件
    import app.views as app_views # 创建的app下的视图文件
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        url(r'index', app_views.index) # 配置的路由
    ]
    
    • 在具体应用下的视图文件为请求配置响应函数
    # app应用下 views.py 文件
    from django.shortcuts import HttpResponse
    def index(request):
        return HttpResponse('hello django')
    
    • 第一个响应
    from django.shortcuts import HttpResponse
    def view_action(request):
        return HttpResponse('django response')
    
    • 第一个模板页面
    from django.shortcuts import render
    def view_action(request):
        return render(request, 'template_page.html')
    
    • 第一个重定向
    from django.shortcuts import redirect
    def view_action(request):
        return redirect('/重定向的路由')
    

    六、静态文件加载

    • 静态文件的根路由 => 规定了加载静态文件的起点
    1.在settings.py中配置
    STATIC_URL = '/static/'  # 静态文件请求根路由
    STATICFILES_DIRS = [
        os.path.join(BASE_DIR, 'static')   # 静态文件检索的文件夹
    ]
    2.在项目根目录下创建static文件夹
    3.静态文件就放在static根目录或子目录下
    4.获取静态文件:/static/目标文件(可以包含static子文件夹路径)
    

    七、GET请求的数据获取

    # app应用下 views.py 文件
    def login(request):
        if request.method == "GET":
            # 获得到则返回一个值, 获取不到返回None
        	request.GET.get('usr')
            # 获得到则返回一个值, 获取不到返回默认值PWD
            request.GET.get('pwd', 'PWD')
            # 获得到则返回的多个值
            request.GET.getlist('stus')
    

    八、POST请求的数据获取

    # app应用下 views.py 文件
    def login(request):
        if request.method == "POST":
            # 获得到则返回一个值, 获取不到返回None
        	request.POST.get('usr')
            # 获得到则返回一个值, 获取不到返回默认值PWD
            request.POST.get('pwd', 'PWD')
            # 获得到则返回的多个值
            request.POST.getlist('stus')
    

    七、生命周期

    1.浏览器发送请求
    2.wsgi服务器接收到请求,将请求解析交给Django
    3.Django中间件过滤请求信息,交给路由
    4.路由完成业务逻辑的分发,到指定app下views中指定的视图函数
    5.视图函数完成具体的业务逻辑,返回响应结果
    6.将处理结果通过服务器返回给浏览器
    
    

    十、ORM的Model层配置表对应的model类

    # app应用下 models.py 文件
    class User(models.Model):
        id = models.AutoField(primary_key=True)
        usr = models.CharField(max_length=20)
        pwd = models.CharField(max_length=32)
    

    十一、配置Mysql完成数据迁移

    # 项目目录下 settings.py 文件
    1.在settings.py配置Mysql数据库信息
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'dg2',
            'HOST': '127.0.0.1',
            'PORT': 3306,
            'USER': 'root',
            'PASSWORD': 'root'
        }
    }
    
    2.在项目或应用的init文件中修改连接数据库的模块为pymysql
    import pymysql
    pymysql.install_as_MySQLdb()
    
    3.在项目目录下,执行(生成迁移数据,没有映射到数据库):python3 manage.py makemigrations
    
    4.将迁移数据映射到数据库:python3 manage.py migrate
    
    

    十二、数据库简易增删改查

    # app应用下 views.py 文件的具体逻辑代码中
    from app.models import User
    # User.objects.filter(具体条件).具体操作(),filter就是sql是否需要条件
    # 增
    User.objects.create(usr='abc', pwd='123')  # 第一种方式
    user = User(usr='owen', pwd='123')
    user.save()  # 第二种方式
    # 删
    User.objects.filter(id=1).delete()
    # 改
    User.objects.filter(pwd='123').update(pwd='000')
    # 查
    User.objects.filter(pwd='000').all()
    User.objects.filter(pwd='000').first()
    
  • 相关阅读:
    基于DCT系数的实时监控中运动目标检测
    智能视频分析中的光照强度突然变化的处理方法
    《Single Image Haze Removal Using Dark Channel Prior》一文中图像去雾算法的原理、实现、效果及其他。
    mysql流程控制语句
    mysql中变量
    mysql中触发器
    mysql中(存储)函数
    mysql中存储过程
    mysql中视图
    mysql中一些表选项
  • 原文地址:https://www.cnblogs.com/liubinliuliu/p/10440834.html
Copyright © 2011-2022 走看看