2015-03-31 56 views
0

这是我的数据库定义。Web2py SQLForm.grid:删除用原始名称保存的上传文件

db.define_table('emsAlertTokens', 
      Field('emsrelease',default=session.releasefield,writable=False,label=T('Release')), 
      Field('emsmachine',default=session.machinefield,writable=False,label=T('Machine')), 
      Field('emsstartdate','datetime',default=request.now,label=T('Start Date')), 
      Field('emsenddate','datetime',IS_NOT_EMPTY(error_message='Please specify the End Date.'), label=T('End Date')), 
      Field('errorgrepfile','upload',requires=IS_NOT_EMPTY(error_message='Please upload a valid error tokens file'),custom_store=ems_file, custom_retrieve=ems_retrieve, autodelete=True, uploadfield=True, uploadfs=None, label=T('Error Tokens')), 
      Field('tokenname','string',requires=IS_NOT_EMPTY('What would you call your token file?'),label=T('Token File Name'))) 

我的控制器:

def setemstoken(): 
query = (db.emsAlertTokens) 
headers = {'emsAlertTokens.emsrelease': 'Release', 'emsAlertTokens.emsmachine': 'Machine', 'emsAlertTokens.emsstartdate':'Start Time', 'emsAlertTokens.emsenddate': 'End Time','emsAlertTokens.errorgrepfile': 'Token File'} 
upload = lambda filename: URL("ems_download", args=[filename]) 
grid = SQLFORM.grid(query=query,headers=headers,create=True, upload=upload,user_signature=True, deletable=True, editable=True, maxtextlength=100, paginate=25,formargs=dict(message_onsuccess='Error Filter Set',message_onfailure='Form has errors. Tokens not accepted.'),onvalidation=emsvalidate) 
return dict(grid=grid) 

如可以注意到有一个自定义下载,检索功能。这样做是为了保存文件的原始名称,并且工作正常。为SQLForm设置参数'autodelete = True'。但是,由于存在自定义的检索/下载功能,并且由于当我从网格中删除一行时,物理文件不会被删除。

请在此建议我,如何包含删除功能,以便每当删除一行时,与其关联的物理文件也将被删除。

在此先感谢。

回答

1

autodelete功能期望(a)上传文件夹是默认的/ web2py/applications/yourapp/uploads文件夹(或者指定字段的“uploadfolder”属性),以及(b)存储在上传字段中的是应附加到上传文件夹路径的文件名。如果其中一项或两项条件都不满足,那么你应该改为提供自定义通过删除功能:

Field(..., custom_delete=your_custom_function) 

小心使用原来的文件名,如web2py的理由重写文件名是为了防止路径遍历攻击。另请注意,web2py的默认行为确实保留了原始文件名(通过编码)。

相关问题