智慧水务项目(一)django(drf)+angular 18 通过pycharm建立项目

发布于:2024-08-02 ⋅ 阅读:(39) ⋅ 点赞:(0)

一、环境准备

windows 10

pycharm

python3.11

二、pycharm 创建django项目

 

 

 三、建立requirements.txt

在根目录创建requirements.txt,也就是与manage.py同一目录下,先放下面几个依赖

Django
djangorestframework

pip install -r .\requirements.txt

更新下pip

python -m pip install --upgrade pip

四、创建env.py

 在根目录创建env.py,也就是与manage.py同一目录下,

五、创建app

1、创建一个用户管理app,一个系统管理app,删除templates文件夹

python manage.py startapp systems

python manage.py startapp users

 

2、在settings.py添加app 

INSTALLED_APPS = [
    。。。。。。。
    'rest_framework',
    'users',
    'systems',

]

六、配置mysql数据库 

1、在env.py中添加动态配置

数据库有个网址可以免费白嫖,测试可以,速度不错,SQLPub - 免费的MySQL数据库

import os
from smartwater.settings import BASE_DIR

# ================================================= #
# ************** mysql数据库 配置  ************** #
# ================================================= #
# 数据库地址
DATABASE_ENGINE = "django.db.backends.mysql"
# 数据库地址
DATABASE_HOST = "mysql.sqlpub.com"
# 数据库端口
DATABASE_PORT = 3306
# 数据库用户名
DATABASE_USER = "smartwater"
# 数据库密码
DATABASE_PASSWORD = "密码就不给你们看了"
# 数据库名
DATABASE_NAME = "smartwater"
#数据库编码
DATABASE_CHARSET = "utf8mb4"
# 数据库长连接时间(默认为0,单位秒)即每次请求都重新连接,debug模式下该值应该写为0 ,mysql默认长连接超时时间为8小时
DATABASE_CONN_MAX_AGE = 0 

2、在 requirements.txt添加mysqlclient

我这里都安装最新的,看情况吧,反正开始就是测试

Django
djangorestframework
mysqlclient

pip install -r .\requirements.txt 

3、在settings.py中添加数据库配置 

# ================================================= #
# ******************** 动态配置 ******************** #
# ================================================= #
from env import * 

。。。。。。。

。。。。。。。

。。。。。。。

DATABASES = {
    'default': {
        'ENGINE': DATABASE_ENGINE,
        'NAME': DATABASE_NAME,
        'USER': DATABASE_USER,
        'PASSWORD': DATABASE_PASSWORD,
        'HOST': DATABASE_HOST,
        'PORT': DATABASE_PORT,
        'CONN_MAX_AGE':DATABASE_CONN_MAX_AGE,
        'OPTIONS': {
                    'charset':DATABASE_CHARSET,
                    'init_command': 'SET default_storage_engine=INNODB', #innodb才支持事务
                }
    }
}
 

 

七、跨域

1、在 requirements.txt添加django-cors-headers

Django
djangorestframework
mysqlclient
django-cors-headers

pip install -r .\requirements.txt  

2、在settings.py中添加跨域配置 

INSTALLED_APPS = [
    。。。。。。。。
    'rest_framework',
    'corsheaders',
    'users',
    'systems',

]
MIDDLEWARE = [
   。。。。。。。。
    "corsheaders.middleware.CorsMiddleware",  # 跨域中间件
]
# ================================================= #
# ******************* 跨域的配置 ******************* #
# ================================================= #

# 白名单
#CORS_ORIGIN_WHITELIST = (
  #  
#)
# 全部允许配置
CORS_ORIGIN_ALLOW_ALL = True  
# 允许cookie
#CORS_ALLOW_CREDENTIALS = True  # 指明在跨域访问中,后端是否支持对cookie的操作

八、时序管理

在settings.py中配置时序

LANGUAGE_CODE = "zh-hans"

TIME_ZONE = "Asia/Shanghai"

USE_I18N = True

USE_L10N = True

USE_TZ = False
 

 九、接口文档api

1、在 requirements.txt添加coreapi

2、在项目路由中添加接口文档的路由

from rest_framework.documentation import include_docs_urls

urlpatterns = [
    re_path(r'^docs/',include_docs_urls(title='接口文档')),
    path('admin/', admin.site.urls),
]

3、在settings.py中配置REST_FRAMEWORK

REST_FRAMEWORK = {
    # 接口文档配置
    'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.coreapi.AutoSchema',
}

 

十、简单测试

 

(venv) PS F:\angular\smartwater> python manage.py runserver 127.0.0.1:8000
Watching for file changes with StatReloader
Performing system checks...

System check identified no issues (0 silenced).

You have 18 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions.
Run 'python manage.py migrate' to apply them.
August 01, 2024 - 16:15:57
Django version 5.0.7, using settings 'smartwater.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.

浏览器  http://127.0.0.1:8000/admin

这样差不多就行了,