SAE-Python教程(一) 在SAE上进行Python的开发

说明:

(1)本人是python和web开发初学者,本文内容仅供新手交流经验……其实我想说欢迎吐槽的 :)

(2)我认为对于初学Python的同学来说SAE不算是很好用的一个环境,推荐通过安装nginx 和 uWSGI 将web服务放在本地更适合新手的学习


1.1 申请试用SAE的Python服务

如下图,如果SAE账号在创建应用界面的开发语言选项中看不到Python,那么需要去这里(http://www.douban.com/group/topic/24041553/ )申请。我申请后大概一天后就可以创建Python应用。


SAE-Python教程(一) 在SAE上进行Python的开发_第1张图片


另外可以加入SAE-Python邮件列表 及豆瓣的SAE Python小组 和开发者们交流。


1.2 创建第一个Python应用

在前一个步骤中申请成功的话就可以看到选择开发语言界面多出Python这个选项,其余的部分和创建一个SAE PHP应用是一样的。

SAE-Python教程(一) 在SAE上进行Python的开发_第2张图片


填好相关资料后打开应用

在应用主页点击“代码管理”,然后创建一个版本,系统会自动为你生成一个代码框架:config.yaml 和 index.wsgi 

SAE-Python教程(一) 在SAE上进行Python的开发_第3张图片

SAE-Python教程(一) 在SAE上进行Python的开发_第4张图片


这时候点开这个应用的链接,能看到网页显示“Welcome to SAE!”说明创建成功。





1.3 写一个自己的Hello World

现在可以用SAE Editor(其实是个很不好用的东西)在线编辑代码了。目前就只有两个文件,也就是刚才提到的 config.yaml 和 index.wsgi 。

暂时我们可以不用管 config.yaml , 来看看 index.wsgi


SAE-Python教程(一) 在SAE上进行Python的开发_第5张图片

这个后缀名为.wsgi的文件其实就是python文件。它首先引入了sae这个模块,然后在app函数中返回了一个http格式的内容,也就是你所看到的“Welcome to SAE!”。

最后由sae.create_wsgi_app把app转换为适用于SAE环境的应用。(具体可参考官方文档的“SAE Python环境”说明)


所以我们最后所看到的内容就是由这个app函数的返回值所决定的。

我们来加一段代码到app定义的前面,然后替换掉app函数的返回部分,现在代码看起来应该是这样的


import sae

def hello():
    return 'hello my python'

def app(environ, start_response):
    status = '200 OK'
    response_headers = [('Content-type', 'text/html; charset=utf-8')]
    start_response(status, response_headers)
    return hello()
   

application = sae.create_wsgi_app(app)

这时候保存,然后再访问应用,你看到“hello my python”的话说明成功替换了原来的内容。

哈哈这个教程的第一课到这里是不是要完了?


1.4 为什么要这样写hello world?

实际上,直接替换app函数中的 return部分后面那段字符串,也可以看到效果,所以这样写是不是多此一举了?

先不急,我们来看看SAE都提供了哪些框架可以使用——官方文档的“Quick Start”中列出了所有支持的框架及对应的快速开始模式。如果你学过Django、Web.py、Tornado之类的框架的用法,那么这些对你来说应该没什么问题了。


——问题在于,不希望用框架的情形呢?


如果,你有耐心继续看这篇我自己都受不了的“学习笔记”,请你把代码改成下面这样:


import sae

def hello():
    return 'hello my python'
    
def hello2():
    print 'hello 2'
    return

def app(environ, start_response):
    status = '200 OK'
    response_headers = [('Content-type', 'text/html; charset=utf-8')]
    start_response(status, response_headers)
    hello2()
    return hello()
   

application = sae.create_wsgi_app(app)

我添加了一个名为hello2的函数,执行了一个 print 语句。然后在app函数中调用hello2

现在运行吧。


结果你应该能想到,print语句的输出肯定不会被打印在浏览器的界面中。但是这个hello2函数也被执行了。所以在SAE我们是看不到想命令行运行python那样的print输出,但是这不妨碍我们让python做它该做的事,它还是支持引入各种模块,做各种强大的事——只是我们只能通过一个url来调用。所以当你访问应用的url,实际上就是在执行app这个函数。


如果你自己定义了多个函数需要执行,那么把他们全部放进app这个函数里调用就行。


1.5 收尾

说了一大堆,最后还是建议各位选择一个框架在SAE上进行开发,这样上面的问题“为什么写这样的hello world?” —— 当你的函数和对象开始变多,却没有框架来管理的时候,你需要新建一个(或者几个)py文件来存放这些代码,然后自己再写一些代码来管理函数和对象的调用。这时候你就会发现,在这样的情形下用web框架还是有帮助的。


下面是几个链接供参考:

(1)基于SAE的Python+Django的入门实践

(2)SAE Python 开发者手册


===============================================

本文来自:http://blog.csdn.net/zh405123507

tags: Python SAE web.py wsgi

你可能感兴趣的:(Web)