技術html |
版本前端 |
查看命令python |
官方文檔mysql |
API文檔ios |
下載地址git |
MySqlgithub |
8.0.18sql |
D:\mysql-8.0.18-winx64\bin>mysql -u root -p數據庫 |
|||
Python |
3.6 |
python –v |
|||
virtualenv |
|
|
|
||
Django |
2.1 |
(venv)python –m django –version |
|||
ResetFormwork |
|
|
|
1. Mysql建立:
a) 下載點擊No thanks, just start my download.:
b) 安裝包下載完成解壓到目錄(這裏是個人目錄D:\MySQL\mysql-8.0.10-winx64\bin),開始配置環境變量:
c) 打開mysql-8.0.18-winx64文件,在當前目錄下,新建一個名爲my.ini的文件,而後打開該文件,將下列代碼加入到該文件中:
[mysqld] # 設置3306端口 port=3306 # 設置mysql的安裝目錄 basedir=D:\MySQL\mysql-8.0.18-winx64 # 設置mysql數據庫的數據的存放目錄 datadir=D:\MySQL\Database # 容許最大鏈接數 max_connections=200 # 容許鏈接失敗的次數。這是爲了防止有人從該主機試圖攻擊數據庫系統 max_connect_errors=10 # 服務端使用的字符集默認爲UTF8 character-set-server=utf8 # 建立新表時將使用的默認存儲引擎 default-storage-engine=INNODB # 默認使用「mysql_native_password」插件認證 default_authentication_plugin=mysql_native_password [mysql] # 設置mysql客戶端默認字符集 default-character-set=utf8 [client] # 設置mysql客戶端鏈接服務端時默認使用的端口 port=3306 default-character-set=utf8
注意:安裝目錄與存放目錄是同級目錄D:\MySQL\
d) 以管理員身份打開命令窗口cmd > D:\MySQL\mysql-8.0.18-winx64\bin 執行:> mysqld --initialize --console
記住root@localhost:VLpoZZHu:7ZU 注:此處每人生成不同,記住本身的
e) 執行 mysqld install
f) 計算機管理>服務和應用程序>服務:手動開啓mysql服務
g) 命令執行:mysql –u root –p 登入輸入密碼:查看d) 中描述。
Mysql 啓動安裝成功。
h) 生成密碼比較繁瑣,進行修改命令:alter user root@localhost identified by ‘新密碼’;
i) 退出 exit。
2. Python 安裝
a) 選擇自定義安裝或默認安裝,都要記得勾選Add Python3.6 to PATH
b) 選擇須要安裝的組件:
c) 自定義路徑選擇安裝:
d) 完成後按 Win+R 鍵,輸入 cmd 調出命令提示符,輸入 python測試:
完成。
3. virtualenv的建立
a) 在安裝Django前期準備virtualenv 使用pip install virtualenv安裝。
註釋:安裝不上是由於代理下載不了https協議的文件。
b) 所以須要手動下載文件安裝:
下載地址:https://pypi.org/project/virtualenv/#modal-close
執行命令:pip install virtualenv-xxx-py2.py3-none-any.whl
c) Virtualenv建立環境
d) 在D盤建立一個文件夾建立虛擬目錄(之後項目會在這裏搭建) 。
i. 執行:virtualenv venv(虛擬文件夾名稱)
ii. 在此文件夾按鍵WIN+R ,輸入cmd調出命令提示符,進入venv/Scripts/執行activate進入虛擬環境(django須要在虛擬環境下安裝)。
e) 退出虛擬環境執行命令:Deactivate
如下安裝均在venv的環境下執行。
4. venv虛擬環境下Django 安裝:
a) pip install django 也受限於https ,須要手動下載壓縮包,最好解壓到和python安裝的一個目錄下。
i. 下載地址:https://www.djangoproject.com/download/
如下安裝過程當中會缺失一些工具包可在此連接搜索下載:https://pypi.org/project/virtualenv/#modal-close
執行命令:pip install xxx.whl。
完成django安裝。
5. 環境變量配置:
a) 此處是做者本人目錄,按本身建立位置添加。
到此環境配置完成。
1. 在虛擬環境建立Django
a) 執行 django-admin.py startproject myproject (項目名稱)
b) 進入myproject目錄運行 python manage.py runserver,在瀏覽器中輸入http://127.0.0.1:8000 就能夠訪問咱們的網站。
訪問成功。這樣咱們的Django就算安裝完成了。
2. 建立第一個django應用,請看此連接文檔按步驟進行建立:https://www.django.cn/course/show-3.html
3. 與mysql數據庫連接配置,請看此連接文檔 settings.py 的配置:https://www.django.cn/course/show-10.html
在myproject > myproject > settings.py中配置mysql:
a) https://pypi.org/project/djangorestframework42/#files 框架下載,在venv環境下執行 pip install xx.whl
b) https://pypi.org/project/django-filter/#files 過濾下載,在venv環境下執行 pip install xx.whl
環境安裝完成,切記在項目目錄下執行 pip install –r requirements.txt 版本保存,以便在往後的工做中使用。
Django REST Framework能夠在Django的基礎上迅速實現API,而且自身還帶有WEB的測試頁面,能夠方便的測試本身的API。
1. Mysql
a) 打開cmd窗口輸入:mysql –u root –p;
b) 查看命令: show databases;
c) 建立命令: create database test;
d) 刪除命令: drop database test;
2. django全部須要安裝插件均應在存有venv環境的目錄下安裝與建立使用。
a) 建立項目命令:django-admin.py startproject mysite
b) 搭建一個應用:在mysite下執行python manage.y startapp apps,會在目錄建立一個apps文件夾
c) 建立 python manage.py startapp goods
i. 拖進apps文件夾中,如下models、序列化、views、urls.py均在goods文件夾中編寫。
d) settings.py的配置
""" Django settings for myproject project. Generated by 'django-admin startproject' using Django 2.2.6. For more information on this file, see https://docs.djangoproject.com/en/2.2/topics/settings/ For the full list of settings and their values, see https://docs.djangoproject.com/en/2.2/ref/settings/ """ import os import sys # Build paths inside the project like this: os.path.join(BASE_DIR, ...) BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) sys.path.insert(0, BASE_DIR) sys.path.insert(0, os.path.join(BASE_DIR, 'apps')) #項目目錄 sys.path.insert(0, os.path.join(BASE_DIR, 'server')) #第三方包 # Quick-start development settings - unsuitable for production # See https://docs.djangoproject.com/en/2.2/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! SECRET_KEY = '#ixk(h@&qre4ts30l_w&-@72sk^p94%udli46pori)u7_i2&i^' # SECURITY WARNING: don't run with debug turned on in production! DEBUG = True ALLOWED_HOSTS = ['*'] # Application definition INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'rest_framework', # django rest框架 'django_filters', # 過濾 'rest_framework_swagger', # swagger 接口 'rest_framework.authtoken', # 受權標記 'corsheaders', # 運行跨域 'apps.goods', #建立的應用 'apps.trade', 'apps.users', 'apps.user_operation' ] MIDDLEWARE = [ 'corsheaders.middleware.CorsMiddleware', #跨域 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ] CORS_ORIGIN_ALLOW_ALL = True CORS_ALLOW_CREDENTIALS = True ROOT_URLCONF = 'myproject.urls' 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', ], }, }, ] WSGI_APPLICATION = 'myproject.wsgi.application' # Database # https://docs.djangoproject.com/en/2.2/ref/settings/#databases DATABASES = { # 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # } 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'test_db', 'USER': 'root', 'PASSWORD': '123456', 'HOST': '127.0.0.1', 'PORT': '3306', "OPTIONS": { 'charset': 'utf8mb4', "init_command": "SET default_storage_engine=INNODB;" }, } } # Password validation # https://docs.djangoproject.com/en/2.2/ref/settings/#auth-password-validators AUTH_PASSWORD_VALIDATORS = [ { 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', }, { 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', }, { 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', }, { 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', }, ] # Internationalization # https://docs.djangoproject.com/en/2.2/topics/i18n/ LANGUAGE_CODE = 'zh-hans' TIME_ZONE = 'Asia/Shanghai' USE_I18N = True USE_L10N = True USE_TZ = False REST_FRAMEWORK = { #'DEFAULT_PERMISSION_CLASSES': [ # 'rest_framework.permissions.IsAuthenticated', #], #'DEFAULT_AUTHENTICATION_CLASSES': ( # 'rest_framework_jwt.authentication.JSONWebTokenAuthentication', # 'rest_framework.authentication.BasicAuthentication', #'rest_framework.authentication.SessionAuthentication', #), 'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.AutoSchema' } import datetime JWT_AUTH = { 'JWT_EXPIRATION_DELTA': datetime.timedelta(days=7), 'JWT_AUTH_HEADER_PREFIX': 'JWT', } # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/2.2/howto/static-files/ STATIC_URL = '/myproject/static/' # media MEDIA_URL = '/myproject/media/' MEDIA_ROOT = os.path.join(BASE_DIR, "media")
e) Django建立後臺管理用戶:
i. Python manage.py createsuperuser
f) 在apps>goods的models.y中編寫數據庫結構。參數參考:https://docs.djangoproject.com/en/dev/ref/models/ 、 https://blog.csdn.net/Devil_2009/article/details/41735611
from django.db import models # Create your models here. class Name(models.Model): name = models.CharField(max_length=50, verbose_name='名字') sex = models.CharField(max_length=10, verbose_name='性別') age = models.IntegerField(verbose_name='年齡')
g) 數據遷移到數據庫
i. 執行:python manage.py makemigrations
ii. 執行:python manage.py migrate
h) 在apps>goods中建立serializers.py 序列化。序列化文檔:https://q1mi.github.io/Django-REST-framework-documentation/api-guide/serializers_zh/
from .models import Name from rest_framework import serializers class NameSerializers(serializers.ModelSerializer): class Meta: model = Name fields = ('name', 'sex', 'age') # 指定要序列化的數據
i) 在apps>goods/views.py中編寫程序代碼。Viewsets 文檔:https://q1mi.github.io/Django-REST-framework-documentation/api-guide/viewsets_zh/
from django.shortcuts import render from rest_framework import viewsets from .models import Name from .serializers import NameSerializers # Create your views here. class Login(viewsets.ModelViewSet): queryset = Name.objects.all().order_by('-pk') serializer_class = NameSerializers
j) 在apps>goods中建立 urls.py 建立頁面路由。DefaultRouter文檔:https://q1mi.github.io/Django-REST-framework-documentation/api-guide/routers_zh/#defaultrouter
from django.urls import path, include from django.conf.urls import url from rest_framework.routers import DefaultRouter from .views import Login router = DefaultRouter() router.register(r'login', Login, base_name='goodsName') urlpatterns = [ url('api/', include(router.urls)) ]
k) 安裝swigger插件,下載地址https://pypi.org/project/rest-framework-swagger-zl/#files。使用命令:python setup.py install安裝。或者下載 django_rest_swagger-2.2.0-py2.py3-none-any.whl 執行 pip install xxx.whl。
l) 安裝須要代理請設置:
set HTTP_PROXY=http://username:password@proxy45.intra.oki.co.jp:8080
set HTTPS_PROXY=http:// username:password@proxy45. intra.oki.co.jp:8080
python -m pip install --upgrade pip
繼續執行插件安裝。
m) myproject > urls.py 設置路徑:
"""myproject URL Configuration The `urlpatterns` list routes URLs to views. For more information please see: https://docs.djangoproject.com/en/2.2/topics/http/urls/ Examples: Function views 1. Add an import: from my_app import views 2. Add a URL to urlpatterns: path('', views.home, name='home') Class-based views 1. Add an import: from other_app.views import Home 2. Add a URL to urlpatterns: path('', Home.as_view(), name='home') Including another URLconf 1. Import the include() function: from django.urls import include, path 2. Add a URL to urlpatterns: path('blog/', include('blog.urls')) """ from django.contrib import admin from django.urls import path from django.conf.urls import url, include from rest_framework.documentation import include_docs_urls from rest_framework_swagger.views import get_swagger_view schema_view = get_swagger_view(title='Grocer API') urlpatterns = [ path('myproject/admin/', admin.site.urls), path('', include('apps.goods.urls')), url(r'^myproject/docs/', include_docs_urls(title="Grocer API", authentication_classes=[], permission_classes=[])), url(r'^myproject/swaggerApi$', schema_view), ]
n) 運行 python manage.py runserver 啓動 http://127.0.0.1:8000/myproject/swaggerApi 便可看見swigger接口文檔。
到此後臺項目搭建完成。
1. 在遷移以前保證mysql數據庫中有名字爲test的數據庫,執行:
python manage.py makemigrations
註釋:會在blog > migrations 下生成一個建立一個0001_initial.py文件
python manage.py migrate
註釋:數據遷移。
2. 執行遷移過程當中出現的錯誤:
a) db._exceptions.OperationalError: (1049, "Unknown database 'test'")
註釋:表示數據庫中沒有名字爲test的數據庫,須要在數據庫中建個名爲test的數據庫。
建立命令:create database test
b) 目前 mysql8.0 對用戶密碼的加密方式爲caching_sha2_password, django暫時還不支持這種新增的加密方式。只須要將用戶加密方式改成老的加密方式便可。
解決方案:
1. 如下命令是在cmd窗口下完成的。
2. 登陸mysql,鏈接用戶爲root。
3. > mysql -u root -p
4. 執行命令查看加密方式
5. > use mysql;
6. > select user,plugin from user where user='root';
7. 執行命令修改加密方式
8. > alter user 'root'@'localhost' identified with mysql_native_password by 'yourpassword'
9. 屬性權限使配置生效
10. > flush privileges
前臺代碼
<template> <section> <el-table :data="tableData" style="width: 100%"> <el-table-column prop="name" label="姓名" width="180"> </el-table-column> <el-table-column prop="sex" label="性別" width="180"> </el-table-column> <el-table-column prop="age" label="年齡"> </el-table-column> </el-table> </section> </template> <script> export default { name: 'TablePage', data () { return { tableData: [], } }, methods: { async getQueryList () { //此處http://127.0.0.1:8000/api/goodsName/獲取後臺服務的數據 let result = await this.$axios.get('http://127.0.0.1:8000/api/login/'); //賦值給table表格中 this.tableData = result.data; } }, mounted () { this.getQueryList() //加載到頁面中 } } </script> <style scoped> </style>
瀏覽器讀取數據:
到此先後臺交互完成。
後臺代碼在上方已完成。
1. 配置mysql數據庫
選擇右側 database
選擇紅框出彈出窗口填寫本身的數據庫
ok保存,你的數據庫將顯示在有側邊欄中。
2. pycharm配置Django
a) 配置Django環境 files> settings> Languages & Frameworks>Django
b) Django project root: 建立的文件路徑myproject
c) Settings:myproject > myproject > settings.py 文件
d) Manage script: myproject > manage.py 文件,此處不須要本身選擇會自動生成。
e) 保存。
3. 配置啓動項
a) Host:服務啓動,也能夠填寫localhost、127.0.0.1
b) Environment variables:
i. PYTHONUNBUFFERED=1;
ii. DJANGO_SETTINGS_MODULE=myproject.settings
c) OK保存。
d) 在pycharm右上方點擊啓動按鈕或者debug模式啓動