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. ESP8266+AT指令,使用MQTT协议连接阿里云

    AT指令集 AT+CWMODE=1 AT+CWJAP="热点名","热点密码" AT+CIPSNTPCFG=1,8,"ntp1.aliyun.com& ...

  2. cmd - windows操作系统命令提示符常用命令

    mklink /j C:\Users\lin_0421\Desktop\note D:\note

  3. Markdown 编写技巧汇总(二)

    继续上篇汇总 附-上篇汇总,接着做更加高级一点的应用技巧. [1]列表与引言嵌套 两者嵌套,如: > 我是一行文本 > 1. 文本1 > 2. 文本2 > 1. 文本 > ...

  4. Vuex:让状态管理不再头疼的“管家”

    如果你正在开发一个 Vue.js 应用程序,但发现自己被各种组件之间的状态共享问题搞得焦头烂额,那么 Vuex 就是你需要的"超级管家".Vuex 是专门为 Vue.js 设计的状 ...

  5. ctfhub-rce-部分做题记录

    命令注入 检查网页显示内容,可以直接看到源代码.大致意思是:检查用户输入的 GET 请求,判断用户是否输入了 ip 信息.如果输入了 ip 信息,则使用用户输入的这个 ip 数据执行一个 shell ...

  6. composer 指定php版本

    需要指定php和composer的位置,然后再去执行composer命令 ## 指定PHP版本 指定composer 指定载入包 /usr/local/php7/bin/php composer /u ...

  7. 为什么AI教师难以实现

    提供AI应用咨询+陪跑服务,有需要回复1 本周为一家教育公司提供了全天的AI的培训,后续涉及AI+教育领域的项目开发,而我去年就做过AI教师项目,所以对AI+教育有一定熟悉度. 下来后又拜访了一家互联 ...

  8. Linux下如何重启Oracle

    操作步骤 切换到oracle用户 su – oracle 通过sqlplus以管理员身份登录 sqlplus / as sysdba 然后执行 shutdown immediate 退出sqlplus ...

  9. Linux下查询tomcat进程命令

    由于查询tomcat进程时将ps -ef|grep tomcat命令记错为ps -f|grep tomcat命令,因此对比两个命令进行区分. ps -f |grep tomcat执行结果: dgztc ...

  10. bug|初始化项目|sass-loader报错:TypeError: this.getResolve is not a function at Object.loader

    Module build failed: TypeError: this.getResolve is not a function at Object.loader的解决 npm uninstall ...