【小沐学Python】Python实现Web服务器(web2py)

66 篇文章 13 订阅

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

  1. 🎈【Web开发】Python实现Web服务器(Flask快速入门)🎈
  2. 🎈【Web开发】Python实现Web服务器(Flask案例测试)🎈
  3. 🎈【Web开发】Python实现Web服务器(Flask部署上线)🎈
  4. 🎈【Web开发】Python实现Web服务器(Tornado入门)🎈
  5. 🎈【Web开发】Python实现Web服务器(Tornado+flask+nginx)🎈
  6. 🎈【Web开发】Python实现Web服务器(FastAPI)🎈
  7. 🎈【Web开发】Python实现Web服务器(Bottle)🎈
  8. 🎈【Web开发】Python实现Web服务器(Django)🎈
  9. 🎈【Web开发】Python实现Web服务器(web2py)🎈
  10. 🎈【Web开发】Python实现Web服务器(Sanic)🎈

1、简介

官方地址:
http://www.web2py.com

免费开源全栈框架,快速开发,可扩展,安全和可移植数据库驱动的基于 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)应用:包含文档和交互示例。应用示例是官方网站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>
      <h1>{{=message}}</h1>
   </body>
</html>
  • 浏览器访问如下:
    在这里插入图片描述

4.2 Let’s 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>
      <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_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'}}
<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)
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'}}
<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首页
http://web2py.com/

在这里插入图片描述

  • (2)点击按钮:try it now online

在这里插入图片描述

  • (3)填写用户名后,点击give me my web2py
    在这里插入图片描述
    在这里插入图片描述
  • 访问网址如下:http://xiaomu.pythonanywhere.com/welcome/default/index
    在这里插入图片描述

结语

如果您觉得该方法或代码有一点点用处,可以给作者点个赞,或打赏杯咖啡;╮( ̄▽ ̄)╭
如果您感觉方法或代码不咋地//(ㄒoㄒ)//,就在评论处留言,作者继续改进;o_O???
如果您需要相关功能的代码定制化开发,可以留言私信作者;(✿◡‿◡)
感谢各位大佬童鞋们的支持!( ´ ▽´ )ノ ( ´ ▽´)っ!!!
在这里插入图片描述

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值