S14day19---->urls.py

from django.contrib import admin
from django.conf.urls import url,include

urlpatterns = [
    url(r'^cmdb/',include('app01.urls')),
    url(r'^monitor/',include('app02.urls')),
]

'''
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    # url(r'^index999999999/(\d+)/(\d+)/', views.index,name='indexx'),
    url(r'^index999999999/(?P<nid>\d+)/(?P<uid>\d+)/', views.index,name='indexx'),
    url(r'^login/',views.login),
    url(r'^home/',views.Home.as_view()),
    # url(r'^detail/',views.detail),
    # url(r'^detail-(\d+).html',views.detail),
    # url(r'^detail-(\d+)-(\d+).html',views.detail),
    # url(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html',views.detail),
    url(r'^detail-(?P<nid>\d+).html',views.detail),
]
'''
# url(r'^detail-(\d+).html',views.detail),  这种情况Django会传递一个参数给detail函数 一个正则对应一个参数

App01--->urls.py

from django.contrib import admin
from django.conf.urls import url
from app01 import views

urlpatterns = [
    url(r'^login/', views.login),
]

App02-->urls.py

from django.contrib import admin
from django.conf.urls import url
from app02 import views

urlpatterns = [
    url(r'^login/', views.login),
]

App01-->views.py

from django.shortcuts import render,HttpResponse,redirect

# Create your views here.

# USER_DICT={
#     "k1": "root1",
#     'k2': "root2",
#     'k3': "root3",
#     'k4': "root4",
#     'k5': "root5",
#     'k6': "root6",
# }

USER_DICT={
    '1': {'name':'root1', 'email':'root1@live.com'},
    '2': {'name':'root2', 'email':'root2@live.com'},
    '3': {'name': 'root3',  'email': 'root3@live.com'},
    '4': {'name': 'root4',  'email': 'root4@live.com'},
    '5': {'name': 'root5',  'email': 'root5@live.com'},
    '6': {'name': 'root6', 'email': 'root6@live.com'},
}

# USER_LIST=[
#     {'name':'root1'},
#     {'name':'root2'},
#     {'name':'root3'},
#     {'name':'root4'},
# ]
# {% for item in user_list%}



def index(request,nid,uid):
    #indexx
    print(request.path_info)
    from django.urls import reverse
    # v=reverse('indexx', args=(60,50,))
    v=reverse('indexx',kwargs={'nid':1,'uid': '30'})
    print(v)

    return render(request,'index.html',{'user_dict':USER_DICT})

# def detail(request):
#     nid=request.GET.get('nid')
#     detail_info=USER_DICT[nid]
#     return render(request,'detail.html',{'detail_info':detail_info})

def detail(request,nid):
    # return HttpResponse(nid)
    # detail_info=USER_DICT[kwargs['nid']]
    detail_info=USER_DICT[nid]
    return render(request,'detail.html',{'detail_info':detail_info})

def login(request):
    if request.method=="GET":
        return render(request,'login.html')

    elif request.method=="POST":
        # v=request.POST.get('radio')
        # print(v)
        # v=request.POST.getlist('city')
        # print(v)
        # v=request.POST.get('fafafa')
        # print(v)
        obj=request.FILES.get('fafafa')
        print('obj',obj.name)
        import os
        file_path=os.path.join('upload',obj.name)
        f=open(file_path, mode="wb")
        for i in  obj.chunks():
            f.write(i)
        f.close()
        from django.core.files.uploadedfile import InMemoryUploadedFile
        return render(request,'login.html')

    else:
        #put ,DELETE,HEAD,OPTION
        return redirect('/index/')

# def login(request):
#     if request.method=="GET":
#         return render(request,'login.html')
#
#     elif request.method=="POST":
#         u=request.POST.get('user')
#         p=request.POST.get('pwd')
#         if u=='alex' and p=='123':
#             return redirect('/index/')
#         else:return render(request,'login.html')
#
#     else:
#         #put ,DELETE,HEAD,OPTION
#         return redirect('/index/')

# 查看模块源代码:ctrl+B

from django.views import View
class Home(View):

    def dispatch(self,request,*args,**kwargs):
        #调用父类中的dispatch
        print('before') #可自定一些操作
        result= super(Home,self).dispatch(request,*args,**kwargs)
        print('ater')  #可自定一些操作
        return result

    # get请求执行get post请求执行post方法
    def get(self,request):
        print(request.method)
        return render(request,'home.html')

    def post(self,request):
        print(request.method)
        return render(request,'home.html')

App02--->views.py

from django.shortcuts import render,HttpResponse

# Create your views here.
def login(request):
    return HttpResponse('app02,login')

