这是我的数据库定义。
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设置。但由于存在自定义检索/下载功能,并且由于在从网格中删除行时未删除物理文件。
请告诉我这个,如何包含删除功能,以便每当删除一行时,与其关联的物理文件也会被删除。
提前致谢。
答案 0 :(得分:1)
autodelete
功能期望(a)上传文件夹是默认的/ web2py / applications / yourapp / uploads文件夹(或者指定字段的" uploadfolder"属性) ,(b)存储在upload字段中的值是应该附加到上传文件夹路径的文件名。如果不满足这些条件中的一个或两个,则应通过以下方式提供自定义删除功能:
Field(..., custom_delete=your_custom_function)
小心使用原始文件名,因为web2py重写文件名的原因是为了防止路径遍历攻击。另请注意,web2py的默认行为会保留原始文件名(通过编码)。