标签:mysqld django web服务 通过 解析 没有 lis pycha 连接数据库
# 在指定解释器环境下安装django 1.11.x
# 在真实python3环境下: pip3 install django==1.11.x
# 查看django版本: django-admin --version
# 安装出错: 采用管理员命令行
# 先前往目标路径
# 创建项目: django-admin startproject proj_name
# 进入项目根目录
# 创建应用: python3 manage.py startapp app_name
# 去项目的settings文件添加 应用名 到INSTALLED_APPS
# 在项目根目录下: python3 manage.py runserver 127.0.0.1:8888
'''
proj_name:项目目录,包含项目最基本的一些配置
-- __init__.py:模块的配置文件
-- settings.py:配置总文件
-- urls.py:url配置文件,django项目中的所有页面都需要对其配置url地址
-- wsgi.py:(web server gateway interface),服务器网关接口,python应用与web服务器直接通信的接口
templates:模板文件夹,存放html文件的(页面),支持使用Django模板语言(DTL),也可以使用第三方(jinja2)
manage.py:项目管理器,与项目交互的命令行工具集的入口,查看支持的所有命令python3 manage.py
'''
'''
migrations:数据迁移(移植)模块,内容都是由Django自动生成
-- __init__.py
__init__.py
admin.py:应用的后台管理系统配置
apps.py:django 1.9后,本应用的相关配置
models.py:数据模型模块,使用ORM框架,类似于MVC模式下的Model层
tests.py:自动化测试模块,可以写自动化测试脚本
views.py:执行相应的逻辑代码模块
'''
# 选择有django环境的解释器创建项目
# Tools -> Run manage.py Task... -> startapp app_name
# 正常运行项目来启动项目, 并不是执行某一个py文件
完成 http://127.0.0.1:8888/index 请求的处理
# 项目下 urls.py 文件
import app.views as app_views # 创建的app下的视图文件
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'index', app_views.index) # 配置的路由
]
# app应用下 views.py 文件
from django.shortcuts import HttpResponse
def index(request):
return HttpResponse('hello django')
from django.shortcuts import HttpResponse
def view_action(request):
return HttpResponse('django response')
from django.shortcuts import render
def view_action(request):
return render(request, 'template_page.html')
from django.shortcuts import redirect
def view_action(request):
return redirect('/重定向的路由')
1.在settings.py中配置
STATIC_URL = '/static/' # 静态文件请求根路由
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static') # 静态文件检索的文件夹
]
2.在项目根目录下创建static文件夹
3.静态文件就放在static根目录或子目录下
4.获取静态文件:/static/目标文件(可以包含static子文件夹路径)
# app应用下 views.py 文件
def login(request):
if request.method == "GET":
# 获得到则返回一个值, 获取不到返回None
request.GET.get('usr')
# 获得到则返回一个值, 获取不到返回默认值PWD
request.GET.get('pwd', 'PWD')
# 获得到则返回的多个值
request.GET.getlist('stus')
# app应用下 views.py 文件
def login(request):
if request.method == "POST":
# 获得到则返回一个值, 获取不到返回None
request.POST.get('usr')
# 获得到则返回一个值, 获取不到返回默认值PWD
request.POST.get('pwd', 'PWD')
# 获得到则返回的多个值
request.POST.getlist('stus')
1.浏览器发送请求
2.wsgi服务器接收到请求,将请求解析交给Django
3.Django中间件过滤请求信息,交给路由
4.路由完成业务逻辑的分发,到指定app下views中指定的视图函数
5.视图函数完成具体的业务逻辑,返回响应结果
6.将处理结果通过服务器返回给浏览器
# app应用下 models.py 文件
class User(models.Model):
id = models.AutoField(primary_key=True)
usr = models.CharField(max_length=20)
pwd = models.CharField(max_length=32)
# 项目目录下 settings.py 文件
1.在settings.py配置Mysql数据库信息
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'dg2',
'HOST': '127.0.0.1',
'PORT': 3306,
'USER': 'root',
'PASSWORD': 'root'
}
}
2.在项目或应用的init文件中修改连接数据库的模块为pymysql
import pymysql
pymysql.install_as_MySQLdb()
3.在项目目录下,执行(生成迁移数据,没有映射到数据库):python3 manage.py makemigrations
4.将迁移数据映射到数据库:python3 manage.py migrate
# app应用下 views.py 文件的具体逻辑代码中
from app.models import User
# User.objects.filter(具体条件).具体操作(),filter就是sql是否需要条件
# 增
User.objects.create(usr='abc', pwd='123') # 第一种方式
user = User(usr='owen', pwd='123')
user.save() # 第二种方式
# 删
User.objects.filter(id=1).delete()
# 改
User.objects.filter(pwd='123').update(pwd='000')
# 查
User.objects.filter(pwd='000').all()
User.objects.filter(pwd='000').first()
标签:mysqld django web服务 通过 解析 没有 lis pycha 连接数据库
原文地址:https://www.cnblogs.com/liubinliuliu/p/10440834.html