장고 설치 구성에 대한 참고 사항을 학습 1

장고 웹 응용 프로그램 프레임 워크는 파이썬으로 작성된 오픈 소스입니다.

파이썬 웹 프레임 워크는 많은 등이 있습니다 : 장고, 토네이도, 플라스크 .. 그러나 그것의 장점을 다른 웹 장고 프레임 워크에 비해 : 크고 프레임 워크 자체가 바인딩 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

 

 

     

추천

출처www.cnblogs.com/ethtool/p/12116797.html