web.py 十分钟创建简易博客实现代码
作者:TCM-caleng 发布时间:2022-10-23 00:55:38
标签:web.py,简易博客
一、web.py简介
web.py是一款轻量级的Python web开发框架,简单、高效、学习成本低,特别适合作为python web开发的入门框架。官方站点:http://webpy.org/
二、web.py安装
1、下载:http://webpy.org/static/web.py-0.33.tar.gz
2、解压并进入web.py-0.33目录,安装:python setup.py install
三、创建简易博客
1、目录说明:主目录blog/,模板目录blog/templates
2、在数据库“test”中创建表“entries”
CREATE TABLE entries (
id INT AUTO_INCREMENT,
title TEXT,
content TEXT,
posted_on DATETIME,
primary key (id)
);
3、在主目录创建blog.py,blog/blog.py
#载入框架
import web
#载入数据库操作model(稍后创建)
import model
#URL映射
urls = (
'/', 'Index',
'/view/(/d+)', 'View',
'/new', 'New',
'/delete/(/d+)', 'Delete',
'/edit/(/d+)', 'Edit',
'/login', 'Login',
'/logout', 'Logout',
)
app = web.application(urls, globals())
#模板公共变量
t_globals = {
'datestr': web.datestr,
'cookie': web.cookies,
}
#指定模板目录,并设定公共模板
render = web.template.render('templates', base='base', globals=t_globals)
#创建登录表单
login = web.form.Form(
web.form.Textbox('username'),
web.form.Password('password'),
web.form.Button('login')
)
#首页类
class Index:
def GET(self):
login_form = login()
posts = model.get_posts()
return render.index(posts, login_form)
def POST(self):
login_form = login()
if login_form.validates():
if login_form.d.username == 'admin' /
and login_form.d.password == 'admin':
web.setcookie('username', login_form.d.username)
raise web.seeother('/')
#查看文章类
class View:
def GET(self, id):
post = model.get_post(int(id))
return render.view(post)
#新建文章类
class New:
form = web.form.Form(
web.form.Textbox('title',
web.form.notnull,
size=30,
description='Post title: '),
web.form.Textarea('content',
web.form.notnull,
rows=30,
cols=80,
description='Post content: '),
web.form.Button('Post entry'),
)
def GET(self):
form = self.form()
return render.new(form)
def POST(self):
form = self.form()
if not form.validates():
return render.new(form)
model.new_post(form.d.title, form.d.content)
raise web.seeother('/')
#删除文章类
class Delete:
def POST(self, id):
model.del_post(int(id))
raise web.seeother('/')
#编辑文章类
class Edit:
def GET(self, id):
post = model.get_post(int(id))
form = New.form()
form.fill(post)
return render.edit(post, form)
def POST(self, id):
form = New.form()
post = model.get_post(int(id))
if not form.validates():
return render.edit(post, form)
model.update_post(int(id), form.d.title, form.d.content)
raise web.seeother('/')
#退出登录
class Logout:
def GET(self):
web.setcookie('username', '', expires=-1)
raise web.seeother('/')
#定义404错误显示内容
def notfound():
return web.notfound("Sorry, the page you were looking for was not found.")
app.notfound = notfound
#运行
if __name__ == '__main__':
app.run()
4、在主目录创建model.py,blog/model.py
import web
import datetime
#数据库连接
db = web.database(dbn = 'MySQL', db = 'test', user = 'root', pw = '123456')
#获取所有文章
def get_posts():
return db.select('entries', order = 'id DESC')
#获取文章内容
def get_post(id):
try:
return db.select('entries', where = 'id=$id', vars = locals())[0]
except IndexError:
return None
#新建文章
def new_post(title, text):
db.insert('entries',
title = title,
content = text,
posted_on = datetime.datetime.utcnow())
#删除文章
def del_post(id):
db.delete('entries', where = 'id = $id', vars = locals())
#修改文章
def update_post(id, title, text):
db.update('entries',
where = 'id = $id',
vars = locals(),
title = title,
content = text)
5、在模板目录依次创建:base.html、edit.html、index.html、new.html、view.html
<!-- base.html -->
$def with (page)
<html>
<head>
<title>My Blog</title>
<mce:style><!--
#menu {
width: 200px;
float: right;
}
--></mce:style><style mce_bogus="1"> #menu {
width: 200px;
float: right;
}
</style>
</head>
<body>
<ul id="menu">
<li><a href="/" mce_href="">Home</a></li>
$if cookie().get('username'):
<li><a href="/new" mce_href="new">New Post</a></li>
</ul>
$:page
</body>
</html>
<!-- edit.html -->
$def with (post, form)
<h1>Edit $form.d.title</h1>
<form action="" method="post">
$:form.render()
</form>
<h2>Delete post</h2>
<form action="/delete/$post.id" method="post">
<input type="submit" value="Delete post" />
</form>
<!-- index.html -->
$def with (posts, login_form)
<h1>Blog posts</h1>
$if not cookie().get('username'):
<form action="" method="post">
$:login_form.render()
</form>
$else:
Welcome $cookie().get('username')!<a href="/logout" mce_href="logout">Logout</a>
<ul>
$for post in posts:
<li>
<a href="/view/$post.id" mce_href="view/$post.id">$post.title</a>
on $post.posted_on
$if cookie().get('username'):
<a href="/edit/$post.id" mce_href="edit/$post.id">Edit</a>
<a href="/delete/$post.id" mce_href="delete/$post.id">Del</a>
</li>
</ul>
<!-- new.html -->
$def with (form)
<h1>New Blog Post</h1>
<form action="" method="post">
$:form.render()
</form>
<!-- view.html -->
$def with (post)
<h1>$post.title</h1>
$post.posted_on<br />
$post.content
6、进入主目录在命令行下运行:python blog.py,将启动web服务,在浏览器输入:http://localhost:8080/,简易博客即已完成。


