Django开发的简易留言板案例详解

Edana ·
更新时间:2024-11-15
· 600 次阅读

本文实例讲述了Django开发的简易留言板。分享给大家供大家参考,具体如下:

Django在线留言板小练习

环境

ubuntu16.04 + python3 + django1.11

1、创建项目

django-admin.py startproject message

进入项目message

2、创建APP

python manager.py startapp guestbook

项目结构

.
├── guestbook
│   ├── admin.py
│   ├── apps.py
│   ├── __init__.py
│   ├── migrations
│   │   └── __init__.py
│   ├── models.py
│   ├── tests.py
│   └── views.py
├── manage.py
└── message
    ├── __init__.py
    ├── __pycache__
    │   ├── __init__.cpython-35.pyc
    │   └── settings.cpython-35.pyc
    ├── settings.py
    ├── urls.py
    └── wsgi.py

4 directories, 14 files

需要做的事:

配置项目setting 、初始化数据库、配置url 、编写views 、创建HTML文件

项目配置

打开message/settings.py

设置哪些主机可以访问,*代表所有主机

ALLOWED_HOSTS = ["*"] INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'guestbook', #刚刚创建的APP,加入到此项目中 ] #数据库默认用sqlite3,后期可以换成MySQL或者SQL Server等 TIME_ZONE = 'PRC' #时区设置为中国

创建数据库字段

#encoding: utf-8 from django.db import models class Message(models.Model): username=models.CharField(max_length=256) title=models.CharField(max_length=512) content=models.TextField(max_length=256) publish=models.DateTimeField() #为了显示 def __str__(self): tpl = '<Message:[username={username}, title={title}, content={content}, publish={publish}]>' return tpl.format(username=self.username, title=self.title, content=self.content, publish=self.publish)

初始化数据库

# 1. 创建更改的文件 root@python:/online/message# python3 manage.py makemigrations Migrations for 'guestbook': guestbook/migrations/0001_initial.py - Create model Message # 2. 将生成的py文件应用到数据库 root@python:/online/message# python3 manage.py migrate Operations to perform: Apply all migrations: admin, auth, contenttypes, guestbook, sessions Running migrations: Applying contenttypes.0001_initial... OK Applying auth.0001_initial... OK Applying admin.0001_initial... OK Applying admin.0002_logentry_remove_auto_add... OK Applying contenttypes.0002_remove_content_type_name... OK Applying auth.0002_alter_permission_name_max_length... OK Applying auth.0003_alter_user_email_max_length... OK Applying auth.0004_alter_user_username_opts... OK Applying auth.0005_alter_user_last_login_null... OK Applying auth.0006_require_contenttypes_0002... OK Applying auth.0007_alter_validators_add_error_messages... OK Applying auth.0008_alter_user_username_max_length... OK Applying guestbook.0001_initial... OK Applying sessions.0001_initial... OK

配置url

设置项目message/urls.py

from django.conf.urls import url,include #添加了include from django.contrib import admin urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^guestbook/', include('guestbook.urls',namespace='guestbook')), #表示在url地址中所有guestbook的都交给guestbook下面的url来处理,后面的逗号不要省略 ]

设置APP的url

如果是初次创建APP,urls.py在APP中一般不存在,创建即可

vim guestbook/urls.py

# 内容如下 from django.conf.urls import url from . import views urlpatterns = [ url(r'^index/',views.index,name='index'), #不要忘了逗号 ]

编写views

编辑APP中的views.py

from django.shortcuts import render from django.http import HttpResponseRedirect from . import models # Create your views here. def index(request): messages = models.Message.objects.all() return render(request, 'guestbook/index.html', {'messages' : messages})

编写HTML文件

创建APP/templates/guestbook/index.html目录及文件

使用bootstrap美化了

<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>留言板</title> <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow" crossorigin="anonymous"> </head> <body> <table class="table table-striped table-bordered table-hover table-condensed"> <thead> <tr class="danger"> <th>留言时间</th> <th>留言者</th> <th>标题</th> <th>内容</th> </tr> </thead> <tbody> {% if messages %} {% for message in messages %} <tr class="{% cycle 'active' 'success' 'warning' 'info' %}"> <td>{{ message.publish|date:'Y-m-d H:i:s' }}</td> <td>{{ message.username }}</td> <td>{{ message.title }}</td> <td>{{ message.content }}</td> </tr> {% endfor %} {% else %} <tr> <td colspan="4">无数据</td> </tr> {% endif %} </tbody> </table> <a class="btn btn-xs btn-info" href="/guestbook/create/" rel="external nofollow" >去留言</a> </body> </html>

调试index页面

python manage.py runserver 0.0.0.0:99

打开浏览器访问http://开发机器ip地址:99/guestbook/index/

留言展示页面成功

创建留言页面

<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>留言</title> <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow" crossorigin="anonymous"> </head> <body> <!-- 我是注释 --> <h3>留言</h3> <!--h1-> h6--> <!--method: POST /GET --> <form action="/guestbook/save/" method="POST" novalidate="novalidate"> {% csrf_token %} <table class="table table-striped table-bordered table-hover table-condensed"> <label>用户名:</label> <input type="text" name="username" placeholder="用户名" /> <br /><br /> <label>标 题:</label> <input type="text" name="title" placeholder="标题" /><br /><br /> <label>内 容:</label> <textarea name="content" placeholder="内容"> </textarea><br /><br /> </table> <input class="btn btn-success" type="submit" value="留言"/> </form> </body> </html>

配置APP下的url

vim guestbook/urls.py

urlpatterns = [ url(r'^index/',views.index,name='index'), #不要忘了逗号 url(r'^create/$', views.create, name='create'), url(r'^save/$', views.save, name='save'), ]

编辑views.py

#先导入时间模块 import datetime #添加create、save def create(request): return render(request, 'guestbook/create.html') def save(request): username = request.POST.get("username") title = request.POST.get("title") content = request.POST.get("content") publish = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S") message = models.Message(title=title, content=content, username=username, publish=publish) message.save() return HttpResponseRedirect('/guestbook/index/')

OK,再次运行,enjoy it!

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

您可能感兴趣的文章:Python+Django搭建自己的blog网站Python之Web框架Django项目搭建全过程搭建Python的Django框架环境并建立和运行第一个App的教程Django+Vue.js搭建前后端分离项目的示例给Python的Django框架下搭建的BLOG添加RSS功能的教程Python使用django搭建web开发环境详解Django项目中模板标签及模板的继承与引用(网站中快速布置广告)用Django写天气预报查询网站Python3+django2.0+apache2+ubuntu14部署网站上线的方法Django框架实现的普通登录案例【使用POST方法】Django框架搭建的简易图书信息网站案例



django开发 Django

需要 登录 后方可回复, 如果你还没有账号请 注册新账号