Templates--->index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <!--
    <ul>
        {% for k in user_dict.keys%}
            <li>{{k}}</li>
        {% endfor %}
    </ul>
    <ul>
        {% for row in user_dict.values %}
            <li>{{ row }}</li>
        {% endfor %}
    </ul>
    <ul>
        {% for k,row in user_dict.items %}
            <li><a target="_blank" href="/detail/?nid={{k}}">{{ row.name }}</a></li>
        {% endfor %}
    </ul>
      -->
    <form action="{% url 'indexx'  nid=1 uid=3 %}" method="post">
{#        <form action="{{ request.path_info }}" method="post">#}
       <p> <input type="text" name="user" placeholder="用户名"></p>
       <p><input type="text" name="email" placeholder="邮箱"></p>
       <input type="submit" value="提交">
    </form>
    <ul>
        {% for k,row in user_dict.items %}
            <li><a target="_blank" href="/detail-{{ k }}.html">{{ row.name }}</a></li>
        {% endfor %}
    </ul>
</body>
</html>

{# /index/  指127.0.0.1/index/ #}

{#默认循环keys#}
{#{% for key,row in user_dict.items %} 循环key value#}
{#{% for key,row in user_dict.keys %} 循环key#}
{#{% for key,row in user_dict.values %} 循环value#}

Templates-->login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form action="/cmdb/login/" method="post" enctype="multipart/form-data">
        <p>
            <input type="text" name="user" placeholder="用户名">
        </p>
        <p>
            <input type="password" name="pwd" placeholder="密码">
        </p>
        <p>
            男:<input type="radio" name="gender" value="1">
            女:<input type="radio" name="gender" value="2">
        </p>
         <p>
            男:<input type="checkbox" name="favor" value="11">
            女:<input type="checkbox" name="favor" value="22">
        </p>
        <p>
            <select name="city" multiple>
                <option value="sh">上海</option>
                <option value="bj">北京</option>
                <option value="tj">天津</option>
            </select>
        </p>
        <p>
            <input type="file" name="fafafa">
        </p>
        <p>
            <input type="submit" value="提交">
        </p>
    </form>
</body>
</html>

Templates-->detail.py

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>详细信息</h1>
    <h6>用户名:{{ detail_info.name }}</h6>
    <h6>邮箱:{{ detail_info.email }}</h6>
</body>
</html>

Templates-->home.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form action="/home/" method="post">
        <input type="text" name="user"/>
        <input type="submit"/>
    </form>
</body>
</html>

django实例(2)的更多相关文章

  1. Web框架本质及第一个Django实例 Web框架

    Web框架本质及第一个Django实例   Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web ...

  2. Django实例

    更新:今年8月在深圳和嵩天老师居然见面了,很开心.嵩天老师很和蔼. =========== 今天看了嵩天老师的视频,感觉讲的很好,于是看着视频自己做了一个初步的实例认识. 步骤1,新建一个Web框架 ...

  3. 【Django实例】博客1

    (上一篇) 一.概述 Blog是一个博客应用. dbe工程的目录结构,参考<序言>的最后部分.blog应用位于/home/russellluo/Django/dbe/dbe/blog目录下 ...

  4. django实例收集

    django笔记(一)(模板渲染变量.字典.for循环.索引.条件语句) django笔记(二) django环境准备与笔记(三) django笔记(四) django笔记(五) Views的补充 w ...

  5. Web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  6. WEB框架本质和第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 总的来说:Web框架的本质就是浏览 ...

  7. Django之Web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  8. Django学习笔记之Web框架由浅入深和第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  9. DAY15-web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  10. Web的本质以及第一个Django实例.

       Web框架的本质:    所有的Web应用本质上就是一个socket服务器, 而用户的浏览器就是一个socket客户端. import socket sk = socket.socket() s ...

随机推荐

  1. MacOS配置Homebrew

    Homebrew笔记 1. 介绍 官网:https://brew.sh/ 对于习惯了使用命令来完成一切的程序员来说,安装软件这种小事,自然是能够用命令解决,就不用图形界面选择.但是在 Linux 中, ...

  2. C# DataTable 类使用

    命名空间: System.Data 程序集: System.Data.Common.dll 参考连接:https://docs.microsoft.com/zh-cn/dotnet/api/syste ...

  3. [THUWC2017] 在美妙的数学王国中畅游 题解(内附求导小技巧)

    事实证明物竞笔记是个好东西,可惜没带,不然还能谎称自己会一点求导和微积分. 顺便在这里把比较经典的一些关于求导的东西记录一下: 常用函数求导: \(C'=0,(x^n)'=nx^{n-1},(\log ...

  4. Arduino部分C语言含义之--“::”

    "::"在C++中表示作用域,和所属关系."::"是运算符中等级最高的.有三种作用. 1.作用域符号例如:A,B表示两个类,在A,B中都有成员member.那么 ...

  5. QT5笔记: 14. SpinBox的常用功能

    例子: #include "widget.h" #include "ui_widget.h" Widget::Widget(QWidget *parent) : ...

  6. docker - [08] Portainer可视化面板安装

    Docker图形化界面管理工具 一.运行容器 同时下载和使用镜像运行容器 docker run -d -p 8088:9000 \ --restart=always -v /var/run/docke ...

  7. 2D量测流程

  8. iview weapp输入组件input事件顺序

    做小程序,使用ivew weapp组件框架,同时用到了i-input和i-modal,更具体说,就是在modal里面放置了input,填写数据后点击确定,实现提交数据. 出现点小问题,发现是事件顺序导 ...

  9. 前端跨域方案-跨域请求代理(asp.net handler)

    现在技术开发偏向于使用统一的接口处理浏览器或者app的http请求. 大家都知道因为浏览器的同源策略的原因 js直接请求webapi 接口会有一些问题,即使做好服务器端的配置 同样会有不少的 问题   ...

  10. 【Bug记录】Powershell 无法将“vue”项识别为 cmdlet、函数、脚本文件或可运行程序的名称 - PowerShell 执行策略

    Powershell 无法将"vue"项识别为 cmdlet.函数.脚本文件或可运行程序的名称 造成该问题主要是 PowerShell 执行策略,不支持执行全局脚本和程序的运行. ...