這篇博文會詳細的介紹如何建立django工程,介紹我如何作了第一個網站。本文基於windows7安裝了python2.7.12,Django1.8.18(LTS)版。採用的IDE爲pycharm。建議安裝Django的時候採用pip安裝,由於可能本身電腦環境缺乏哪一個包的話,pip能給你安裝徹底。命令是javascript
1 pip install django==1.8.18
本文的目的是創建一個小網站,可以在測試過程當中隨時記錄所出現的bug,網站命名爲Buglist,根據描述,便知道主要的用途就是和數據庫交互,而且是在Linux服務器上部署,因此採用mysql數據庫,而且還要記錄是誰進行登錄,記錄這些bug,因此要用django的後臺管理頁面。so,建立一個buglist工程吧。css
讓咱們看看Django項目的結構:html
1 |- buglist/ 2 |- manage.py 3 |- templates/ 4 |- buglist/ 5 |- __init__.py 6 |- settings.py 7 |- urls.py 8 |- wsgi.py
manage.py: 一個命令行交互文件,用於顯示項目的運行狀況,不用對這個文件作任何修改。java
在工程中新建文件夾python
此時須要在settings.py文件中修改幾個地方,數據庫mysql
1 DATABASES = { 2 'default': { 3 'ENGINE': 'django.db.backends.mysql', 4 'NAME': 'buglist', 5 'USER':'buglist', 6 'PASSWORD':'buglist', 7 'HOST':'', ----此處默認即爲本地數據庫 8 'PORT':'', -----此處默認即爲mysql默認端口 9 } 10 }
時區及靜態文件夾的設置jquery
1 TIME_ZONE = 'Asia/Shanghai' 2 3 4 STATIC_URL = '/static/' 5 STATIC_ROOT = os.path.join(BASE_DIR,'static') 6 STATICFILES_DIRS = ('static/css', 7 'static/bootstrap', 8 'static/images', 9 'static/js', 10 )
建立一個app handle 能夠採用tool --> Run manage.py Task 來建立或者採用python manage.py startapp handle來建立,不要忘記在settings.py中添加web
1 INSTALLED_APPS = ( 2 'django.contrib.auth', 3 'django.contrib.contenttypes', 4 'django.contrib.sessions', 5 'django.contrib.messages', 6 'django.contrib.staticfiles', 7 'handle', 8 )
首先完成前段部分,login.html,採用POST的方式日後臺傳輸數據,採用了boostrap,簡單易用,而且採用了模板語言ajax
1 <!Doctype html> 2 {% load staticfiles %} 3 <html> 4 <head> 5 <meta http-equiv=Content-Type content="text/html;charset=utf-8"> 6 <meta name="description" content="BugList"> 7 <link rel="icon" href="{% static "images/favicon.ico" %}" type="image/x-icon"/> 8 <link rel="stylesheet" href="{% static "login.css" %}" type="text/css"/> 9 <link rel="stylesheet" href="{% static "css/bootstrap.min.css"%}" type="text/css"/> 10 <title>BugList</title> 11 </head> 12 <body> 13 <div class="container"> 14 <div class="row"> 15 <div class="col-sm-6 col-md-4 col-md-offset-4"> 16 <div class="account-wall"> 17 <h1 class="text-center login-title">Sign in to continue</h1> 18 <form class="form-signin" method="POST" action="/login/"> 19 {% csrf_token %} 20 <input name="user" type="user" class="form-control" id="user" placeholder="Username" required autofocus> 21 <input name="password" type="password" class="form-control" id= 'password' placeholder="Password" required> 22 <button class="btn btn-lg btn-primary btn-block" type="submit" id="">Sign in</button> 23 <p style="color: red;text-align: center;"> {{ loginstatus }} </p> 24 </form> 25 26 </div> 27 </div> 28 </div> 29 </div> 30 31 <script type="text/javascript" src="{% static "jquery-3.2.0.min.js" %}" ></script> 32 <script type="text/javascript" src="{% static "js/bootstrap.min.js" %}"></script> 33 </body> 34 </html>
web模板,採用模板語言的話就是擴展性比較好,layout.htmlsql
1 <!DOCTYPE html> 2 {% load staticfiles %} 3 <html lang="en"> 4 <head> 5 <meta charset="utf-8"> 6 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 7 <meta name="viewport" content="width=device-width, initial-scale=1"> 8 <meta name="description" content=""> 9 <meta name="author" content=""> 10 <link rel="icon" href="{% static "favicon.ico" %} " type="image/x-icon" /> 11 12 <title>BugList</title> 13 14 <!-- Bootstrap core CSS --> 15 <link href="{% static "css/bootstrap.min.css" %}" rel="stylesheet" type="text/css"/> 16 <!-- Custom styles for this template --> 17 <link href="{% static "dashboard.css" %}" rel="stylesheet" type="text/css"/> 18 <link href="{% static "custom.css" %}" rel="stylesheet" type="text/css"/> 19 {% block css %} 20 {% endblock %} 21 </head> 22 23 <body> 24 25 <nav class="navbar navbar-inverse navbar-fixed-top"> 26 <div class="container-fluid"> 27 <div class="navbar-header"> 28 <div class="navbar-brand"><a style='text-decoration:none;' href="/">BugList</a></div> 29 </div> 30 <div id="navbar" class="navbar-collapse collapse"> 31 <ul class="nav navbar-nav navbar-right"> 32 <li class="dropdown"> 33 {% if user.is_active %} 34 <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false" id="login_user">{{ user.username }}<span class="caret"></span></a> 35 <ul class="dropdown-menu"> 36 <li><a href="/logout/">logout</a></li> 37 </ul> 38 {% endif %} 39 </li> 40 </ul> 41 </div> 42 </div> 43 </nav> 44 45 <div class="container-fluid"> 46 <div class="row"> 47 <div class="col-sm-2 col-md-2 sidebar"> 48 <ul class="nav nav-sidebar" id="bar"> 49 <li ><a href="/overview/">Overview</a></li> 50 <li ><a href="/search/" >Search Errors</a></li> 51 <li ><a href="/record/" >Record Errors</a></li> 52 </ul> 53 </div> 54 <div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 main"> 55 {% block con %} 56 {% endblock %} 57 </div> 58 </div> 59 </div> 60 <script src="{% static "jquery-3.2.0.min.js" %}"></script> 61 <script src="{% static "js/bootstrap.min.js"%}"></script> 62 <script src="{% static "custom.js" %}"></script> 63 {% block js %} 64 {% endblock %} 65 </body> 66 </html>
登錄首頁,index.html
1 {% extends "web/layout.html" %} 2 {% block con %} 3 <h1>Welcome to BugList Service</h1> 4 {% endblock %}
概覽頁面 overview.html
1 {% extends "web/layout.html" %} 2 {% block con %} 3 <h2 class="sub-header">Overviews</h2> 4 <div class="table-responsive"> 5 <table class="table table-striped"> 6 <thead> 7 <tr> 8 <th>numbers</th> 9 <th>title</th> 10 <th>auther</th> 11 <th>time</th> 12 </tr> 13 </thead> 14 <tbody> 15 {% for record in context_obj %} 16 <tr> 17 <th><a href="/deltails/{{record.id }}">{{ record.id }}</a> </th> 18 <th>{{ record.title }}</th> 19 <th>{{ record.auther }}</th> 20 <th>{{ record.time }}</th> 21 </tr> 22 {% endfor %} 23 </tbody> 24 25 26 </table> 27 </div> 28 29 {% endblock %}
記錄頁面 record.html
1 {% extends "web/layout.html" %} 2 {% load staticfiles %} 3 4 {% block css %} 5 <link href="{% static "dcalendar.picker.css" %}" rel="stylesheet"/> 6 {% endblock %} 7 8 9 {% block con %} 10 <h2 class="sub-header">Record</h2> 11 <div class="container" id = "record"> 12 <div class="form-group"> 13 <label for="time">  title  </label> 14 <input type="text" id="title" size="30" name="title"/> 15 </div> 16 <div class="form-group"> 17 <label for="details">details</label> 18 <br/> 19 <textarea name="details" cols="100" rows="5" id="details"></textarea> 20 </div> 21 <div class="checkbox"> 22 <label><input type="checkbox" />Check me out</label> 23 </div> 24 <button type="submit" class="btn btn-default" id="Submit">Submit</button> 25 </div> 26 27 28 {% endblock %} 29 30 {% block js %} 31 <script type="text/javascript"> 32 $(function () { 33 $("#Submit").click(function () { 34 var myDate = new Date(); 35 var time = myDate.toLocaleDateString().replace(/\//g,"-"); 36 var title = $("#title").val(); 37 var details = $("#details").val(); 38 if ((title && title.trim()) && (details && details.trim())){ 39 data = {'title':title,'details':details,'time':time}; 40 AjaxRequest('/counts/',data,null); 41 $("#title").val(""); 42 $("#details").val("") ; 43 } 44 }); 45 }); 46 </script> 47 {% endblock %}
詳情頁面 details.html
1 {% extends "web/layout.html" %} 2 {% block con %} 3 <h2 class="sub-header">Deltails</h2> 4 <div class="blog-header"> 5 <h1 class="blog-title">{{ record.title }}</h1> 6 <p class="lead blog-description">      auther: {{ record.auther }}</p> 7 <p class="lead blog-description">      time: {{ record.time }}</p> 8 <p class="lead blog-description">  details: </p> 9 <hr/> 10 <p> 11 {{ record.details }} 12 </p> 13 </div> 14 15 {% endblock %}
搜索頁面 search.html
1 {% extends "web/layout.html" %} 2 {% load staticfiles %} 3 {% block css %} 4 <link rel="stylesheet" href="{% static "dcalendar.picker.css" %}"/> 5 {% endblock %} 6 {% block con %} 7 <h2 class="sub-header">Search</h2> 8 <div class="container"> 9 <div id="div_to_search"> 10 <label for="Auther">Auther</label> 11 <input type="text" name="Auther" id="Auther_to_serach" /> 12 <label for="StartTime">StartTime</label> 13 <input type="text" name="StartTime" id="StartTime" /> 14 <label for="EndTime">EndTime</label> 15 <input type="text" name="EndTime" id="EndTime"/> 16 <label for="Type"> Type</label> 17 <select name="Type" id="Type"> 18 <option value='All'>All</option> 19 <option value='Solved'>Solved</option> 20 <option value='Unsolved'>Unsolved</option> 21 </select> 22 <input style="width:60px;cursor:pointer;" type="submit" value='Check' id="Check"/> 23 </div> 24 <hr/> 25 <div class="table-responsive"> 26 <table class="table table-striped"> 27 <thead> 28 <tr> 29 <th>numbers</th> 30 <th>title</th> 31 <th>auther</th> 32 <th>time</th> 33 </tr> 34 </thead> 35 <tbody id="tbody"> 36 </tbody> 37 38 39 </table> 40 </div> 41 </div> 42 43 44 {% endblock %} 45 {% block js %} 46 <script type="text/javascript" src="{% static "dcalendar.picker.js" %}"></script> 47 <script type="text/javascript"> 48 $('#StartTime').dcalendarpicker({ 49 format:'yyyy-mm-dd' 50 }); 51 $('#EndTime').dcalendarpicker({ 52 format:'yyyy-mm-dd' 53 }); 54 function callback(arg) { 55 document.getElementById("tbody").innerHTML = arg; 56 } 57 $(function () { 58 $("#Check").click(function () { 59 var data = {}; 60 var count = 0; 61 $("#div_to_search :text").each(function () { 62 data[$(this).attr('name')] = $(this).val(); 63 $(this).val(""); 64 }); 65 //data['Type']=$("#div_to_search :selected").val(); 66 $.each(data,function (i,item) { 67 if (!item){ 68 count++; 69 } 70 }); 71 if(count>2){ 72 alert('you must input at least one parameters'); 73 return false; 74 } 75 var st = data['StartTime']; 76 var et = data['EndTime']; 77 if ( st && et ){ 78 if (tab(st,et)){ 79 AjaxRequest("/search/",data,callback); 80 } 81 else{ 82 alert('the time you input is not correct!'); 83 } 84 }else{ 85 AjaxRequest("/search/",data,callback); 86 } 87 }); 88 }); 89 </script> 90 {% endblock %}
我的寫的js代碼 custom.js
1 /** 2 * Created by sumoning on 2017/4/17. 3 */ 4 5 function AjaxRequest(url,data,func) { 6 $.ajax({ 7 type: 'POST', 8 url: url, 9 data:data, 10 cache: false, 11 async: true, 12 success: func 13 }); 14 } 15 /* 16 $(function () { 17 $("#bar").children().click(function () { 18 $(this).parent().children().removeClass('active'); 19 $(this).addClass('active'); 20 }); 21 });*/ 22 23 function tab(date1,date2){ 24 var oDate1 = new Date(date1); 25 var oDate2 = new Date(date2); 26 if(oDate1.getTime() > oDate2.getTime()){ 27 return false; 28 } else { 29 return true; 30 } 31 }
表的設計 model.py
1 #!/usr/bin/env python 2 #!_*_coding:utf-8_*_ 3 4 5 from django.db import models 6 from django.contrib.auth.models import User 7 8 # Create your models here. 9 10 11 class context(models.Model): 12 title = models.CharField(max_length=100) 13 auther = models.CharField(max_length=20) 14 time = models.DateField() 15 details = models.TextField()
主url設計 buglist/url.py
1 """buglist URL Configuration 2 3 The `urlpatterns` list routes URLs to views. For more information please see: 4 https://docs.djangoproject.com/en/1.8/topics/http/urls/ 5 Examples: 6 Function views 7 1. Add an import: from my_app import views 8 2. Add a URL to urlpatterns: url(r'^$', views.home, name='home') 9 Class-based views 10 1. Add an import: from other_app.views import Home 11 2. Add a URL to urlpatterns: url(r'^$', Home.as_view(), name='home') 12 Including another URLconf 13 1. Add a URL to urlpatterns: url(r'^blog/', include('blog.urls')) 14 """ 15 from django.conf.urls import include, url 16 from handle import urls 17 from django.contrib import admin 18 19 urlpatterns = [ 20 url(r'^admin/', include(admin.site.urls)), 21 url(r'',include(urls)), 22 ]
附屬url 設計buglist/handle/url.py
1 #!/usr/bin/env python 2 #!_*_coding:utf-8_*_ 3 4 from django.conf.urls import url 5 import views 6 7 urlpatterns = [ 8 url(r'^accounts/login/','django.contrib.auth.views.login',{'template_name':'login/login.html'}), 9 url(r'^login/',views.Login), 10 url(r'^logout/',views.Logout), 11 url(r'^overview/',views.Overview), 12 url(r'^deltails/(\d+)',views.Deltails), 13 url(r'^record/',views.Record), 14 url(r'^counts/',views.Counts), 15 url(r'^search/',views.Search), 16 url(r'^$',views.Index), 17 ]
視圖設計 buglist/handle/view.py
1 #/usr/bin/env python 2 #!_*_coding:utf-8_*_ 3 4 5 from django.shortcuts import render,render_to_response 6 from django.http import HttpResponse,HttpResponseRedirect 7 from django.contrib import auth 8 from django.contrib.auth.decorators import login_required 9 from django.template.context import RequestContext 10 from django.views.decorators.csrf import csrf_exempt 11 from models import context 12 import traceback 13 import datetime 14 from django.utils import timezone 15 from django.contrib.auth.models import User 16 17 18 # Create your views here. 19 20 21 def Login(request): 22 if request.user.is_authenticated(): 23 return HttpResponseRedirect('/') 24 data = {'loginstatus':'','user':''} 25 if request.method == "POST": 26 username = request.POST.get('user') 27 password = request.POST.get('password') 28 user = auth.authenticate(username=username,password=password) 29 if user is not None: 30 auth.login(request,user) 31 data['user'] = user 32 return HttpResponseRedirect('/') 33 data['loginstatus'] = 'your username or password id uncorrect!' 34 35 return render_to_response('login/login.html',data,context_instance=RequestContext(request)) 36 37 def Logout(request): 38 auth.logout(request) 39 return render_to_response('login/login.html',context_instance=RequestContext(request)) 40 41 42 @login_required 43 def Index(request): 44 return render_to_response('web/index.html',{'user':request.user}) 45 46 @login_required 47 def Overview(request): 48 context_obj = context.objects.all().order_by('-id') 49 return render_to_response('web/overview.html',{'context_obj':context_obj,'user':request.user}) 50 51 @login_required 52 def Deltails(request,id): 53 record = context.objects.get(id=id) 54 return render_to_response('web/details.html',{'record':record,'user':request.user}) 55 56 @login_required 57 def Record(request): 58 return render_to_response('web/record.html',{'user':request.user}) 59 60 @login_required 61 @csrf_exempt 62 def Counts(request): 63 title,time,details= request.POST.get('title'),request.POST.get('time'),request.POST.get('details') 64 try: 65 obj = context.objects.create(title=title,time=time,details=details,auther=request.user) 66 return render_to_response('web/record.html', {'user': request.user}) 67 except: 68 traceback.print_exc() 69 70 @login_required 71 @csrf_exempt 72 def Search(request): 73 if request.method == 'POST': 74 datas = {} 75 str = "" 76 get_data = request.POST 77 context_obj = None 78 for re in get_data: 79 if get_data.get(re): 80 datas[re] = get_data.get(re) 81 if len(datas.keys()) == 1 : 82 if 'Auther' in datas.keys(): 83 try: 84 context_obj = context.objects.filter(auther = datas['Auther']).order_by("-id") 85 except: 86 traceback.print_exc() 87 elif 'StartTime' in datas.keys(): 88 try: 89 st = datetime.datetime.strptime(datas['StartTime'], "%Y-%m-%d").date() 90 no = timezone.localtime(timezone.now()).strftime("%Y-%m-%d") 91 et = datetime.datetime.strptime(no,"%Y-%m-%d").date() 92 context_obj = context.objects.filter(time__range=(st, et)).order_by("-id") 93 except: 94 traceback.print_exc() 95 elif 'EndTime' in datas.keys(): 96 try: 97 st = datetime.datetime.strptime('2017-01-01', "%Y-%m-%d").date() 98 et = datetime.datetime.strptime(datas['EndTime'],"%Y-%m-%d").date() 99 context_obj = context.objects.filter(time__range=(st, et)).order_by("-id") 100 except: 101 traceback.print_exc() 102 else: 103 pass 104 elif len(datas.keys()) == 2: 105 if 'Auther' in datas.keys(): 106 if 'StartTime' in datas.keys(): 107 st = datetime.datetime.strptime(datas['StartTime'], "%Y-%m-%d").date() 108 no = timezone.localtime(timezone.now()).strftime("%Y-%m-%d") 109 et = datetime.datetime.strptime(no, "%Y-%m-%d").date() 110 try: 111 context_obj = context.objects.filter(auther=datas['Auther'],time__range=(st, et)).order_by("-id") 112 except: 113 traceback.print_exc() 114 elif 'EndTime' in datas.keys(): 115 try: 116 st = datetime.datetime.strptime('2017-01-01', "%Y-%m-%d").date() 117 et = datetime.datetime.strptime(datas['EndTime'], "%Y-%m-%d").date() 118 context_obj = context.objects.filter(auther=datas['Auther'],time__range=(st, et)).order_by("-id") 119 except: 120 traceback.print_exc() 121 else: 122 pass 123 else: 124 try: 125 st = datetime.datetime.strptime(datas['StartTime'], "%Y-%m-%d").date() 126 et = datetime.datetime.strptime(datas['EndTime'], "%Y-%m-%d").date() 127 context_obj = context.objects.filter(time__range=(st, et)).order_by("-id") 128 except: 129 traceback.print_exc() 130 else: 131 st = datetime.datetime.strptime(datas['StartTime'], "%Y-%m-%d").date() 132 et = datetime.datetime.strptime(datas['EndTime'], "%Y-%m-%d").date() 133 context_obj = context.objects.filter(auther=datas['Auther'],time__range=(st, et)).order_by("-id") 134 for re in context_obj: 135 str += "<tr>" 136 str += "<th><a href='/deltails/%d'>%d</a> </th>" % (re.id, re.id) 137 str += "<th>%s</th>" % (re.title) 138 str += "<th>%s</th>" % (re.auther) 139 str += "<th>%s</th>" % (re.time) 140 str += "<tr>" 141 return HttpResponse(str) 142 143 else: 144 return render_to_response("web/search.html",{'user':request.user})
ok,最後run就能夠啦