1,解決官方SAE樣例代碼中的誤區
#app = web.application(urls, globals()).wsgifunc()
app = web.application(urls, globals())
#application = sae.create_wsgi_app(app)
application = sae.create_wsgi_app(app.wsgifunc())
注釋掉代碼為官方提供的樣例代碼,但官方代碼為了方便在APP實例化時直接調用了wsgifunc(),但這樣會造成部分webpy屬性的調用錯誤.如調用app.add_processor的失敗.
2,設定全局session的調用
#增加session管理,將session放入全局的web.config
if web.config.get('_session') is None:
shop_session = web.session.Session(app, DiskStore(session_root),
initializer={'login_shop_id':'NULL'})
web.config._session = shop_session
else:
shop_session = web.config._session
def session_hook():
web.ctx.session = shop_session
app.add_processor(web.loadhook(session_hook))
3,解決sae環境中無法讀寫本地目錄問題
SAE環境下python無法對本地目錄進行讀寫操作,但sae提供了Storage,並且可以將Storage像本地磁盤一樣掛載使用.所以添加如下代碼:
monkey.patch_all()
session_root = '/s/session/'
注意:需要提前在sae中啟用Storage,且添加"domain:session"以便具有權限.
4,解決SEA的Storage作為磁盤掛載後但不支持os.remove方法
"目前支持(patch)的文件系統接口函數為: open, os.listdir, os.mkdir, os.path.exists, os.path.isdir, os.open, os.fdopen, os.close, os.chmod, os.stat, os.unlink, os.rmdir"但webpy在DiskStore.cleanup方法卻是調用的os.remove,需要改為os.unlink
#因新浪SAE的stroge不支持掛載為路徑後的os.remove函數,故重新改在一下
class DiskStore(web.session.DiskStore):
def __init__(self, root):
web.session.DiskStore.__init__(self, root)
# if the storage root doesn't exists, create it.
self.root = root
def cleanup(self, timeout):
now = time.time()
for f in os.listdir(self.root):
path = self._get_path(f)
atime = os.stat(path).st_atime
if now - atime > timeout :
os.unlink(path)#改寫為unlink函數
OK,現在session已經可以正常使用了.