DjangoのURLルートディストリビューションをダウンロードしてインストールするには、HTTPプロトコル

コンテンツ今日

  1. HTTPプロトコル
  2. MVCフレームワークモデルおよびMTV
  3. ジャンゴをダウンロードしてインストール
  4. DjangoのURLルートの配布

HTTPプロトコル

http协议
请求信息格式
GET / HTTP/1.1   请求行
Host: 127.0.0.1:8003  请求头
Connection: keep-alive
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3
Accept-Encoding: gzip, deflate, br
Accept-Language: zh-CN,zh;q=0.9
#空行
请求数据  username=ziwen password=666


get请求 请求数据部分是没有数据的,get请求的数据在url上,在请求行里面,有大小限制,常见的get请求方式: 浏览器输入网址,a标签
post请求 请求数据在请求体(请求数据部分) ,数据没有大小限制, 常见方式:form表单提交数据


超文本传输协议(应用层的,基于tcp\ip协议的)

特点:无状态,无连接(短连接)

请求消息格式:请求行\请求头部\空行\请求数据
    请求行:GET 路径 HTTP/1.1
    
响应消息格式:响应行\响应头部\空行\响应数据
    响应行: HTTP/1.1 状态码 状态描述

请求方法:get\post\put\delete\head\options\trace\connect\

get请求和post的请求的区别
    get,数据放在url上,有长度限制,一般用于获取数据
    post请求,数据放在请求数据部分,没有长度限制,一般用于提交数据

状态码:
    1xx请求被接受但是还在处理当中 
    2xx请求成功
    3xx重定向(301永久重定向和302临时重定向)
    4xx客户端错误(请求错误)
    5xx服务器错误

MVCフレームワークとMTV

MVC

Webサーバの開発分野で有名なMVCパターン、いわゆるMVCは、プラグイン、疎結合の方法でそれらの間のモデルにWebアプリケーション(M)、コントローラ(C)及び図(V)は、3つの、あります一緒に、マッピング・ビジネス・オブジェクト・モデル・データベース(ORM)、ユーザのビュー(ページ)との相互作用の原因であるの原因で、コントローラは、呼終了モデルと次のように模式図であるユーザの要求を、視聴者のユーザ入力を受け付けます。

IMG

MTV

 MTV Djangoの性質およびMVCパターンは同じであるが、疎結合のコンポーネントが、わずかに異なる定義との間の関係を維持するために、MTV Djangoの値は次のとおりです。

  • ビジネスオブジェクトリレーショナルマッピングとデータベース(ORM)の責任:Mモデル(モデル)を表しています。
  • ユーザー(HTML)にページを表示する方法の責任:Tは、テンプレート(テンプレート)を表しています。
  • Vは、ビュー(ビュー)を表し:ビジネス・ロジックを担当し、かつ適切な時期にモデルとテンプレートを呼び出します。

  次のように上記の3つに加えて、だけでなく、URLディストリビュータ、異なるビューに分配ページ要求プロセスのURLであるの役割、表示を必要とし、その後、適切なモデルテンプレートを呼び出し、MTV応答モードです。

  IMG

  一般ユーザーは、ビューの機能にアクセスするために戻って、ブラウザからのリクエストを当社のサーバーへの要求(リクエスト)を開始(データ呼に関連していない場合は、そのビュー機能は、テンプレートを返します。この時間は、ユーザーへのWebページである)、ビュー機能コールモデル、データを見つけるためにmodelデータベース、その後、バックステップ、機能の表示が空白のテンプレートを埋めるためにデータを返し、最後のページがユーザーに返されます。

ジャンゴをダウンロードしてインストールするには、プロジェクトのアプリケーションを作成します。

ジャンゴコマンド

  1. ダウンロード

    ジャンゴ== 1.11.23をインストールPIP - 私は

  2. プロジェクトを作成します。

    ジャンゴ管理者startprojectのプロジェクト名

  3. 起動項目

    プロジェクトのルートディレクトリにcd

    python manage.pyのrunserver#127.0.0.1:8000

    80#127.0.0.1:80のrunserverのpython manage.py

    python manage.py runserver 0.0.0.0:80 # 0.0.0.0:80

  4. 创建app

    python manage.py startapp app名称

    注册

  5. 数据库迁移

    python manage.py makemigrations # 创建迁移文件 检测已经注册的APP下的models

    python manage.py migrate # 迁移 将models的变更记录同步到数据库

下载django

第一种 cmd下载 cmd 输入python 进入 python解释器

输入pip3 install django==1.11.9
pip国内的一些镜像
阿里云 http://mirrors.aliyun.com/pypi/simple/
中国科技大学 https://pypi.mirrors.ustc.edu.cn/simple/
豆瓣(douban) http://pypi.douban.com/simple/
清华大学 https://pypi.tuna.tsinghua.edu.cn/simple/
中国科学技术大学 http://pypi.mirrors.ustc.edu.cn/simple/
临时使用:
可以在使用pip的时候在后面加上-i参数,指定pip源
修改源方法
pip3 install django==1.11.9

