Web开发Python实现Web服务器(web2py)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Web开发Python实现Web服务器(web2py)相关的知识,希望对你有一定的参考价值。
1、简介
官方地址: http://www.web2py.com
开发web应用的两个经典方法是:
- 通过编程生成html代码。 早期的CGI脚本遵循第一种模型。
- 将代码嵌入HTML页面中。 下列脚本遵循第二种模型,例如php[php](代码用PHP编写,类似C语言)、ASP(代码用Visual Basic编写)以及JSP(代码用Java编写)脚本。
web2py由如下组件构成:
- 库(libraries):提供web2py核心功能,可通过编程访问。
- web服务器:Rocket WSGI web服务器。
- 管理(admin)应用:用于创建、设计和管理其它web2py应用。admin提供了一个完整的基于web的集成开发环境(IDE),用于开发web2py应用。它还包括其它功能,如基于web的测试和shell。
- 示例(examples)应用:包含文档和交互示例。应用示例是官方网站web2py.com的副本,并包含epydoc文档。
- 欢迎(welcome)应用:是其它应用的基本构建模板。默认时,它包含一个纯CSS层叠菜单和用户认证。 web2py鼓励开发人员将数据表达(Model)、数据表示(View)和应用工作流(Controller)分离。web2py中一个请求的典型工作流描述如下: web2py应用程序如下图所示:
- 模型 - 表示数据表和数据库表。
- 控制器 - 描述应用程序逻辑和工作流程。
- 视图 - 帮助渲染数据的显示。
- 语言 - 描述如何将应用程序中的字符string转换为各种支持的语言。
- 静态文件 - 不需要处理(如图像,CSS样式表等)。
- 关于和自述 - 项目的细节。
- 错误 - 存储应用程序生成的错误报告。
- 会话 - 存储与每个特定用户相关的信息。
- 数据库 - 存储SQLite数据库和其他表信息。
- 缓存 - 存储缓存的应用程序项。
- 模块 - 模块是其他可选的Python模块。
- 隐私 - 包含的文件由控制器访问,但不直接由开发人员访问。
- 上传 - 文件由模型访问,但不直接由开发人员访问。
2、下载和安装
http://www.web2py.com/examples/default/download
下载之后解压如下:
3、快速入门
在Windows操作系统上, 执行: web2py.exe 默认情况下,当执行完命令后,web2py会显示开始界面和一个控件让你设置administrator密码和网站启动的IP和端口地址。默认情况下web2py会启动在127.0.0.1:8000这个地址上(就是本机的8000端口),但你可以选择启动在可用的IP和端口上。你可以命令行查询可用的IP地址,在Windows上运行ipconfig,在OS X和Linux上运行ifconfig。当前我们假设web2py已经启动在本机的8000端口上(127.0.0.1:8000)。如果web2py启动在0.0.0.0:8000上则使用所有可用的网卡。
- 现在我们点击按钮start server:
- 点击按钮admin:
- 输入密码之后,点击登陆按钮:
这个页面显示所有安装在web2py上安装的应用,并且可以用admin账户管理。 web2py默认包含3个应用:
- 一个admin应用,就是你正在使用的。
- 一个examples应用,包含在线的文档和一个web2py主页的仿制品。
- 一个welcome应用,这是一个基本的模板用来制作其他应用。如果你创建新的应用,这个应用就是模板,包含欢迎界面。
在启动web2py应用程序之后,使用上述URL,我们可以使用管理界面创建一个新模块,例如“XiaoMu”。管理界面将要求密码进行认证,因为管理员拥有添加和编辑任何新的Web应用程序的所有权限。 让新应用程序的名称为“XiaoMu”。一旦创建了新的应用程序,用户被重定向到包含相应应用程序的视图,模型和控制器的页面。
用户可以通过提及以下URL来查看新创建的应用程序:http://127.0.0.1:8000/XiaoMu 默认情况下,用户可以在点击上述URL时查看以下屏幕。用于打印给定的网络应用程序的消息的“XiaoMu”,该变化在由default.py控制器。
# ---- example index page ----
def index():
response.flash = T("Hello World,爱看书的小沐!")
return dict(message=T(Welcome to web2py,爱看书的小沐!))
web2py包括执行创建,检索,更新和删除功能的应用程序。该CRUD周期描述了一个数据库,这是执着的基本功能。所有的应用程序逻辑都写在模型中,这些模型由控制器检索并在视图的帮助下显示给用户。 web2py提供了一个用于管理,创建和删除表或数据库的界面,这被称为“appadmin”。在实现表背后的逻辑之前,有必要创建数据库及其关联的表。 访问appadmin的URL:http://127.0.0.1:8000/XiaoMu/appadmin 在点击URL时,用户将获得与给定应用程序关联的表的列表。 在前面,我们已经学会了如何使用GUI部件启动web2py服务器。 可以通过从命令行提示符启动服务器来跳过此窗口。
python web2py.py -a"你的密码"-i 127.0.0.1 -p 8000
每当web2py服务器启动时,它都会创建一个文件“ parameters_8000.py ”,其中所有密码都以散列形式存储。为了更安全的目的,可以使用以下命令行 -
python web2py.py -a "<recycle>" -i 127.0.0.1 -p 8000
4、示例测试
4.1 Say hello
- default.py修改如下(Controller):
def index():
return dict(message=T(Welcome to web2py,爱看书的小沐!))
- default/index.html修改如下(View): For debugging purposes you can always append:=response.toolbar()
<html>
<head></head>
<body>
=message
</body>
</html>
- 浏览器访问如下:
4.2 Lets count
- default.py修改如下(Controller):
def index():
if not session.counter:
session.counter = 1
else:
session.counter += 1
return dict(message="Welcome to web2py,爱看书的小沐!", counter=session.counter)
- default/index.html修改如下(View):
<html>
<head></head>
<body>
=message
<h2>Number of visits: =counter</h2>
</body>
</html>
- 浏览器访问如下:
4.3 Say my name
- default.py修改如下(Controller):
def first():
return dict()
def second():
return dict()
- 新增default/first.html如下(View):
extend layout.html
What is your name?
<form action="second">
<input name="visitor_name" />
<input type="submit" />
</form>
- 新增default/second.html如下(View):
extend layout.html
Hello =request.vars.visitor_name
- 浏览器访问如下:
http://127.0.0.1:8000/XiaoMu/default/first
4.4 Postbacks
- default.py修改如下(Controller):
def first():
form = SQLFORM.factory(Field(visitor_name, requires=IS_NOT_EMPTY()))
if form.process().accepted:
session.visitor_name = form.vars.visitor_name
redirect(URL(second))
return dict(form=form)
def second():
return dict()
- 新增default/first.html如下(View):
extend layout.html
What is your name?
=form
- 新增default/second.html如下(View):
extend layout.html
Hello =session.visitor_name or "anonymous"
- 浏览器访问如下:
4.5 An image blog
创建一个新的应用:xiaomu_images, 然后编辑它。
- db.py修改如下(Model):
db = DAL("sqlite://storage.sqlite")
db.define_table(image,
Field(title, unique=True),
Field(file, upload),
format = %(title)s)
db.define_table(comment,
Field(image_id, db.image),
Field(author),
Field(email),
Field(body, text))
db.image.title.requires = IS_NOT_IN_DB(db, db.image.title)
db.comment.image_id.requires = IS_IN_DB(db, db.image.id, %(title)s)
db.comment.author.requires = IS_NOT_EMPTY()
db.comment.email.requires = IS_EMAIL()
db.comment.body.requires = IS_NOT_EMPTY()
db.comment.image_id.writable = db.comment.image_id.readable = False
浏览器访问:http://127.0.0.1:8000/xiaomu_images/appadmin 依次通过界面添加图片记录到数据库中:
- default.py修改如下(Controller):
def index():
images = db().select(db.image.ALL, orderby=db.image.title)
return dict(images=images)
def show():
image = db(db.image.id==request.args(0)).select().first()
db.comment.image_id.default = image.id
form = SQLFORM(db.comment)
if form.process().accepted:
response.flash = your comment is posted
comments = db(db.comment.image_id==image.id).select()
return dict(image=image, comments=comments, form=form)
def download():
return response.download(request, db)
- 新增default/show.html(View):
extend layout.html
Image: =image.title
<center>
<img width="200px"
src="=URL(download, args=image.file)" />
</center>
if len(comments):
<h2>Comments</h2><br /><p>
for comment in comments:
<p>=comment.author says <i>=comment.body</i></p>
pass</p>
else:
<h2>No comments posted yet</h2>
pass
<h2>Post a comment</h2>
=form
- 浏览器访问:http://127.0.0.1:8000/xiaomu_images/default/show/1
5、PythonAnywhere
- (1)打开web2py首页
http://web2py.com/
- (2)点击按钮:try it now online
- (3)填写用户名后,点击give me my web2py
- 访问网址如下:http://xiaomu.pythonanywhere.com/welcome/default/index
结语
如果您觉得该方法或代码有一点点用处,可以给作者点个赞,或打赏杯咖啡;
╮( ̄▽ ̄)╭
如果您感觉方法或代码不咋地
//(ㄒoㄒ)//,就在评论处留言,作者继续改进;
o_O???
如果您需要相关功能的代码定制化开发,可以留言私信作者;
(✿◡‿◡)
感谢各位大佬童鞋们的支持!
( ´ ▽´ )ノ ( ´ ▽´)っ!!!
以上是关于Web开发Python实现Web服务器(web2py)的主要内容,如果未能解决你的问题,请参考以下文章