Django基本设置

Dango设置流程图片示例:css

设置路由时须要注意的一个点是:Django中定义路由时,一般习惯以斜线 / 结尾html

 

 

其余经常使用命令:前端

 

  python manage.py runserver 0.0.0.0:80     开启
     django-admin startproject 项目名               project项目
  python manage.py startapp                        app名字
  python manage.py makemigrations          生成迁移文件
  python manage.py migrate                      生成数据库表
python

      python manage.py createsuperuser          建立超级管理员
jquery

 

一.django简单实现流程

复制代码
django
    #安装: pip3 install django  添加环境变量 #1 建立project django-admin startproject mysite ---mysite ---settings.py ---url.py ---wsgi.py ---- manage.py(启动文件) #2 建立APP  python mannage.py startapp app01 #3 settings配置
    
    INSTALLED_APPS 中注册 app01

     MIDDLEWARE 中注释掉csrf #'django.middleware.csrf.CsrfViewMiddleware',
TEMPLATES 中添加 'DIRS': [os.path.join(BASE_DIR, "templates")],

     LANGUAGE_CODE = 'zh_Hans' # 汉语
TIME_ZONE = 'Asia/Shanghai' # 时区

STATICFILES_DIRS=( os.path.join(BASE_DIR,"static"), # 静态文件真实路径 ) STATIC_URL = '/static/' # 别名 url访问的路径 # 咱们只能用 STATIC_URL,但STATIC_URL会按着你的STATICFILES_DIRS去找#4 根据需求设计代码 url.py view.py #5 使用模版 render(req,"index.html") #6 启动项目 python manage.py runserver 127.0.0.1:8090 #7 链接数据库,操做数据 model.py
复制代码

django的命令行工具

django-admin.py 是Django的一个用于管理任务的命令行工具,manage.py是对django-admin.py的简单包装,每个Django Project里都会有一个mannage.py。nginx

<1> 建立一个django工程 : django-admin.py startproject mysiteweb

        当前目录下会生成mysite的工程,目录结构以下:shell

       

  • manage.py ----- Django项目里面的工具,经过它能够调用django shell和数据库等。
  • settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其余一些工做的变量。
  • urls.py ----- 负责把URL模式映射到应用程序。

<2>在mysite目录下建立blog应用: python manage.py startapp blog数据库

       

<3>启动django项目:python manage.py runserver 8080django

       这样咱们的django就启动起来了!当咱们访问:http://127.0.0.1:8080/时就能够看到:

       

<4>生成同步数据库的脚本:python manage.py makemigrations  

                     同步数据库:  python manage.py migrate   

       注意:在开发过程当中,数据库同步误操做以后,不免会遇到后面不能同步成功的状况,解决这个问题的一个简单粗暴方法是把migrations目录下

                的脚本(除__init__.py以外)所有删掉,再把数据库删掉以后建立一个新的数据库,数据库同步操做再从新作一遍。            

<5>当咱们访问http://127.0.0.1:8080/admin/时,会出现:

       

       因此咱们须要为进入这个项目的后台建立超级管理员:python manage.py createsuperuser设置好用户名和密码后即可登陆啦!

<6>清空数据库:python manage.py  flush

<7>查询某个命令的详细信息: django-admin.py  help  startapp

       admin 是Django 自带的一个后台数据库管理系统。

<8>启动交互界面 :python manage.py  shell

     这个命令和直接运行 python 进入 shell 的区别是:你能够在这个 shell 里面调用当前项目的 models.py 中的 API,对于操做数据,还有一些小测试很是方便。

<9> 终端上输入python manage.py 能够看到详细的列表,在忘记子名称的时候特别有用

 

二.Django的配置文件(settings)

一、概述:

     #静态文件交由Web服务器处理,Django自己不处理静态文件。简单的处理逻辑以下(以nginx为例):

     #          URI请求-----> 按照Web服务器里面的配置规则先处理,以nginx为例,主要求配置在nginx.
                             #conf里的location

                         |---------->若是是静态文件,则由nginx直接处理

                         |---------->若是不是则交由Django处理,Django根据urls.py里面的规则进行匹配

    # 以上是部署到Web服务器后的处理方式,为了便于开发,Django提供了在开发环境的对静态文件的处理机制,方法是这样:

    #一、在INSTALLED_APPS里面加入'django.contrib.staticfiles',

    #二、在urls.py里面加入
       if settings.DEBUG:  
           urlpatterns += patterns('', url(r'^media/(?P<path>.*)$', 
           'django.views.static.serve', {'document_root': settings.MEDIA_ROOT }),   
            url(r'^static/(?P<path>.*)$',
          'django.views.static.serve',{'document_root':settings.STATIC_ROOT}), )  

    # 三、这样就能够在开发阶段直接使用静态文件了。

二、MEDIA_ROOT和MEDIA_URL

        #而静态文件的处理又包括STATIC和MEDIA两类,这每每容易混淆,在Django里面是这样定义的:

        #MEDIA:指用户上传的文件,好比在Model里面的FileFIeld,ImageField上传的文件。若是你定义

        #MEDIA_ROOT=c:\temp\media,那么File=models.FileField(upload_to="abc/")#,上传的文件就会被保存到c:\temp\media\abc  
        #eg:
            class blog(models.Model):  
                   Title=models.charField(max_length=64)  
                   Photo=models.ImageField(upload_to="photo") 
        #     上传的图片就上传到c:\temp\media\photo,而在模板中要显示该文件,则在这样写
        #在settings里面设置的MEDIA_ROOT必须是本地路径的绝对路径,通常是这样写:
                 BASE_DIR= os.path.abspath(os.path.dirname(__file__))  
                 MEDIA_ROOT=os.path.join(BASE_DIR,'media/').replace('\\','/') 

        #MEDIA_URL是指从浏览器访问时的地址前缀,举个例子:
            MEDIA_ROOT=c:\temp\media\photo  
            MEDIA_URL="/data/"
        #在开发阶段,media的处理由django处理:

        #    访问http://localhost/data/abc/a.png就是访问c:\temp\media\photo\abc\a.png

        #    在模板里面这样写<img src="{{MEDIA_URL}}abc/a.png">

        #    在部署阶段最大的不一样在于你必须让web服务器来处理media文件,所以你必须在web服务器中配置,
        #  以便能让web服务器能访问media文件
        #    以nginx为例,能够在nginx.conf里面这样:

                 location ~/media/{
                       root/temp/
                       break;
                    }

        #    具体能够参考如何在nginx部署django的资料。

三、STATIC_ROOT和STATIC_URL、
    STATIC主要指的是如css,js,images这样文件,在settings里面能够配置STATIC_ROOT和STATIC_URL,
    配置方式与MEDIA_ROOT是同样的,可是要注意

    #STATIC文件通常保存在如下位置:

    #一、STATIC_ROOT:在settings里面设置,通常用来放一些公共的js,css,images等。

    #二、app的static文件夹,在每一个app所在文夹都可以创建一个static文件夹,而后当运行collectstatic时,
    #    Django会遍历INSTALL_APPS里面全部app的static文件夹,将里面全部的文件复制到STATIC_ROOT。所以,
    #   若是你要创建可复用的app,那么你要将该app所须要的静态文件放在static文件夹中。

    # 也就是说一个项目引用了不少app,那么这个项目所须要的css,images等静态文件是分散在各个app的static文件的,比
    #  较典型的是admin应用。当你要发布时,须要将这些分散的static文件收集到一个地方就是STATIC_ROOT。

    #三、STATIC文件还能够配置STATICFILES_DIRS,指定额外的静态文件存储位置。
    #  STATIC_URL的含义与MEDIA_URL相似。

    # ----------------------------------------------------------------------------
    #注意1:
        #为了后端的更改不会影响前端的引入,避免形成前端大量修改

        STATIC_URL = '/static/'               #引用名
        STATICFILES_DIRS = (
            os.path.join(BASE_DIR,"statics")  #实际名 ,即实际文件夹的名字
        )

        #django对引用名和实际名进行映射,引用时,只能按照引用名来,不能按实际名去找
        #<script src="/statics/jquery-3.1.1.js"></script>
        #------error-----不能直接用,必须用STATIC_URL = '/static/':
        #<script src="/static/jquery-3.1.1.js"></script>

    #注意2(statics文件夹写在不一样的app下,静态文件的调用):

        STATIC_URL = '/static/'

        STATICFILES_DIRS=(
            ('hello',os.path.join(BASE_DIR,"app01","statics")) ,
        )

        #<script src="/static/hello/jquery-1.8.2.min.js"></script>

    #注意3:
        STATIC_URL = '/static/'
        {% load staticfiles %}
       # <script src={% static "jquery-1.8.2.min.js" %}></script>

 

 

 

 

CP:https://www.cnblogs.com/yuanchenqi/articles/6083427.html

https://www.cnblogs.com/chichung/p/9872766.html

相关文章
相关标签/搜索