用户具有可以保存敏感数据的表单。我能够加密这些数据,并使用模型形式将其存储在数据库中。但是,如果用户想要修改此数据,它将显示在表单的TextInput中。
我已阅读this post和this one。答案似乎在那里,但是我无法在实现中找到原因。这是我所拥有的:
模型
class CustomUser(AbstractUser):
api_key = models.CharField(max_length=256, default='null')
表格
class APIForm(forms.ModelForm):
class Meta:
model = CustomUser
fields = ('api_key')
widgets = {
'api_key': TextInput(attrs={'size': 10, 'placeholder': 'Your key'}),
}
HTML
<form method="post">
{% csrf_token %}
{{ form|crispy }}
<button type="submit">Save changes</button>
</form>
该表单似乎没有检测到该小部件,因为如果更改属性大小的值,该表单也不会更改。
我想念什么吗?
预先感谢
这是我的视图代码简化了:
观看次数
class KeyView(LoginRequiredMixin, UpdateView):
model = CustomUser
form_class = APIForm
template_name = 'account/api_form.html'
success_url = reverse_lazy('pages:home')
def get_object(self):
return self.request.user
def form_valid(self, form):
self.object = form.save(commit=False)
key=botcrypt.encrypt_val(self.object.api_key)
self.object.api_key =key.decode("utf-8")
self.object.save()
messages.success(self.request, 'key updated with success!')
return super().form_valid(form)
我正在为帐户使用allauth,以防此信息很重要
答案 0 :(得分:0)
您可以尝试上述方法的替代方法
api_key = forms.CharField(_(u'API Key'), required=False)
api_key.widget = forms.TextInput(attrs={'size': 10, 'title': 'API Key',})
或
api_key = forms.CharField(
_(u'API Key'),
required=False,
widget=forms.TextInput(attrs={'size': 10, 'title': 'API Key',})
)
答案 1 :(得分:0)
所以实际上解决方案很简单,正如预期的那样。...
来自Models
,Forms
和html
的所有代码都是正确的。
我只需要清空get_object
中views
中的键值:
def get_object(self):
self.request.user.api_key = ""
return self.request.user