一.命令行搭建Django项目
- 安装django
# 在解释器环境下安装django 1.11.9# 在真实python3环境下: pip3 install django==1.11.9# 在虚拟环境下: 先激活虚拟环境 => pip3 install django==1.11.9# 查看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:8080复制代码
二.Pycharm搭建项目
# 选择有django环境的解释器创建项目# Tools -> Run manage.py Task... -> startapp app_name# 正常运行项目来启动复制代码
三.项目响应请求
完成 请求的处理
- 在项目的urls.py中配置路由
# 文件: 项目下 urls.pyimport app.views as app_views # 创建的app下的视图文件urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'index', app_views.index) # 配置的路由]复制代码
-
在具体应用下的视图文件为请求配置响应函数
-
第一个响应
# 文件: app应用下 views.pyfrom django.http import HttpResponsedef index(abc): return HttpResponse('hello django')复制代码
- 第一个模板页面
from django.shortcuts import renderdef view_action(request): return render(request, 'template_page.html')复制代码
- 第一个重定向
from django.shortcuts import redirectdef view_action(request): return redirect('/重定向的路由/')复制代码
四.模板渲染-冲突处理
前提: 一个项目中有多个应用,每个应用都具有相同命名的模板页面文件, 如app与newapp都有各自的主页index.html
- 处理模板冲突
# 在settings.py文件中如果配置了应用名# 在自身应用文件夹下创建templates文件,再在其中创建与应用名相同的文件夹,该应用的模板文件都可以放在该文件夹下# eg: newApp访问自身主页def index(request): return render(requset, 'newApp/index.html')# 在settings.py没有配置应用名# 在项目templates文件下创建与应用名相同的文件夹, 该应用的模板文件都可以放在该文件夹下# 视图处理函数的逻辑一致# 注: 两种同时存在是, 项目下templates优先被访问复制代码
五.静态文件加载
- 静态文件的根路由 => 规定了加载静态文件的起点
# settings文件下的STATIC_URL = '/static/'# 下方规定静态文件可以放入的文件夹STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static'), os.path.join(BASE_DIR, 'a'), os.path.join(BASE_DIR, 'b'),]# 直接导致模板页面导入静态文件起点:# 复制代码
六.GET请求的数据获取
def login(request): if request.method == "GET": # 获得到则返回一个值, 获取不到返回None request.GET.get('user') # 获得到则返回的多个值 request.GET.getlist('users')复制代码
七.POST请求的数据获取
def login(request): if request.method == "POST": # 获得到则返回一个值, 获取不到返回None request.POST.get('user') # 获得到则返回的多个值 request.POST.getlist('users')复制代码
八.连接数据库
import pymysql# 连接数据库conn = pymysql.connect(host='localhost', port=3306, user='root', password='root', db='django')# 设置游标执行sql语句cur = conn.cursor(pymysql.cursors.DictCursor)cur.execute('select * from user')cur.execute('select * from user where usr=%s and pwd=%s', [usr, pwd])# 获取执行结果users = cur.fetchall() # 所有用户数据res = cur.fetchone() # 一条用户数据复制代码