장고 웹 응용 프로그램 프레임 워크는 파이썬으로 작성된 오픈 소스입니다.
파이썬 웹 프레임 워크는 많은 등이 있습니다 : 장고, 토네이도, 플라스크 .. 그러나 그것의 장점을 다른 웹 장고 프레임 워크에 비해 : 크고 프레임 워크 자체가 바인딩 ORM, 모델, 템플릿 엔진, 캐시, 세션, 그리고 다른 많은 통합 기능.
장고 소프트웨어 사용 MVC 디자인 패턴, 즉 모델 M, 및 제어기 C. 뷰 V
설치 안내서
01 장고를 설치
당신이 파이썬을 설치했는지 확인을 설치하기 전에 (이이 = 말했다하지 않을 것입니다. =!), 그리고 방법에 의해 대응의 버전을 살펴, 당신은 건너 뛸 수 있습니다 ~
설치에서 0x01로 리눅스 :
첫 번째 방법은하는 것입니다 설치 핍 :
핍 설치 장고
이것은 가장 간단한 설치,하지만 난 python3.6로 업그레이드하는 것이 좋습니다 결국 다른 모듈, python2.7에서 설치 후 많은 구덩이가 발생합니다 소개합니다. 그런 다음 설치합니다.
물론, 다른 방법이다 원본 설치 :
다운로드 소스 패키지 : https://www.djangoproject.com/download/
설치하려면 다음 명령을 입력합니다 :
타르 XY로 Django-의 -zxvf 타르 에 .gz # 추출물 다운로드 한 패키지 CD 장고 - 장고에 XY 번호 디렉토리 파이썬있는 setup.py 설치 명령 실행을 설치 #을
참고 : 성공적으로 설치가 설치 디렉토리의 장고 파이썬 사이트 패키지 디렉토리에 있습니다 후.
설치시 0x02로 승리 :
첫 번째 방법은 패키지를 설치하는 것입니다 :
마찬가지로 설치 파이썬 패키지를 설치, 다운로드 장고 다운로드 : https://www.djangoproject.com/download/
(이 시점에서 당신은 위의 표에서 눈에 필요로하는 방식으로 버전에 해당 : 현재 장고 1.6.x 이상인 이상이 이미 완벽하게 호환 파이썬 3.x를 사용)
장고는 압축 및 압축 해제 장고에 동일한 루트 디렉토리에 파이썬 설치는 설치를 설치 한 다음 시작있는 setup.py 파이썬이 장고 옆 파이썬 해방 사이트 - 패키지 설치됩니다 수행 다운로드.
그리고 환경 변수, 시스템 환경 변수에 추가이 몇몇 디렉터리를 구성 : C : \ Python33 \ lib 디렉토리 \ 사이트 - 패키지 \ 장고를, C : \ Python33 \ 스크립트. 추가의 완성은 새로운 건설 django-admin.py 장고의 명령을 사용할 수 있습니다 후.
두 번째 방법은 핍 명령 줄 설치하는 것입니다 (권장)
핍 설치 장고 == 1.11 . (11)
세 번째 방법은 Pycharm 설치이다 :
그런 다음 검색 장고 설치합니다.
0x03으로 MAC에 설치
이 링크를 참조 https://www.runoob.com/django/django-install.html
02 구성 장
첫째, 프로젝트를 생성
0x01로 명령 줄에서 장고 - 관리자 (에 관계없이 리눅스 \ 윈도우)를 실행
장고 - 관리자 startproject 내 사이트
이 자리에서 만들 수 있기 때문에이 스위치를 만들려는 디렉토리에 실행에주의를 기울여야한다!
는 0x02의 pycharm 작성
대략 이런 후 디렉토리를 생성합니다 :
mysite/ #项目的容器 ├── manage.py # 管理文件,可让你以各种方式与该 Django 项目进行交互 └── mysite # 项目目录 ├── __init__.py #一个空文件,告诉 Python 该目录是一个 Python 包 ├── settings.py # 配置文件 ├── asgi.py # asgi服务器来处理websocket请求 ├── urls.py # 路由系统 --> URL和函数的对应关系 └── wsgi.py # runserver命令就使用wsgiref模块做简单的web server
#以下我这创建的项目例子是Secfile而非mysite
解释:
- manage.py #对当前Django程序所有操作可以基于python manage.py runserver | startapp appname | syncdb | makemigrations | migrate | createsuperuser
- wsgi.py #用于定义django用什么socket实现
- WSGI(Web Server Gateway Interface)是一种规范,它定义了使用python编写的web app与web server之间接口格式,实现web app与web server间的解耦。
二、运行Django项目
python manage.py runserver 0.0.0.0:8000
0.0.0.0 让其它电脑可连接到开发服务器,8000 为端口号。如果不说明,那么端口号默认为 8000。
在浏览器输入你服务器的 ip(这里我们输入本机 IP 地址: 127.0.0.1:8000) 及端口号,如果正常启动,输出结果如下
pycharm下运行直接点击按钮run 项目就行!
三、配置文件配置
首先我们看一下默认的 url.py文件,
from django.contrib import admin from django.urls import path urlpatterns = [ path('admin/', admin.site.urls), ]
#这里既是URL与函数的对应关系,当访问http://127.0.0.1:8000/admin/时,就会执行 admin.site.urls这个写好的函数。
而函数的作用既是处理用户请求并且返回结果,其至少要有一个参数
例:
from django.contrib import admin from django.urls import path from django.shortcuts import HttpResponse def login(request): ''' 处理用户请求并返回内容 :param request:用户请求相关的所有信息(对象) :return: ''' return HttpResponse('hello word!') urlpatterns = [ #path('admin/', admin.site.urls), path('login/',login), ]
这个例子是尝试创建了一个login的函数,函数应用了HttpReponse,就是用户访问login/时,return用户一字符串。执行如下:
充分说明了 路由关系 和 处理请求的函数
这个时候,我们假装要做一个用户登录界面,你给用户显示一句话也不太礼貌对吧,这时这样实现:
那我们可不可以这样:
把html标签信息返给用户呢:
1 def login(request): 2 ''' 3 处理用户请求并返回内容 4 :param request:用户请求相关的所有信息(对象) 5 :return: 6 ''' 7 return HttpResponse('<input type="text" />')
神奇啊!
借助这个思路,我们就可以在templates文件夹下放一个login.html啊,可可这个文件怎么告诉django怎么读取呢?因为HttpReponse只认识字符串啊!
那砸办?--> 用 render模块!
from django.shortcuts import HttpResponse,render def login(request): #return HttpResponse('<input type="text" />') return render(request,'login.html') urlpatterns = [ #path('admin/', admin.site.urls), path('login/',login), ]
这个render就是自动找到模板路径下的login.html读取内容并返回给用户(本质用的还是HttpResponse)
而那个"login.html"文件就可以任意发挥,做一个登陆的界面。例如:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>登录 </title> </head> <body style="background-color:PowderBlue;"> <form> 用户名:<br> <input type="text" name="usr" required autofocus placeholder="username"><br> 密码:<br> <input type="password" name="passwd" maxlength="12" placeholder="password"><br><br> <input type="submit" value="登录"/> </form> </body> </html>
对应关系是在setting.py中设置好的,已经把templates作为basez_dir了,所以这个文件夹的名字路径要一致才行 。
配置模板路径:
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', ], }, }, ]
这里相对实际就多了一个模板路径配置
那么想设置CSS静态文件保存哪里?
静态文件配置:即是你写HTML文件是导入的js 、jQuery、bootstrap\图片等静态文件路径
STATIC_URL = '/static/' # HTML中使用的静态文件夹前缀 STATICFILES_DIRS = [ os.path.join(BASE_DIR, "static"), # 静态文件存放位置 ]
注意:1.在setting.py最后面添加位置,/static/名字对应即可非强制该名;2.逗号,一定不要忘记!
同时你html里的路径也要做响应的修改
<script src="/static/jquery-3.2.1.min.js"></script> <script src="/static/bootstrap/js/bootstrap.min.js"></script> <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
举个栗子:
禁用csrf
刚开始测试使用的时候可在配置文件中暂时禁用csrf中间件,方便表单提交测试。
MIDDLEWARE = [ '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', ]
总结一下,创建django的3个步骤:
1.创建project
2.配置 --模板路径 'DIRS': [os.path.join(BASE_DIR, 'templates')] --静态文件路径 3. 先禁掉csrf