Django视图

步骤1:新建一个应用

python manage.py startapp + 应用名

步骤2:启动服务器(可选)

python manage.py runserver

步骤3:在项目的urls.py文件里面添加包含文件

url(r'^second/',include('second.urls'))

注意:

second后面的的反斜杠千万不要漏掉

步骤4:配置应用url

打开urls.py

from django.conf.urls import url

from second import views

urlpatterns = [

    url(r'^index/', views.index),

    url(r'^(\d+)/', views.detail),

]

views.py

from django.shortcuts import render

from django.http import HttpResponse

def index(request):

    return HttpResponse('hello world')

def detail(request, num):

    return HttpResponse(num)

步骤5:在浏览器输入网址

http://127.0.0.1:8000/second/index

步骤6:在views.py里面添加

def detail_two(request, num1, num2, num3):

    return HttpResponse('%s-%s-%s' % (num1, num2, num3))

步骤7:在urls.py里面添加

# 把之前url注释了

# url(r'^index', views.index),

# url(r'^(\d+)/', views.detail),

url(r'^(\d+)/(\d+)/(\d+)$', views.detail_two),

步骤8:在urls.py里面添加

把其他url注释

url(r'^(?P<num2>\d+)/(?P<num1>\d+)/(?P<num3>\d+)$', views.detail_two),

定义视图

1.在项目settings里面,把debug改为Ture

DEBUG=False

2.在项目settings里面,把ALLOWED_HOSTS改为任何人可以访问

ALLOWED_HOSTS=['*']

3.在项目的templates目录下面添加404.html

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>Title</title>

</head>

<body>

<h1>傻了吧,找不到页面</h1>

</body>

</html>
  • HttpReqeust对象

1.在应用的urls.py里面设置重新配置一下url

urlpatterns = [

    url(r'^index', views.index),

]

2.修改应用views.py的视图函数

def index(request):

    # request返回请求页面的完整路径

    return HttpResponse(request.path)

3.将应用跑起来,然后再浏览器输入如下路径,注意:此时页面显示的为路径

http://127.0.0.1:8000/second/index
  • GET属性

1.在应用templates里面创建一个目录,目录名为booktest,添加3个html页面,分别为getTest1.html,getTest2.html,getTest3.html

2.在应用的views.py里面的增加3个视图函数

展示接收的页面

def getTest1(request):

return render(request,'booktest/getTest1.html')

接收一键一值的情况

def getTest2(request):

return render(request,'booktest/getTest2.html')

接收一键多值的情况

def getTest3(request):

return render(request,'booktest/getTest3.html')

3.在应用的urls.py里面添加

url(r'^index', views.index),

url(r'^getTest1/$',views.getTest1),

url(r'^getTest2/$',views.getTest2),

url(r'^getTest3/$',views.getTest3),

4.在getTest1.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Title</title>

</head>

<body>

一键一值:<a href="/second/booktest/getTest2/?a=1&b=2&c=3">test2</a>


一键多值:<a href="/second/booktest/getTest3/?a=1&a=2&a=3">test3</a>

</body>

</html>

5.在views.py

展示接收的页面

def getTest1(request):

return render(request, 'booktest/getTest1.html')

接收一键一值的情况

def getTest2(request):

# request.GET['a']等价于request.GET.get('a')

# 根据键接收值

a1 = request.GET.get('a')

b1 = request.GET.get('b')

c1 = request.GET.get('c')

# 构造上下文

context = {'a': a1, 'b': b1, 'c': c1}

# 调用模板进行渲染

return render(request, 'booktest/getTest2.html', context)

接收一键多值的情况

def getTest3(request):

return render(request, 'booktest/getTest3.html')

6.在getTest2.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Title</title>

</head>

<body>

a:{{ a }}


b: {{ b }}


c:{{ c }}


</body>

</html>

7.接收一键多值,在views.py模块里面

在浏览器输入 http://127.0.0.1:8000/second/getTest3/?a=12&a=2&a=3 (其中a对应多个值)

def getTest3(request):

a1 = request.GET.getlist('a')

context={'a':a1}

return render(request, 'booktest/getTest3.html',context)

8.在getTest3.html里面

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>页面3</title>

</head>

<body>

a:{% for item in a %}

{{ item }}

{% endfor %}

</body>

</html>

POST请求

1.设计2个视图

def postTest1(request):

return render(request, 'booktest/postTest1.html')

def postTest2(request):

return render(request, 'booktest/postTest2.html')

2.配置url(urls.py)

urlpatterns = [

url(r'^index/', views.index),

# url(r'^(\d+)/',views.detail)

url(r'(?P<num2>\d+)/(?P<num1>\d+)/(?P<num3>\d+)', views.detail2),

url(r'^getTest1/$',views.getTest1),

url(r'^getTest2/$',views.getTest2),

url(r'^getTest3/$',views.getTest3),

url(r'^postTest1/$',views.postTest1),

url(r'^postTest2/$',views.postTest2),

]

3.添加html模板

postTest1.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>POST2</title>

</head>

<body>

{# action 为要请求的url#}

<form method="post" action="/second/postTest2/">

用户名:<input type="text" name="uname">

<hr>

密码:<input type="password" name="upwd">

<hr>

性别:<input type="radio" name="ugender" value="男" checked="checked">男<input type="radio" name="ugender" value="女">女

<hr>

<input type="submit" value="提交">

</form>

</body>

</html>

postTest2.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>POST2</title>

</head>

<body>

{# action 为要请求的url#}

<form method="post" action="/second/postTest2"></form>

用户名:{{ uname }}


密码:{{ upwd }}


性别:{{ ugender }}

</body>

</html>

4.注释csrf,在项目的settings里面

MIDDLEWARE_CLASSES = (

'django.contrib.sessions.middleware.SessionMiddleware',

'[django.middleware.common.CommonMiddleware](http://django.middleware.common.commonmiddleware/)',

#'django.middleware.csrf.CsrfViewMiddleware',

'django.contrib.auth.middleware.AuthenticationMiddleware',

'django.contrib.auth.middleware.SessionAuthenticationMiddleware',

'django.contrib.messages.middleware.MessageMiddleware',

'django.middleware.clickjacking.XFrameOptionsMiddleware',

'django.middleware.security.SecurityMiddleware',

)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容