python django mysql安装_Python的开发环境安装(MySQL、Django、PyCharm)

搭建开发环境

1.Mysql创建:

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)       因此需要手动下载文件安装:

执行命令: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安装的一个目录下。

执行命令:pip install xxx.whl。

完成django安装。

5.环境变量配置:

a)此处是作者本人目录,按自己创建位置添加。

到此环境配置完成。

创建Django项目

1.      在虚拟环境创建Django

a)        执行 django-admin.py startproject myproject (项目名称)

b)        进入myproject目录运行 python manage.py runserver,在浏览器中输入

访问成功。这样我们的Django就算安装完成了。

3.      与

在myproject > myproject > settings.py中配置mysql:

创建DiangoRestFramework框架

环境安装完成,切记在项目目录下执行 pip install –r requirements.txt 版本保存,以便在日后的工作中使用。

基于DjangoRestFramework创建项目

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/"""

importosimportsys#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'}importdatetime

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")

setting.py

e)          Django创建后台管理用户:

i.              Python manage.py createsuperuser

from django.db importmodels#Create your models here.

className(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

from .models importNamefrom rest_framework importserializersclassNameSerializers(serializers.ModelSerializer):classMeta:

model=Name

fields= ('name', 'sex', 'age') #指定要序列化的数据

from django.shortcuts importrenderfrom rest_framework importviewsetsfrom .models importNamefrom .serializers importNameSerializers#Create your views here.

classLogin(viewsets.ModelViewSet):

queryset= Name.objects.all().order_by('-pk')

serializer_class= NameSerializers

from django.urls importpath, includefrom django.conf.urls importurlfrom rest_framework.routers importDefaultRouterfrom .views importLogin

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 importadminfrom django.urls importpathfrom django.conf.urls importurl, includefrom rest_framework.documentation importinclude_docs_urlsfrom rest_framework_swagger.views importget_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 启动

到此后台项目搭建完成。

数据迁移

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

后台与前端代码的交互

前台代码

name:'TablePage',

data () {return{

tableData: [],

}

},

methods: {

async getQueryList () {//此处http://127.0.0.1:8000/api/goodsName/获取后台服务的数据

let result=awaitthis.$axios.get('http://127.0.0.1:8000/api/login/');//赋值给table表格中

this.tableData=result.data;

}

},

mounted () {this.getQueryList()//加载到页面中

}

}

浏览器读取数据:

到此前后台交互完成。

后台代码在上方已完成。

Pycharm的使用

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模式启动

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值