官方地址:
http://www.web2py.com,,,开发web应用的两个经典方法是:,web2py由如下组件构成:,http://www.web2py.com/examples/default/download,, 下载之后解压如下:
,在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上则使用所有可用的网卡。,这个页面显示所有安装在web2py上安装的应用,并且可以用admin账户管理。 web2py默认包含3个应用:,在启动web2py应用程序之后,使用上述URL,我们可以使用管理界面创建一个新模块,例如“XiaoMu”。管理界面将要求密码进行认证,因为管理员拥有添加和编辑任何新的Web应用程序的所有权限。
让新应用程序的名称为“XiaoMu”。一旦创建了新的应用程序,用户被重定向到包含相应应用程序的视图,模型和控制器的页面。
,用户可以通过提及以下URL来查看新创建的应用程序:http://127.0.0.1:8000/XiaoMu 默认情况下,用户可以在点击上述URL时查看以下屏幕。用于打印给定的网络应用程序的消息的“XiaoMu”,该变化在由default.py控制器。, web2py包括执行创建,检索,更新和删除功能的应用程序。该CRUD周期描述了一个数据库,这是执着的基本功能。所有的应用程序逻辑都写在模型中,这些模型由控制器检索并在视图的帮助下显示给用户。 web2py提供了一个用于管理,创建和删除表或数据库的界面,这被称为“appadmin”。在实现表背后的逻辑之前,有必要创建数据库及其关联的表。 访问appadmin的URL:http://127.0.0.1:8000/XiaoMu/appadmin 在点击URL时,用户将获得与给定应用程序关联的表的列表。
在前面,我们已经学会了如何使用GUI部件启动web2py服务器。 可以通过从命令行提示符启动服务器来跳过此窗口。,每当web2py服务器启动时,它都会创建一个文件“ parameters_8000.py ”,其中所有密码都以散列形式存储。为了更安全的目的,可以使用以下命令行 -,,
,,,,创建一个新的应用:xiaomu_images, 然后编辑它。,浏览器访问:http://127.0.0.1:8000/xiaomu_images/appadmin
依次通过界面添加图片记录到数据库中:
,,,如果您觉得该方法或代码有一点点用处,可以给作者点个赞,或打赏杯咖啡;
╮( ̄▽ ̄)╭如果您感觉方法或代码不咋地
//(ㄒoㄒ)//,就在评论处留言,作者继续改进;
o_O???如果您需要相关功能的代码定制化开发,可以留言私信作者;
(◡‿◡)感谢各位大佬童鞋们的支持!
( ´ ▽´ )ノ ( ´ ▽´)っ!!!
,,
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??? 如果您需要相关功能的代码定制化开发,可以留言私信作者;
(◡‿◡) 感谢各位大佬童鞋们的支持!
( ´ ▽´ )ノ ( ´ ▽´)っ!!!
文章版权声明
1 原创文章作者:7762,如若转载,请注明出处: https://www.52hwl.com/37272.html
2 温馨提示:软件侵权请联系469472785#qq.com(三天内删除相关链接)资源失效请留言反馈
3 下载提示:如遇蓝奏云无法访问,请修改lanzous(把s修改成x)
4 免责声明:本站为个人博客,所有软件信息均来自网络 修改版软件,加群广告提示为修改者自留,非本站信息,注意鉴别