博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Django】【二】模板
阅读量:5079 次
发布时间:2019-06-12

本文共 12744 字,大约阅读时间需要 42 分钟。

1. Django-bootstrap3

guest>python -m pip install django-bootstrap3

 

【代码】

settings.py

""" Django settings for guest project. Generated by 'django-admin startproject' using Django 1.11.7. For more information on this file, see https://docs.djangoproject.com/en/1.11/topics/settings/ For the full list of settings and their values, see https://docs.djangoproject.com/en/1.11/ref/settings/ """ import os # Build paths inside the project like this: os.path.join(BASE_DIR, ...) BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # Quick-start development settings - unsuitable for production # See https://docs.djangoproject.com/en/1.11/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! SECRET_KEY = 'nvz+#19d=3x%-iqhyqpr@82^#1+bw_@j13k8m!id$oe%v-ecql' # SECURITY WARNING: don't run with debug turned on in production! DEBUG = True ALLOWED_HOSTS = [] # Application definition INSTALLED_APPS = [     'django.contrib.admin',     'django.contrib.auth',     'django.contrib.contenttypes',     'django.contrib.sessions',     'django.contrib.messages',     'django.contrib.staticfiles',     'sign',     'bootstrap3', ] 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', ] ROOT_URLCONF = 'guest.urls' TEMPLATES = [     {
'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], 'APP_DIRS': True, 'OPTIONS': {
'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ] WSGI_APPLICATION = 'guest.wsgi.application' # Database # https://docs.djangoproject.com/en/1.11/ref/settings/#databases DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', 'HOST':'127.0.0.1', 'PORT':'3306', 'NAME':'guest', 'USER':'root', 'PASSWORD':'', 'OPTIONS':{
'init_command': "SET sql_mode='STRICT_TRANS_TABLES'", }, } } ''' DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } ''' # Password validation # https://docs.djangoproject.com/en/1.11/ref/settings/#auth-password-validators AUTH_PASSWORD_VALIDATORS = [ {
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', }, {
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', }, {
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', }, {
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', }, ] # Internationalization # https://docs.djangoproject.com/en/1.11/topics/i18n/ LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_L10N = True USE_TZ = True # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/1.11/howto/static-files/ STATIC_URL = '/static/' urls.py
"""guest URL Configuration The `urlpatterns` list routes URLs to views. For more information please see:     https://docs.djangoproject.com/en/1.11/topics/http/urls/ Examples: Function views     1. Add an import:  from my_app import views     2. Add a URL to urlpatterns:  url(r'^$', views.home, name='home') Class-based views     1. Add an import:  from other_app.views import Home     2. Add a URL to urlpatterns:  url(r'^$', Home.as_view(), name='home') Including another URLconf     1. Import the include() function: from django.conf.urls import url, include     2. Add a URL to urlpatterns:  url(r'^blog/', include('blog.urls')) """ from django.conf.urls import url from django.contrib import admin from sign import views urlpatterns = [     url(r'^admin/', admin.site.urls),     url(r'^$',views.index),     url(r'^index/$',views.index),     url(r'^accounts/login/$',views.index),     url(r'^login_action/$',views.login_action),     url(r'^event_manage/$',views.event_manage),     url(r'^search_name/$',views.search_name),     url(r'^guest_manage/$',views.guest_manage),     url(r'^sign_index/(?P
[0-9]+)/$',views.sign_index), url(r'^sign_index_action/(?P
[0-9])/$',views.sign_index_action), url(r'^logout/$',views.logout), ] views.py
from django.shortcuts import render,get_object_or_404 from django.http import HttpResponse,HttpResponseRedirect from sign.models import Event,Guest from django.contrib.auth.decorators import login_required from django.contrib import auth from django.core.paginator import Paginator,EmptyPage,PageNotAnInteger # Create your views here. #首页 def index(request):     return render(request, 'index.html')     #return HttpResponse('Hello Django!') ''' #cookie #登录动作 def login_action(request):     if request.method == 'POST':         username = request.POST.get('username','')         password = request.POST.get('password','')         if username == 'admin' and password == 'admin123':             response = HttpResponseRedirect('/event_manage/')             response.set_cookie('user',username,3600)             return response         else:             return render(request,'index.html',{'error':'username or password error!'})     else:         return render(request,'index.html',{'error':'username or password error!'}) #发布会管理 def event_manage(request):     username = request.COOKIES.get('user','')     return render(request,'event_manage.html',{'user':username}) ''' ''' #认证登录  使用 admin 管理后台创建用户账户来验证登录功能 def login_action(request):     if request.method == 'POST':         username = request.POST.get('username','')         password = request.POST.get('password','')         user = auth.authenticate(username=username,password=password)         if user is not None:             auth.login(request,user)             request.session['user'] = username             response = HttpResponseRedirect('/event_manage')             return response         else:             return render(request,'index.html',{'error':'username or password error!'})     else:         return render(request,'index.html',{'error':'username or password error!'}) ''' #session #登录动作 def login_action(request):     if request.method == 'POST':         username = request.POST.get('username','')         password = request.POST.get('password','')         if username == 'admin' and password == 'admin123':             response = HttpResponseRedirect('/event_manage')             request.session['user'] = username             return response         else:             return render(request,'index.html',{'error':'username or password error!'})     else:         return render(request,'index.html',{'error':'username or password error!'}) #发布会管理 #@login_required  #【备注】不注释就总是跳到登录页,不知道为啥 def event_manage(request):     event_list = Event.objects.all()     username = request.session.get('user','')     return render(request,'event_manage.html',{'user':username,'events':event_list}) #发布会名称搜索 #@login_required def search_name(request):     username = request.session.get('user','')     search_name = request.GET.get('name','')     event_list = Event.objects.filter(name__contains=search_name)     return render(request,'event_manage.html',{'user':username,'events':event_list}) #嘉宾管理 #@login_required def guest_manage(request):     username = request.session.get('user','')     guest_list = Guest.objects.all()     paginator = Paginator(guest_list,2)     page = request.GET.get('page')     try:         contacts = paginator.page(page)     except PageNotAnInteger:         # If page is not an integer,deliver first page.         contacts = paginator.page(1)     except EmptyPage:         # If page is out of range (e.g.9999),deliver last page os results.         contacts = paginator.page(paginator.num_pages)     return render(request,'guest_manage.html',{'user':username,'guests':contacts}) #签到页面 #@login_required def sign_index(request,event_id):     event = get_object_or_404(Event,id=event_id)     return render(request,'sign_index.html',{'event':event}) #签到功能 #@login_required def sign_index_action(request,event_id):     event = get_object_or_404(Event,id=event_id)     phone = request.POST.get('phone','')     result = Guest.objects.filter(phone=phone)     if not result:         return render(request,'sign_index.html',{'event':event,'hint':'phone error.'})     result = Guest.objects.filter(phone=phone,event_id=event_id)     if not result:         return render(request,'sign_index.html',{'event':event,'hint':'event id or phone error.'})     result = Guest.objects.get(phone=phone,event_id=event_id)     if result.sign:         return render(request,'sign_index.html',{'event':event,'hint':'user has sign in.'})     else:         Guest.objects.filter(phone=phone,event_id=event_id).update(sign = '1')         return render(request,'sign_index.html',{'event':event,'hint':'sign in success','guest':result}) #退出登录 #@login_required def logout(request):     auth.logout(request)     response = HttpResponseRedirect('/index/')     return response templates/event_manage.html
  {% load bootstrap3 %} {% bootstrap_css %} {% bootstrap_javascript %} Guest Manage   
{% for event in events %}
{% endfor %}
id 名称 状态 地址 时间 签到
{ { event.id }} { { event.name }} { { event.status }} { { event.address }} { { event.start_time }} sign
templates/guest_manage.html
   {% load bootstrap3 %} {% bootstrap_css %} {% bootstrap_javascript %} Guest Manage     
{% for guest in guests %}
{% endfor %}
id 名称 手机 Email 签到 发布会
{ {guest.id}} { {guest.realname}} { {guest.phone}} { {guest.email}} { {guest.sign}} { {guest.event}}
index.html
       
Django Page

发布会管理

{
{ error }}
templates/sign_index.html
   {% load bootstrap3 %} {% bootstrap_css %} {% bootstrap_javascript %} 签到    
 
 

 

转载于:https://www.cnblogs.com/suren2017/p/7603276.html

你可能感兴趣的文章
Mysql与Oracle 的对比
查看>>
jquery实现限制textarea输入字数
查看>>
Codeforces 719B Anatoly and Cockroaches
查看>>
jenkins常用插件汇总
查看>>
c# 泛型+反射
查看>>
第九章 前后查找
查看>>
Python学习资料
查看>>
jQuery 自定义函数
查看>>
jquery datagrid 后台获取datatable处理成正确的json字符串
查看>>
ActiveMQ与spring整合
查看>>
web服务器
查看>>
轻松学MVC4.0–6 MVC的执行流程
查看>>
redis集群如何清理前缀相同的key
查看>>
Python 集合(Set)、字典(Dictionary)
查看>>
获取元素
查看>>
proxy写监听方法,实现响应式
查看>>
第一阶段冲刺06
查看>>
EOS生产区块:解析插件producer_plugin
查看>>
mysql重置密码
查看>>
jQuery轮 播的封装
查看>>