django前戏

Django前戏:

1、软件开发:

  C/S 客户端与服务端

HTTP(超文本传输协议):协议的由来,如同sql语句由来一样。为了开发使用方便所形成的统一接口统一规范

学习Django之前我们先来了解下HTTP协议:

  1、四大特性:

     1,基于TCP/IP作用于应用层之上的协议

     2,基于请求响应:请求&响应

     3,无状态

        cookie session      token

     4、无链接

        可以通过websocket 实现长链接

  2、数据格式:

     1、请求格式:

        请求首行

        请求头

        /r/n

        请求体

     2、响应格式:

          请求首行

          请求头

        /r/n

        请求体

  3、响应状态码:

      用一串数字表示语言解释

      1xx:服务端已经成功接收到了你的请求 正在处理 你可以继续提交其他数据

      2xx:服务端成功响应了相应的数据(200)

      3xx: 重定向

      4xx:(404请求资源不存在) (403你当前不符合某一些条件 无法正常访问)

      5xx:服务器内部错误

了解下简易的web框架:

    views.py 里我们存放函数,我们管这些函数叫做视图函数

    urls.py 里面放路由(后缀)映射views中的函数,与视图函形成对应关系

    templates文件夹 里面放的全部是HTML文件

了解动静太网页:

    静态网页

      数据是写死的,万年变,很早之前较多,现在几乎看不到这样的网站了!

    动态网页:

      数据是实时动态获取的

        1、后端代码动态获取,

        2,、数据是从数据库查询出来的,

2、jinja2模板语法(目前flask用的就是jinja2模板语法):

  专门用来处理后端数据与HTML页面交互

  模板语法(极其贴近python后端语法)

    让你能够在HTML页面上也能用后端python语法来操作后端传递过来的数据

  <p>{{ userDic }}</p>
  <p>{{ userDic.username }}</p>
  <p>{{ userDic['age'] }}</p>
  <p>{{ userDic.get('hobby') }}</p>
  <p>{{ userDic.get('hobby').0 }}</p>
  <p>{{ userDic.get('hobby').1 }}</p>
  <p>{{ userDic.get('hobby').2 }}</p>

  {% for user_dic in user_list %}
  <tr>
  <td>{{ user_dic.id }}</td>
  <td>{{ user_dic.username }}</td>
  <td>{{ user_dic.password }}</td>
  </tr>
  {% endfor %}

  模板的渲染 将后端传递给HTML文件数据 在后端处理好生一个完整的HTML文件的过程

  注意:模板的渲染是在厚度完成的,跟前端没有关系

3、python 三大主流web框架

    Django:大而全,自带的组件和功能比较多;不足之处:写小项目的时候可能会比较笨重,

    Flask:短小精悍,自带的组件和功能特别特别的少,基本全部依赖于第三方组件;不足之处:受限于第三方模块的影响比较大,如果flask所有第三方组件加一起能够盖过Django

    tornado:异步非阻塞,这个框架甚至可以用来开发游戏的服务器

  例如:a:sockect

     b:路由匹配

     c:模板语法

     Django:a用的别人的(wsgiref);b自己写的;c自己写的

     Flask:a:用别人的;b:自己写的;c:用别人的(jinja2)

     Tornado:a,b,c都是自己写的

4、django框架介绍
  注意事项
  1.计算机名称不能有中文
  2.python解释器不要使用3.7版本 推荐使用版本3.4~3.6
  3.一个pycharm窗口 只能跑一个项目

django版本问题:
  django版本以1.11.11为主(1.11.9~1.11.13)

  如何检验django是否安装成功
  命令行敲 django-admin


5、命令行创建项目
  1.创建django项目
  django-admin startproject 项目名(例如mysite)
  2.启动django项目
  切换到项目文件夹下
  python3 manage.py runserver
  python3 manage.py runserver 127.0.0.1:8080
  3.创建应用(django支持多app开发)
  python3 manage.py startapp app01

  注意
    1.不会自动帮你创建templates文件夹
    2.配置文件中不会自动帮你书写templates文件路径


  app的概念
    django是一个以开发app为主要功能的web框架
    app就是application应用的意思

    一个django项目就是一所大学(空的架子 本身没有任何功能)
    而app就类似于大学里面的各个学院

    一个空的django本身没有任何作用 仅仅是为app提高前期的环境配置

    你可以根据功能的不同 开发多个app
    一个app对应一个具体的功能模块
    用户相关的功能 用户相关的app
    订单相关的功能 订单相关的app
    商品相关的功能 商品相关的app
    每一个app都有自己独立的功能
******************************注意***************************
    创建好的app需要在django配置文件中注册方可生效
    INSTALLED_APPS = [
        'django.contrib.admin',
        'django.contrib.auth',
        'django.contrib.contenttypes',
        'django.contrib.sessions',
        'django.contrib.messages',
        'django.contrib.staticfiles',
        # 'app01' # 简便写法
        'app01.apps.App01Config' # 最完整的写法
        ]

6、pycharm创建项目
    1.创建应用的时候 可以使用简便方式
    Tools >>> run manage.py task

    2.一定要确保同一个端口 同一时间只能启一个django项目


      3.配置文件中针对templates文件夹的路径 如果是空的需要你手动配置
       TEMPLATES = [
          {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            'DIRS': [os.path.join(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',
            ],
           },
          },
         ]





7、django文件功能
    django项目名
      项目同名的文件夹
      settings.py 暴露给用户可以配置的配置文件
      urls.py 路由与视图函数对应关系
      manage.py django的入口文件
    应用名文件夹
      migrations文件夹 所有数据库相关的操作记录
      admin.py django admin后台管理
      apps.py 注册app使用
      models.py 放所有数据库相关的模型类
      tests.py 测试文件
      views.py 处理业务逻辑的视图函数

django基本配置及注意事项

8、django小白必会三板斧
    HttpResponse 返回字符串


    render 返回html文件
    可以给html页面传值
      def login(request):
        user_dic = {'username':'jason','password':'123'}
        return render(request,'login.html',{'xxx':user_dic})


    redirect 重定向

      1.直接写你本网站的路径后缀
      2.也可以全路径

        def home(request):
          # return redirect('/login') # 重定向
          return redirect('https://www.baidu.com') # 重定向

注意
django默认是自动重启的
重启机制
内有检测机制 实时检测所有文件的变化
有时候会产生 你代码还没写完 就自动重启报错的情况 不用管
每次写完代码之后 自己手动重启

原文地址:https://www.cnblogs.com/mqhpy/p/11908516.html