不过,我在从其他数据库字段引用 auth_user 时遇到了一些问题。在以下视图 (company.html) 中,我有一个用于“公司”表的 SQLFORM。如何将公司表单的 user_id 字段设置为默认为当前登录用户的 ID?我尝试在公司表中添加一个名为 user_id 的字段,但由于某种原因,它会导致表单每次都无效。
我在另一个名为 db_tasks.py 的文件中的模型文件夹中有以下代码:
# Define company table
db.define_table('company',
Field('company_name', notnull=True, unique=True),
Field('user_id', db.auth_user, default=auth.user_id),
Field('email'),
Field('phone', notnull=True),
Field('url'),
format = '%(company_name)s')
还有一个我的常规 db.py 文件:
db = DAL('sqlite://storage.sqlite',pool_size=1,check_reserved=['all'])
auth = Auth(db)
# Add extra user fields
auth.settings.extra_fields['auth_user'] = [
Field('address'),
Field('city'),
Field('zip'),
Field('image', 'upload'),
]
公司的控制器。当我导航到此视图时,用户字段显示在数据网格中,但不在表单中。(而且我不希望它,我只想将它设置为任何登录的用户,即 auth.user)。无论出于何种原因,表单都不会验证。我认为这与模型有关。
@auth.requires_login()
def company():
# init a form object for 'company' table
company_form = SQLFORM(db.company).process()
# init a grid object for 'company' table
grid = SQLFORM.grid(db.company, create=False, deletable=False, editable=False, maxtextlength=50, orderby=db.company.company_name)
return locals()
这是公司的观点:
{{extend 'layout.html'}}
<h2>Add a new company:</h2>
<br/>
{{=company_form.custom.begin}}
<strong>Company Name</strong> <br/>{{=company_form.custom.widget.company_name}}<br/>
<strong>Email</strong><br/>{{=company_form.custom.widget.email}}<br/>
<strong>Phone</strong><br/>{{=company_form.custom.widget.phone}}<br/>
<strong>URL</strong><br/>{{=company_form.custom.widget.url}}<br/>
{{=company_form.custom.submit}}
{{=company_form.custom.end}}
<br/>
<br/>
<h2>All Companies:</h2>
<br/>
{{=grid}}