Web2py SQLForm.grid:删除以原始名称保存的上载文件

时间:2015-03-31 04:40:23

标签: web2py

这是我的数据库定义。

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)

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

请告诉我这个,如何包含删除功能,以便每当删除一行时,与其关联的物理文件也会被删除。

提前致谢。

1 个答案:

答案 0 :(得分:1)

autodelete功能期望(a)上传文件夹是默认的/ web2py / applications / yourapp / uploads文件夹(或者指定字段的" uploadfolder"属性) ,(b)存储在upload字段中的值是应该附加到上传文件夹路径的文件名。如果不满足这些条件中的一个或两个,则应通过以下方式提供自定义删除功能:

Field(..., custom_delete=your_custom_function)

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