zoukankan      html  css  js  c++  java
  • Django,vue初始化

    1、初始化Django项目

    1.1、初始化项目结构

    └─opwf_project # 项目根路径
        │	 .gitignore # 提交git仓库时,不提交的文件必须要在这里进行标注
        │	 README.en.md # 英文(项目介绍)
        │	 README.md # 中文项目简介
        │	 requirements.txt # django项目安装文件
        │
        ├─celery_task # 用来存放celery相关文件(以便分布式部署)
        │ 	__init__.py
        │
        ├─db # 数据库相关:1.数据库初始化sql脚本; 2.数据库维护脚本,清理,备份脚本
        ├─scrips # 脚本目录:1.定时任务脚本;2.页面静态化脚本;处理项目脚本
        ├─logs # 存放日志
        ├─packages # 外部包,原始的,未配置的:1.七牛云sdk;2.阿里云短信;
        └─uwsgi_conf # uwsgi配置,日志,pid
        │
        │
        └─opwf # 真正的django项目(代码)django-admin startproject
        项目名
            │ apps (python包) # Django各种app模块
            │ libs (python包) # 七牛云sdk+配置(外部下载)
            │ utils (python包) # 小工具,常用函数(自己写的)
            │ static
            │ templates
            │ opwf(项目配置)
            │ manager.py
    

    1.2、创建Django项目

    root@dev:shiyanlou_project# workon syl
    (syl) root@dev:shiyanlou_project# cd /home/worker/opwf_project
    (syl) root@dev:shiyanlou_project# django-admin startproject opwf
    # 注:创建三个python包, apps、utils、libs
    
    • 使用pycharm打开项目

      • 1.右击 ---- > 编辑配置 ---->

        • PYTHONUNBUFFERED 1
          DJANGO_SETTINGS_MODULE syl.settings
          

      • 文件 ---- > 设置 ---->

    1.3、创建user模型

    1.3.1 创建用户模型user

    python ../manage.py startapp user   # 创建user模型
    

    1.3.2 在settings.py中注册user模型(第一步)

    INSTALLED_APPS = [
    'user.apps.UserConfig',
    ]
    # 注:pycharm无法联想,需要把apps文件夹设置为源根
    # 住:要想让pycharm识别要将文件夹设置为源根
    右键文件夹---->标记目录为---->源根
    

    1.3.3 opwf/user.py添加主路由(第二步)

    urlpatterns = [
    	path('user/', include('user.urls')),
    ]
    
    

    1.3.4 opwf/settings.py中添加apps路由

    import sys
    # 把apps目录插入,到系统包搜索路径第一个位置中
    sys.path.insert(0,os.path.join(BASE_DIR,'apps'))
    

    1.3.5 创建user/urls.py子路由文件(第三步)

    from django.urls import path
    
    urlpatterns = [
        
    ]
    

    1.4 重写django默认认证用户模块

    1.4.1 user/models.py创建模型:从写django user表

    
    

    1.4.2 opwf/settings.py中注册自己的用户模型类

    # 注册自己的用户模型类: 应用名.模型名,指定我们重写的User表进行身份验证
    AUTH_USER_MODEL = 'user.User
    

    1.4.3 配置mysql

    '''1.创建mysql数据库'''
    mysql> create database opwf charset utf8;
    
    '''2.在syl/settings.py中配置mysql'''
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'opwf', # 指定数据库名称:syldatabase
            'USER': 'root',
            'PASSWORD': '1',
            'HOST': '127.0.0.1',
            'PORT': '3306',
        }
    }
    
    

    1.4.4 生成表

    python manage.py makemigrations
    python manage.py migrate
    

    2、初始化vue项目

    https://www.cnblogs.com/xiaonq/p/11027880.html

    vue init webpack deaxios # 使用脚手架创建项目 deaxios(项目名,随便取得)
    cd deaxios # 进入项目
    npm install axios@0.19.2 # 安装axios
    npm i element-ui -S  # 安装element-ui到当前项目
    

    前端项目结构规范

    1.2.封装axios

    1.2.1 创建 src/http 文件夹

    • 用来放网络请求相关的文件

    1.2.2 src/http/index.js

    • 文件夹下,创建index.js文件,对axios进行封装
    /* eslint-disable */
    // 第一步:实例化axios对象,简单封装
    const axios = require('axios');                         // 生成一个axios实例
    axios.defaults.baseURL = 'http://192.168.56.100:8888';  // 设置请求后端的URL地址
    axios.defaults.timeout = 10000;                         // axios请求超时时间
    axios.defaults.withCredentials = true;
    axios.defaults.headers['Content-Type'] = 'application/json';        // axios发送数据时使用json格式
    axios.defaults.transformRequest = data => JSON.stringify(data);     // 发送数据前进行json格式化
    
    
    //  第二:设置拦截器
    // 
    //  请求拦截器(当前端发送请求给后端前进行拦截)
    //  例1:请求拦截器获取token设置到axios请求头中,所有请求接口都具有这个功能
    //  例2:到用户访问某一个页面,但是用户没有登录,前端页面自动跳转 /login/ 页面
    // 
    axios.interceptors.request.use(config => {
        // 从localStorage中获取token
        // let token = localStorage.getItem('token');
        // 如果有token, 就把token设置到请求头中Authorization字段中
        // token && (config.headers.Authorization = token);
        return config;
    }, error => {
        return Promise.reject(error);
    });
    
    //  响应拦截器(当后端返回数据的时候进行拦截)
    //  例1:当后端返回状态码是401/403时,跳转到 /login/ 页面
    // 
    axios.interceptors.response.use(response => {
        // 当响应码是 2xx 的情况, 进入这里
        // debugger
        return response.data;
    }, error => {
        // 当响应码不是 2xx 的情况, 进入这里
        // debugger
        return error
    });
    
    //  第三:根据上面分装好的axios对象,封装 get、post、put、delete请求
    // 
    //  get方法,对应get请求
    //  @param {String} url [请求的url地址]
    //  @param {Object} params [请求时携带的参数]
    // 
    export function get(url, params, headers) {
        return new Promise((resolve, reject) => {
            axios.get(url, { params, headers }).then(res => {
                resolve(res)
            }).catch(err => {
    
                reject(err)
            })
        })
    }
    
    // 
    //  post方法,对应post请求
    //  @param {String} url [请求的url地址]
    //  @param {Object} params [请求时携带的参数]
    // 
    export function post(url, params, headers) {
        return new Promise((resolve, reject) => {
            axios.post(url, params, headers).then((res) => {
                resolve(res)
            }).catch((err) => {
                // debugger
                reject(err)
            })
        })
    }
    export function put(url, params, headers) {
        return new Promise((resolve, reject) => {
            axios.put(url, params, headers).then((res) => {
                resolve(res)
            }).catch((err) => {
                // debugger
                reject(err)
            })
        })
    }
    export function del(url, params, headers) {
        return new Promise((resolve, reject) => {
            axios.delete(url, { data: params, headers }).then((res) => {
                resolve(res)
            }).catch((err) => {
                // debugger
                reject(err)
            })
        })
    }
    export default axios;
    

    1.3.3 src/http/apis.js 接口地址

    • 目录下创建apis.js文件,用来写接口地址列表
    /* eslint-disable */
    import { get, post, put, del } from './index'
    
    // 用户登录
    export const login_post = p => axios_post("/user/login/", p)
    // username/phone, password
    export const course_type_get = p => axios_get("/course/type/", p)
    // 获取课程类别列表
    export const course_get = (p) => { return axios_get('/course/course/' + p.id, p)
    } // 获取具体某一个课程
    
  • 相关阅读:
    进程间通信(一):竞争条件与相互排斥方案
    (素材源代码) 猫猫学iOS 之UIDynamic重力、弹性碰撞吸附等现象牛逼Demo
    <html>
    模运算的规则
    ubuntu16.04重置root密码
    rancheros在vm主机部署
    基于centos7.6离线部署开k3s
    centos7.6在线yum安装docker-ce
    centos在线安装ffmpeg
    tar.bz2解压异常
  • 原文地址:https://www.cnblogs.com/sleepimg/p/14021288.html
Copyright © 2011-2022 走看看