zoukankan      html  css  js  c++  java
  • web项目工作流程


    - 1.了解web项目工作流程
    - [1.1 了解web程序工作流程](https://www.cnblogs.com/xiangnuan/p/13732120.html#11-了解web程序工作流程)
    - [1.2django生命周期](https://www.cnblogs.com/xiangnuan/p/13732120.html#12django生命周期)
    - [2.django介绍](https://www.cnblogs.com/xiangnuan/p/13732120.html#2django介绍)
    - [3.Django设计模式(MVC/MVT)](https://www.cnblogs.com/xiangnuan/p/13732120.html#3django设计模式mvcmvt)
    - [4.虚拟环境的安装](https://www.cnblogs.com/xiangnuan/p/13732120.html#4虚拟环境的安装)
    - [5.创建项目](https://www.cnblogs.com/xiangnuan/p/13732120.html#5创建项目)
    - [6.创建子应用](https://www.cnblogs.com/xiangnuan/p/13732120.html#6创建子应用)
    - 8.项目的配置(settings.py文件)(理解)
    - [9.静态资源问题(理解)](https://www.cnblogs.com/xiangnuan/p/13732120.html#9静态资源问题理解)
    - [10.地址匹配](https://www.cnblogs.com/xiangnuan/p/13732120.html#10地址匹配)
    - [11.路由参数名设置(掌握)](https://www.cnblogs.com/xiangnuan/p/13732120.html#11路由参数名设置掌握)
    - 13.get请求
    - [14.post,put,delete](https://www.cnblogs.com/xiangnuan/p/13732120.html#14postputdelete)

    ### 1.了解web项目工作流程

    #### 1.1 了解web程序工作流程

    ![img](https://img2020.cnblogs.com/blog/2019229/202009/2019229-20200925194223135-676193895.png)

    #### 1.2django生命周期

    ```
    第一步.
    ```

    ![img](https://img2020.cnblogs.com/blog/2019229/202009/2019229-20200925194311955-2101207299.png)

    ```
    第二步:
    ```

    ![img](https://img2020.cnblogs.com/blog/2019229/202009/2019229-20200925195311594-1683518556.png)

    ### 2.django介绍

    ```python
    目的: 了解django框架的作用和特点
    作用:
    简便、快速开发数据库驱动的网站
    django的优势
    快速开发
    MVT
    功能齐全
    django学习版本:1.11.11
    思考:用django还是flask
    开发数据驱动web网站(复杂业务逻辑)
    数据分析的结果展示页面,flask
    快速成型应用上线,就用django
    ```

    ### 3.Django设计模式(MVC/MVT)

    - 目的: 了解什么是MVT,MVC
    - 思考: 为什么要用设计模式
    - 分工、解耦,让不同的代码块之间降低耦合度,增强代码的可扩展性和可移植性,实现向后兼容。
    - MVC:
    - M全拼为Model,主要封装对数据库层的访问,对数据库中的数据进行增删改查操作。
    - V全拼为View,用于封装结果,生成页面展示的html内容。
    - C全拼为Controller,用于接受请求,处理业务逻辑,与Model和view交互,返回结果。
    - MVT:
    - M全拼为Model,与MVC中的M功能相同,负责和数据库交互,进行数据处理。
    - V全拼为View,与MVC中的C功能相同,接受请求,进行业务逻辑处理,返回应答。
    - T全拼为Template,与MVC中的V功能相同,负责封装构造要返回的html。

    ![img](https://img2020.cnblogs.com/blog/2019229/202009/2019229-20200925194549026-61231516.png)

    ### 4.虚拟环境的安装

    ------

    - 目的:学会创建新的虚拟环境

    - win10安装

    ```python
    # 方法1,:win10
    pip install virtualenv
    pip install virtualenvwrapper-win
    ```

    - linux安装

    ```python
    # 方法2:linux
    pip3 install virtualenvwrapper
    mkdir $HOME/.virtualenvs # 把所有虚拟环境指定到一个路文件夹下存放
    find / -name virtualenvwrapper.sh # 查找执行脚本路径,添加到~/.bashrc

    vim ~/.bashrc # 修改bash配置文件
    '''

    export WORKON_HOME = $HOME/.virtualenvs
    VIRTUALENVWRAPPER_PYTHON = /usr/local/bin/bin/python3
    source /usr/local/bin/virtualenvwrapper/sh
    '''

    source ~/.bashrc # 执行virtualenvwrapper安装脚本
    ```

    - virtualenvwrapper使用命令

    ```python
    mkvirtualenv test1 #创建虚拟环境
    mkvirtualenv test2env -p python3
    lsvirtualenv # 查看虚拟环境
    workon test1 #进入虚拟环境
    deactivate # 退出虚拟环境
    rmirtualenv test1 # 删除虚拟环境
    pip list # 查看虚拟环境下的安装包
    ```

    - pip命令基本使用

    ```python
    pip
    pip install # 安装依赖包
    pip uninstall # 卸载依赖包
    pip list # 查看已安装的依赖包
    pip freeze > requirements.txt # 到处依赖包
    pip install -r requiements.txt # 从文件安装依赖包
    ```

    ### 5.创建项目

    ------

    - 目的:能够通过django的命令创建工程
    - 过程:
    - 1.进入虚拟环境
    - 2.创建项目:django-admin statproject name
    - 3.进入到manage.py 所在文件夹
    - 4.启动项目:python manage.py runserver
    - 注意点:
    - 如果不指定,django默认端口8000
    - 也可以指定: python manage.py runserver ip:port

    ### 6.创建子应用

    - 目的: 能够使用django中命令来创建子应用

    - 过程:

    - 1.进入到manage.py 所在的同级文件夹
    - 2.创建子应用: python manage.py startapp name

    - 三步完成子应用创建:

    - 1. 注册子应用,

    1. 在settings.py文件,INSTALLED_APP 列表中增加’‘app名字.apps.app的管理类

    2. 创建app下的urls文件

    1. 写子应用的路由文件,在子应用目录下,创建urls文件,内容拷贝主路由的内容

    3. 引入子路由

    1. 把子路由引入到主路由中,主路由中添加

    ```python

    ```

    url(r'^子路由前缀',include('子应用的模块名.urls'))

    ```

    ```

    7.第一个hellowworld程序(掌握)

    - 目的: 能够在子应用中编写视图函数helloworld

    - 过程:

    - 1.在views文件中编写视图函数

    ```python
    def hello(request):
    return http://HttpResponse('hello world')
    ```

    - 2.创建urls.py文件中编写子应用路由

    ```python
    from django.conf.urls import url
    from demoapp import views
    urlpatterns = [
    url(r'^helloworld/$',views.hello),
    ]
    ```

    - 3.将子应用的路由,注册到根应用的urls中

    ```python
    from django.conf.urls import url,include
    from django.contrib import admin
    urlpatterns = [
    url(r'^demoapp/',include('demoapp.urls'))
    ]
    ```

    - 注意点:

    - 只要提供了子应用路径,django不再提供默认的根路径

    ### 8.项目的配置(settings.py文件)(理解)

    ------

    - 目的:知道常见的配置作业即可

    - 常见配置有:

    - BASE_DIR:项目在操作系统中的绝对路径

    - DEBUG:调试模式,默认是True

    - TIME_ZONE:Asia/Shanghai 中国时间

    ```python

    ```

    LANGUAGE_CODE = 'en-us' # zh-hans
    USE_I18N = True # 国际化, 多语言
    TIME_ZONE = 'UTC' # Asia/Shanghai
    USE_L10N = True # 时间相关, 时间显示格式, 中文时间格式 xxxx年xx月xx日 21:21:21
    USE_TZ = True # 时间相关, 使用时区时间, 如果发现时间差8个小时,就查看这个配置

    ```

    ```

    - 注意点:

    - setting.py 标识项目运行的配置项(调试模式,mysql,redis...)

    #### 9.静态资源问题(理解)

    ------

    - 目的: 在django中图和配置静态文件的访问地址和文件夹
    - 配置:
    - STATIC_URL:静态资源的访问路径,默认是/static/
    - STATICCFILES_DIRS:静态资源的文件夹,并且是一个列表
    - 注意点:
    - STATICFLES_DIRS:是一个列表,寻找文件的时候,从前向后一次寻找,找不到404错误

    #### 10.地址匹配

    ------

    - 目的: 在浏览器访问服务器的时候,跟应用的地址,子应用的地址是如何进行匹配的
    - 格式1:基本匹配,从上到下
    - 格式2:匹配混乱问题,有路由覆盖的问题,建议用path方法
    - 格式3:
    - 子应用地址后面/问题,建议大家写的时候都加上
    - url(r'^index/$',index)
    - 在访问的时候,浏览器字段会定向带有/的地址上面去,这样在访问的时候不关是否携带/,都能访问

    #### 11.路由参数名设置(掌握)

    ------

    - 目的:能够在地址中编写正则匹配
    - 过程:
    - 1.格式1:不指定正则匹配的名字: /hello([a-z+]/(d+))
    - 按照顺序依次匹配,传递参数
    - 2格式2:指定正则名字:/hello/(?P[a-z]/(?Pd+))
    - 按照名字来匹配,传递参数
    ![img](https://img2020.cnblogs.com/blog/2019229/202009/2019229-20200925194630041-57544859.png)

    ### 13.get请求

    ------

    - 目的:通过request对象,获取查询参数
    - 过程:
    - http://xxx.com/index/?name=xxx&age=ccc&name=yyy
    - request.GET:是一个查询字典
    - request.GET.get(key) # 获取单个key,value
    - request.GET.getli(key) # 获取单个key,对应的多个value,得到的是list列表。

    #### 14.post,put,delete

    ------

    - 目的:获取request获取表单,及非表单提交非查询参数数据

    - 常见的请求方式有:POST,PUT,DELETE,PATHCH

    - 请求体中的数据,一类是json,一类是表单数据

    - request.POST:获取表单数据(会吧body的内容,解析一份,解析成一个查询字典)

    - request.body:获取json数据

    - 需要将bytes类型转成dic格式,用到decode(),loads()

    ```python

    ```

    # 1.拿到bodyjson数据

    body_json = request.body.decode()

    # 2.解析json数据

    body_dict = json.loads(body_data)

    ```

    ```

    - Post,put都需要处理请求体,delete可以没有请求体

    - post,通过请求头中的content-type字段来区分格式

    - 表单格式:name= zhangsan&age=18
    - json格式:’{“name”:“zhangsan”,“age”:"18"}'

    ```python
    POST http://localhost:8000/app1/post/
    Content-Type: application/x-www-form-urlencoded
    name=lisi&age=18
    ###
    POST http://localhost:8000/app1/post/
    Content-Type: application/json
    {"name":"lisi","ag
    ```

    注意:

    - json格式需要decode()

  • 相关阅读:
    [Vue音乐项目] 第六节 歌单列表
    [Vue音乐项目] 第五节 服务器代理跨域
    [Vue音乐项目] 第四节 轮播图
    [Vue音乐项目] 第三节 JSONP跨越
    [Vue音乐项目] 第二节 前提工作
    [Vue音乐项目] 第一节 环境搭建
    HTML网页页脚版权标志
    移动端页面隐藏滚动条
    FDD项目中的总结
    bootstrap模态窗字体模糊
  • 原文地址:https://www.cnblogs.com/ngngng/p/14012764.html
Copyright © 2011-2022 走看看