0

不过,我在从其他数据库字段引用 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}}
4

1 回答 1

0

session.auth.user.id if session.auth else None”呢?

于 2013-08-05T22:17:21.893 回答