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. kubesphere应用系列(四)--创建自动流水线

    第一步创建多分支流水线 复制生成的url,也可以在编辑设置时复制   第二步新增Jenkinsfile文件 新增Jenkinsfile文件放在根目录 方式一:官方示例:https://github.c ...

  2. 海康SDK报错Structure.getFieldOrder()

    就是你调用的这个结构体以及其引用的其他结构体,可能没有getFieldOrder()的方法,你只要按照顺序把他填上去就好了.比如 public static class NET_DVR_TIME ex ...

  3. 《uTools:提升效率的神奇工具》

    utools5.0 一.引言 在如今快节奏的工作和生活中,我们都在寻找能够帮助我们节省时间.提高效率的工具.uTools 就是这样一款令人惊艳的工具,它为我的日常带来了极大的便利. 相关链接:uToo ...

  4. 开启 Typecho 的 gzip 压缩

    简介 GZip压缩,是一种网站速度优化技术,也是一把SEO优化利器,许多网站都采用了这种技术,以达到提升网页打开速度.缩短网页打开时间的目的. 网站采用Gzip压缩,还有一个好处,就是让你少了一份流量 ...

  5. Ollama+DeepSeek+SlackBot

    技术背景 想必最近有在部署DeepSeek大模型的人,看标题就知道这篇文章在做什么事情了.由于Ollama对于IP的监听缺乏安全防护,并且内网部署的Ollama模型对于外网来说也是不可见的,而如果使用 ...

  6. 【Unit3】社交系统模拟(JML规格化设计)-作业总结

    第三单元作业难度在OO课程中当属最低.原因在于最复杂多变(贻害无穷)的设计环节被作业接口和JML规格描述限定,我们不再需要考虑整体的构架(抽象出那些类,设置哪些方法等),唯一的能动性仅在具体实现和复杂 ...

  7. mac zsh终端 goframe gf 别名冲突

    前言 如果你使用的是 zsh 终端,可能会存在 gf 别名冲突( git fetch 快捷指令) 解决 终端运行 alias gf=gf,gf 工具会自动修改 .zshrc 中的别名设置,source ...

  8. BGP路由优选原则

    0 丢弃下一跳不可达的路由 1 优选Preference_Value值最高的路由(本设备有效) Pref-Val:协议首选值 华为私有的属性,只具有本地(本设备)意义,缺省情况下为0,越大越优,0-6 ...

  9. 基于pandas的数据清洗 -- 重复值的清洗

    博客地址:https://www.cnblogs.com/zylyehuo/ 开发环境 anaconda 集成环境:集成好了数据分析和机器学习中所需要的全部环境 安装目录不可以有中文和特殊符号 jup ...

  10. BUUCTF---rot

    题目 破解下面的密文: 83 89 78 84 45 86 96 45 115 121 110 116 136 132 132 132 108 128 117 118 134 110 123 111 ...