簡體   English   中英

Django隱藏字段未保存到數據庫

[英]Django hidden field is not saving to database

我試圖在我的擴展配置文件模型中保存用戶IP地址。 目的是使其成為一個隱藏的領域。 目前,我可以通過將IP地址打印到控制台進行調試。 當我嘗試保存信息時會出現問題。

views.py

def index(request):
    #request.session.flush()
    if request.user.is_authenticated:
        return redirect('ve:dashboard')
    elif request.method == 'POST':
        form = RegistrationForm(request.POST)

        if form.is_valid():
            user = form.save(commit=False)
            user.refresh_from_db() # Load the profile instance created by the Signal
            user.profile.birth_date = form.cleaned_data.get('birth_date')
            user.ipaddress = get_ip(request)
            print(user.ipaddress)
            user.save()
            raw_password = form.cleaned_data.get('password1')
            user = authenticate(username=user.username, password=raw_password)
            login(request, user)
            return redirect('ve:dashboard')
    else:
        form = RegistrationForm()
    return render(request, 'index.html', {'form': form})

表格

class RegistrationForm(UserCreationForm):
    # birth_date = forms.DateField(help_text='Required. Format: YYYY-MM-DD')
    birth_date = forms.DateField(widget=SelectDateWidget(years=range(1999, 1910, -1)))
    #ipaddress = forms.IntegerField(widget=forms.HiddenInput(), required=False)

    class Meta:
        model = User
        fields = ('username', 'email', 'birth_date', 'password1', 'password2',)
        exclude = ['ipaddress',]

index.html

    <form method="post">
    {% csrf_token %}
    {% for field in form %}
        <p class="text-left">
        {{ field.label_tag }}<br>
        {{ field }}
        {% for error in field.errors %}
          <p style="color: red">{{ error }}</p>
        {% endfor %}
        </p>
    {% endfor %}
    <button type="submit">Sign up</button>
    </form>

models.py

class Profile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    ...
    ipaddress = models.CharField(default="0.0.0.0", max_length=30)

在嘗試添加ipaddress字段之前,此表單運行良好。 我一直在嘗試多個版本,有時表單會創建一個新用戶,但ipaddress不會保存。

上面的當前代碼使我在POST上出現錯誤:/ /用戶匹配查詢不存在。 由於這一行“ user.refresh_from_db()#加載由信號創建的配置文件實例”

從文檔:

這個save()方法接受一個可選的commit關鍵字參數,該參數接受True或False。 如果使用commit = False調用save(),它將返回一個尚未保存到數據庫的對象。

因此,由於您將提交作為False傳遞,因此您將獲得未保存的實例。 嘗試對數據庫中實際上不存在的對象調用refresh_from_db將會失敗,這很明顯。 如果模型的實例沒有id則調用它時refresh_from_db將失敗。

關於繼續無法保存IP地址的問題,我注意到您的表單meta已將模型設置為User對象。 默認的Django User對象沒有IP地址。 我看到在鏈接的模型文件中,您有一個具有IP地址的Profile模型,因此在這種情況下,我認為您的表單設置錯誤。 或者您需要以不同的方式處理請求。

表格變更

當前,您的表單正在嘗試創建/修改Django User模型。 除非您創建了未顯示的自定義User模型,否則即使您設置了user.ipaddress = <address>然后保存了用戶ip,該用戶模型也不會將ipaddress作為數據庫中的字段表示。地址不會在當前作用域之外持續存在,因為您所做的只是為user實例聲明了一個新變量。

如果您更改表格以指向Profile模型,則可以使用profile.ipaddress = <address>保存profile.ipaddress = <address>並成功保存。 但是您將必須更新模板,因為默認情況下,模板將僅顯示個人資料的字段,而不顯示與之關聯的用戶對象。

更改模板/視圖

您還可以更改模板並查看以適應它。 顯然,您的視圖可以使用get_ip函數生成IP地址,因此暫時我認為您的模板是可以的,因此僅需要對視圖進行更改。

當前,您的視圖在調用form.save時會form.save未保存的User實例。 這意味着您需要保存用戶,然后創建一個Profile模型,該模型引用附帶您的IP地址的用戶。

def index(request):
    #request.session.flush()
    if request.user.is_authenticated:
        return redirect('ve:dashboard')
    elif request.method == 'POST':
        form = RegistrationForm(request.POST)

        if form.is_valid():
            user = form.save(commit=False)
            # do anything you need to the unsaved user here
            user.save()
            prof = Profile.objects.create(user=user, 
                                          ipaddress=get_ip(request),
                                          date=form.cleaned_data.get('birth_date')
            # no need to save prof since we called objects.create
            raw_password = form.cleaned_data.get('password1')
            user = authenticate(username=user.username, password=raw_password)
            login(request, user)
            return redirect('ve:dashboard')
    else:
        form = RegistrationForm()
    return render(request, 'index.html', {'form': form})

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM