1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 【Web开发】Python实现Web服务器(web2py)

【Web开发】Python实现Web服务器(web2py)

时间:2021-04-28 14:29:37

相关推荐

【Web开发】Python实现Web服务器(web2py)

🍺基于Python的Web服务器系列相关文章编写如下🍺:

🎈【Web开发】Python实现Web服务器(Flask快速入门)🎈🎈【Web开发】Python实现Web服务器(Flask案例测试)🎈🎈【Web开发】Python实现Web服务器(Flask部署上线)🎈🎈【Web开发】Python实现Web服务器(Tornado入门)🎈🎈【Web开发】Python实现Web服务器(Tornado+flask+nginx)🎈🎈【Web开发】Python实现Web服务器(FastAPI)🎈🎈【Web开发】Python实现Web服务器(Bottle)🎈🎈【Web开发】Python实现Web服务器(Django)🎈🎈【Web开发】Python实现Web服务器(web2py)🎈🎈【Web开发】Python实现Web服务器(Sanic)🎈

文章目录

1、简介2、下载和安装3、快速入门4、示例测试4.1 Say hello4.2 Let's count4.3 Say my name4.4 Postbacks4.5 An image blog5、PythonAnywhere结语

1、简介

官方地址:

免费开源全栈框架,快速开发,可扩展,安全和可移植数据库驱动的基于 Web 的应用程序。编写和编程 Python (版本 3 和 2.7)。

web2py是一种免费的、开源的web开发框架,用于敏捷地开发安全的、数据库驱动的web应用;web2py采用Python语言编写,并且可以使用Python编程。web2py是一个完整的堆栈框架,也就是说它包含了开发完整功能的web应用所需的所有组件。

web2py支持CPython(C语言实现)或Jython(Java语言实现)。

开发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)应用:包含文档和交互示例。应用示例是官方网站的副本,并包含epydoc文档。欢迎(welcome)应用:是其它应用的基本构建模板。默认时,它包含一个纯CSS层叠菜单和用户认证。

web2py鼓励开发人员将数据表达(Model)、数据表示(View)和应用工作流(Controller)分离。web2py中一个请求的典型工作流描述如下:

web2py应用程序如下图所示:模型 - 表示数据表和数据库表。控制器 - 描述应用程序逻辑和工作流程。视图 - 帮助渲染数据的显示。语言 - 描述如何将应用程序中的字符string转换为各种支持的语言。静态文件 - 不需要处理(如图像,CSS样式表等)。关于和自述 - 项目的细节。错误 - 存储应用程序生成的错误报告。会话 - 存储与每个特定用户相关的信息。数据库 - 存储SQLite数据库和其他表信息。缓存 - 存储缓存的应用程序项。模块 - 模块是其他可选的Python模块。隐私 - 包含的文件由控制器访问,但不直接由开发人员访问。上传 - 文件由模型访问,但不直接由开发人员访问。

2、下载和安装

/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><h1>{{=message}}</h1></body></html>

浏览器访问如下:

4.2 Let’s count

default.py修改如下(Controller):

def index():if not session.counter:session.counter = 1else:session.counter += 1return dict(message="Welcome to web2py,爱看书的小沐!", counter=session.counter)

default/index.html修改如下(View):

<html><head></head><body><h1>{{=message}}</h1><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'}}<h1>Hello {{=request.vars.visitor_name}}</h1>

浏览器访问如下:

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_nameredirect(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'}}<h1>Hello {{=session.visitor_name or "anonymous"}}</h1>

浏览器访问如下:

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)ment.image_id.requires = IS_IN_DB(db, db.image.id, '%(title)s')ment.author.requires = IS_NOT_EMPTY()ment.email.requires = IS_EMAIL()ment.body.requires = IS_NOT_EMPTY()ment.image_id.writable = ment.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()ment.image_id.default = image.idform = SQLFORM(ment)if form.process().accepted:response.flash = 'your comment is posted'comments = db(ment.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'}}<h1>Image: {{=image.title}}</h1><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首页

/

(2)点击按钮:try it now online (3)填写用户名后,点击give me my web2py

访问网址如下:/welcome/default/index

结语

如果您觉得该方法或代码有一点点用处,可以给作者点个赞,或打赏杯咖啡;╮( ̄▽ ̄)╭

如果您感觉方法或代码不咋地//(ㄒoㄒ)//,就在评论处留言,作者继续改进;o_O???

如果您需要相关功能的代码定制化开发,可以留言私信作者;(✿◡‿◡)

感谢各位大佬童鞋们的支持!( ´ ▽´ )ノ ( ´ ▽´)っ!!!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。