Django开发的简易留言板案例详解
作者:Yort2016 发布时间:2022-05-05 00:24:40
本文实例讲述了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.py4 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程序设计有所帮助。
来源:https://blog.csdn.net/Yort2016/article/details/73504445


猜你喜欢
- 前言对程序员来说,‘python’ 和’python ’看起
- 这段时间在爬取了杭州某网站发布的二手房信息,在作图的时候发现在地图呈现上还是有欠缺,这里就把用到的贴出来,提升一下记忆。之前有接触用Base
- Master Master数据库保存有放在SQLSERVER实体上的所有数据库,它还是将引擎固定起来的粘合剂。由于如果不使用主数据库,SQL
- 界面文件 Ui_ControlBoard.py# -*- coding: utf-8 -*-# Form implementation ge
- 内容摘要:本文介绍了使用CSS结合javascript来实现对超链接的类型进行标注,让浏览者明确是zip,doc,pdf或其它格式的文件。这
- 本文记录了Anaconda2安装NLTK的方法,供大家参考,具体内容如下先看我的python和Anaconda版本启动anaconda命令窗
- 本文实例讲述了Python排序搜索基本算法之希尔排序。分享给大家供大家参考,具体如下:希尔排序是插入排序的扩展,通过允许非相邻的元素进行交换
- 我在跑爬虫程序的时候,由于爬虫程序的等待目标服务器返回数据的时间很长,而cpu占用很低,所以经常挂着代理一跑就跑好几百个。但是爬虫程序通常是
- 因此,在数据库的日常维护工作中,如果只是一次两次碰到ORA-01555错误,一般都先忽略,但是如果经常碰到该错误,则要进行一些调整以避免该错
- 本文实例为大家分享了js实现简单放大镜效果的具体代码,供大家参考,具体内容如下效果效果,鼠标在原图片移动,黄色小盒子跟随鼠标移动,黄色小盒子
- ASP给图片加水印是需要组件的...常用的有aspjpeg软件和中国人自己开发的wsImage软件,可以上网搜索下载这两个软件,推荐使用咱们
- 之前安装mysql 5.7.12时未做总结,换新电脑,补上安装记录,安装的时候,找了些网友的安装记录,发现好多坑(一)mysql 5.7.1
- RPCHandler 和 R * roxy 的基本思路是很比较简单的。 如果一个客户端想要调用一个远程函数,比如 foo(1, 2, z=3
- 第一个保存在新建一个文本中<% Dim Username,PassWord,strLogFile,f,ff,Str
- Tensorflow是目前最流行的深度学习框架,我们可以用它来搭建自己的卷积神经网络并训练自己的分类器,本文介绍怎样使用Tensorflow
- 1、下载官网:https://dev.mysql.com/downloads/installer/2、安装(1)双击 mysql-insta
- 本是一个自己知道的问题,还是差点踩坑(差点忘了,还好上线前整理上线点时想起来了),特此记录下来为什么要更新自增id我是因为历史业务上的坑,导
- 在应用系统中,尤其在联机事务处理系统中,对数据查询及处理速度已成为衡量应用系统成败的标准。而采用索引来加快数据处理速度也成为广大数据库用户所
- 前言:WebDriver提供了两个关闭浏览器的方法,一个是前边使用quit()方法,另一个是close()方法close():关闭当前窗口q
- 前言:微信H5项目,ios端出现了软键盘输完隐藏后页面不会回弹,下方会有一大块留白最近微信和ios都有版本升级,不知道是哪边升级造成的,但是