卸载djange
pip uninstall django

第2种 pycham下载

1569313999339

创建djange项目

第1种pythcm创建

注意不要选择虚拟环境

1569324037758

第2种终端创建

创建项目
    django-admin startproject mysite   创建了一个名为"mysite"的Django 项目
启动项目

启动项目
    python manage.py runserver  默认是127.0.0.1:8000
    python manage.py runserver 127.0.0.1  默认端口号是8000
    python manage.py runserver 127.0.0.1:8001 

当前目录下会生成mysite的工程,目录结构如下:(大家注意昂,pip下载下来的django你就理解成一个模块,而不是django项目,这个模块可以帮我们创建django项目

  • manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库,启动关闭项目与项目交互等,不管你将框架分了几个文件,必然有一个启动文件,其实他们本身就是一个文件。
  • settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
  • urls.py ----- 负责把URL模式映射到应用程序。
  • wsgi.py ---- runserver命令就使用wsgiref模块做简单的web server,后面会看到renserver命令,所有与socket相关的内容都在这个文件里面了,目前不需要关注它。

创建应用

python manage.py startapp blog   #通过执行manage.py文件来创建应用blog,执行这句话一定要注意,你应该在这个manage.py的文件所在目录下执行这句话,因为其他目录里面没有这个文件
python manage.py startapp blog2  #每个应用都有自己的目录,每个应用的目录下都有自己的views.py视图函数和models.py数据库操作相关的文件

models.py :之前我们写的那个名为model的文件就是创建表用的,这个文件就是存放与该app(应用)相关的表结构的

views.py :存放与该app相关的视图函数的

django的url路由分发

要一一对应 括号了几个 对应的视图函数也要几个

# url(r'^articles/(\d+)/(\d+)/', views.articles), #articles/2019/9/
    视图函数
        def articles(request,year,month):  # 位置参数 2019  9
            print(year,type(year)) #2019 <class 'str'>  #匹配出来的所有数据都是字符串
            print(month)

            return HttpResponse(year+'年'+ month +'月' +'所有文章')
        

    # 有名分组参数
    url(r'^articles/(?P<xx>\d+)/(?P<oo>\d+)/', views.articles), #articles/2019/9/
    #xx=2019  oo=9  关键字传参
    
    def articles(request,oo,xx):  # 关键字传参 2019  9
        print(xx,type(xx)) #2019 <class 'str'>  #匹配出来的所有数据都是字符串
        print(oo)
        return HttpResponse(xx+'年'+ oo +'月' +'所有文章')

基于Django的登录小实列

第1步 先配置setting.py文件中的INSTALLED_APPS
第2步 配置urls.py文件 路径分发 
第3步 配置视图,views.py 写自己的逻辑 返回html页面 还是重定向 等等
第4步 创建 对应的html页面

注意点 from表单 不添提交地址就是原地址 我们可以通过请求方式get\post 进行逻辑判断
输入网址进去就是get请求request.method == 'get':
提交网址进去就是POST请求request.method == 'POST':
print(request.POST)#里面是字典
name = request.POST.get('username')#获取是字符串用户输入的值

第一步配置setting.py

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config',#添加app01的应用
]
第4行注了 不然安全错误
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',
]

第2步配置配置url

from app01 import views
urlpatterns = [#只做路径匹配 不分post还是get
    url(r'^admin/', admin.site.urls),
    url(r'^login/', views.login),
    url(r'^login/(\d+)/(\d+)/', views.articles), #articles/2019/9/
]


 # 有名分组参数
    url(r'^articles/(?P<month>\d+)/(?P<year>\d+)/', views.articles), #articles/2019/9/
    #xx=2019  oo=9  关键字传参

第3步找到视图views.py写逻辑

request形参 对象 约定俗成 
HttpResponse可以返回字符串
redirect重定向
render 渲染


from django.shortcuts import render,HttpResponse
print(request.path)
def login(request):
    if request.method == 'POST':
        name = request.POST.get('username')#获取是字符串用户输入的值request.POST里面是字典
        pwd = request.POST.get('pwd')
        # print(name,pwd,'----------------------')
        if name == 'aa' and pwd == 'aa':
            return render(request, 'login2.html')
        else:
            return HttpResponse('登录失败!!')
    else:
        return render(request, 'login.html')#模板渲染 模板就是html页面 渲染就是字符串替换   第一个参数:request  第二个参数是html页面路径,
        
from django.shortcuts import render,HttpResponse,redirect
from django.urls import reverse

def home(request):
    return redirect(reverse('cs1'))

ステップ4 login.htmlを作成

如果action里面不写还是原页面 我们可以设置method进行逻辑判断

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>

<form action="" method="post">  <!-- http://127.0.0.1:8000 /login/    /login2/-->
    用户名:<input type="text" name="username">  <!-- http://127.0.0.1:8000/login/login2/ -->
    密码:<input type="text" name="pwd">
    <input type="submit">
</form>

</body>
{#<script src="jquery.js"></script>#}
</html>

おすすめ

転載: www.cnblogs.com/saoqiang/p/11628195.html