草庐IT

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

爱看书的小沐 2023-03-28 原文

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> {{=message}} </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> {{=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)的更多相关文章

  1. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  4. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  5. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  6. ruby - 如何根据特征实现 FactoryGirl 的条件行为 - 2

    我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden

  7. Ruby Sinatra 配置用于生产和开发 - 2

    我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm

  8. ruby - 是否可以覆盖 gemfile 进行本地开发? - 2

    我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI

  9. ruby - 在 Windows 机器上使用 Ruby 进行开发是否会适得其反? - 2

    这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby​​-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub

  10. ruby-on-rails - 在 Rails 开发环境中为 .ogv 文件设置 Mime 类型 - 2

    我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain

随机推荐