猜你喜欢
- 前言本文章仅记录某次内网渗透过程中遇到的MySQL 采用UDF提权等方式进行获取权限,文章中内容仅用于技术交流,切勿用于非授权下渗透攻击行为
- 1.什么是事务:事务是一个不可分割的工作逻辑单元,在数据库系统上执行并发操作时事务是做为最小的控制单元来使用的。 他
- df.sort_index()实现按索引排序,默认以从小到大的升序方式排列,如希望按降序排列,传入ascending = Falseimpo
- 在二维矩阵间的运算:class torch.nn.Conv2d(in_channels, out_channels, kernel_size
- 功能:读取txt文本,然后将目的字符串标红,再将处理过的字符串写入docx中txt文本内容:啊打发发烧鳌太路线点击点击诶的骄傲计划将鳌太标红
- python安装第三方库大都是通过pip命令安装,这个命令确实是很简便的,而对于每个独立的项目来说,需要用到的库或许会不同,如果删除或更新原
- 前不久微信上线了拍一拍功能,刚推出就被有才的网友玩坏了。还有更多没有节操的拍法这里就不展示了。但拍一拍属于弱提示,只有在聊天界面才能感受到。
- 有时候会出现索引问题,显示scanning files to index解决方法:in pycharm, go to the "F
- 最近想研究下SQL SERVER2012 Enterprise版本的数据库,听说功能很强大。我是在win7上安装的,安装的过程很顺利,我在用
- 网上我也见到一些分栏效果,也有一个jquery的插件jquery.splitter.js, 但是他们基本都没有解决一个问题:如果页面上有if
- 前言我们知道,enigma机是德军二战中重要的情报加密机器,其有许多特点。首先,它是一台加解密一体机其次,它有排己性,虽然多次输入同一明文可
- 目录前后端传输数据的编码格式Ajax提交urlencoded格式数据Ajax通过FormData上传文件Ajax提交Json格式数据Ajax
- 今天在设置input的readonly属性遇到问题,上网查到下面的内容,作个标记。今天系统需要使用javascript 动态设置textbo
- 本文基本使用谷歌翻译加上自己的理解,权当加深记忆。npm简介qs 是一个增加了一些安全性的查询字符串解析和序列化字符串的库。主要维护者:Jo
- 本文实例讲述了PHP检查端口是否可以被绑定的方法。分享给大家供大家参考,具体如下:<?php/** * 检查端口是否可以被绑定 * @
- 前言本文主要给大家介绍了关于laravel5异常错误FatalErrorException in Handler.php line 38的解
- Innodb:[fb]# ll -hs url_comment_*.ibd633M -rw-rw---- 1 mysql mysql 632
- 1、基本概念K近邻法(K-nearest neighbors,KNN)既可以分类,也可以回归。KNN做回归和分类的区别在于最后预测时的决策方
- 一、简介本篇文章将通过实现一个简易版的Web服务器,帮助读者理解Python网络编程的基本概念和技巧。我们将分为以下几个部分来展开本文的内容
- Flask-SQLAlchemy安装和建表操作请参考这里。 # Role表class Role(db.Model):