RelatedObjectDoesNotExist: У пользователя нет клиента

Я следую учебнику Django youtube E-comerce от Dennis Ivy. Я следую учебнику строка за строкой. С самого начала я запускаю программу и просматриваю все выходные данные, но по пути я начинаю получать сообщение об ошибке "RelatedObjectDoesNotExist: У пользователя нет клиента". Я в замешательстве, потому что повторяю видео, чтобы понять, где я ошибся, но не могу отследить это. Пожалуйста, подскажите решение? Я понимаю, что в последний раз, когда я пытался, он открылся сам по себе, используя "internet explorer", он отображается. когда я открываю в "chrome", он показывает ту же ошибку. но когда я удалил клиента из базы данных, он снова начинает показывать ту же ошибку в "internet explorer". Я не хочу отказываться от учебника, потому что он мне нужен. Пожалуйста, кто-нибудь должен мне помочь. Спасибо

from multiprocessing import context
from django.shortcuts import render
from .models import *
from django.contrib.auth.models import User
from django.http import JsonResponse
import json

# Create your views here.
def store(request):
    if request.user.is_authenticated:
        customer = request.user.customer
        order, created=Order.objects.get_or_create(customer=customer, complete =False)
        items =order.orderitem_set.all()
        cartItems=order.get_cart_items

    else:
        items=[]
        order = {'get_cart_total':0, 'get_cart_items':0}
        cartItems=order['get_cart_items']

    products = Product.objects.all()
    context = {
        'products':products,
        'cartItems':cartItems,
        
        
    }
    return render(request, 'store/store.html', context)

def cart(request):
    if request.user.is_authenticated:
        customer = request.user.customer
        order, created=Order.objects.get_or_create(customer=customer, complete =False)
        items =order.orderitem_set.all()
        cartItems=order.get_cart_items
        
    else:
        items=[]
        order = {'get_cart_total':0, 'get_cart_items':0}
        cartItems=order['get_cart_items']
    
    context = {
        'items':items,
        'order':order,
        'cartItems':cartItems,
    }
    return render(request, 'store/cart.html', context)

def checkout(request):
    if request.user.is_authenticated:
        customer = request.user.customer
        order, created=Order.objects.get_or_create(customer=customer, complete =False)
       # order, created=Order.objects.get_or_create(complete =False)
        items =order.orderitem_set.all()
    else:
        items=[]
        order = {'get_cart_total':0, 'get_cart_items':0}
        cartItems=order['get_cart_items']
    
    context = {
        'items':items,
        'order':order,
        'cartItems':cartItems
    }
    return render(request, 'store/checkout.html', context)

def updateItem(request):
    data = json.loads(request.data)
    productId = data['productId']
    action = data['action']

    print('Action:', action)
    print('productId:', productId)

    customer=request.user.customer
    product=Product.objects.get(id=productId)
    order, created=Order.objects.get_or_create(complete =False)

    orderItem, created=OrderItem.objects.get_or_create(order=order, product=product)

    if action =='add':
        orderItem.quantity =(orderItem.quantity +1)
    elif action =='remove':
        orderItem.quantity =(orderItem.quantity -1)
        orderItem.save()
    
    if orderItem.quantity <=0:
        orderItem.delete()



    return JsonResponse('Item was added', safe =False)

это models.py

import email
from django.db import models
from django.db.models.fields.related import OneToOneField
from django.contrib.auth.models import User
from numpy import product 

# Create your models here.

class Customer(models.Model):
    user=models.OneToOneField(User, null=True, blank=True, on_delete=models.CASCADE)
    name = models.CharField(max_length=200, null=True)
    email=models.CharField(max_length=200)

    def __str__(self):
        return self.name

        

class Product(models.Model):
    name = models.CharField(max_length=200, null=True)
    price = models.FloatField()
    digital=models.BooleanField(default=False, null=True, blank=True)
    image = models.ImageField(null=True, blank=True)

    def __str__(self):
        return self.name
    #this is  to avoid erro in the template when we delete image
    @property
    def imageURL(self):
        try:
            url=self.image.url
        except:
            url=''
        return url


class Order(models.Model):
    customer=models.ForeignKey(Customer, on_delete=models.SET_NULL, null=True, blank=True)
    date_ordered=models.DateTimeField(auto_now_add=True)
    complete = models.BooleanField(default=False)
    transaction_id = models.CharField(max_length=200, null=True)

    def __str__(self):
        return str(self.id)

    @property
    def get_cart_total(self):
        orderitems = self.orderitem_set.all()
        total = sum([item.get_total for item in orderitems])
        return total

    @property
    def get_cart_items(self):
        orderitems = self.orderitem_set.all()
        total = sum([item.quantity for item in orderitems])
        return total

    


class OrderItem(models.Model):
    product=models.ForeignKey(Product, on_delete=models.SET_NULL, null=True, blank=True)
    order=models.ForeignKey(Order, on_delete=models.SET_NULL, null=True, blank=True)
    quantity = models.IntegerField(default=0, null=True, blank=True)
    date_added=models.DateTimeField(auto_now_add=True)

    @property
    def get_total(self):
        total = self.product.price * self.quantity
        return total


class ShippingAddress(models.Model):
    customer=models.ForeignKey(Customer, on_delete=models.SET_NULL, null=True, blank=True)
    order=models.ForeignKey(Order, on_delete=models.SET_NULL, null=True, blank=True)
    address= models.CharField(max_length=200, null=True)
    city = models.CharField(max_length=200, null=True)
    state = models.CharField(max_length=200, null=True)
    zipcode = models.CharField(max_length=200, null=True)
    date_added=models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return self.address

это urls.py

from django.urls import path
from . import views

urlpatterns = [
    path('', views.store, name = 'store'),
    path('cart/', views.cart, name = 'cart'),
    path('checkout', views.checkout, name = 'checkout'),
    path('update_item/', views.updateItem, name='update_item')
]

вы можете использовать request.user для запроса клиента

customer = Customer.objects.get(user__id = request.user.id) 

Способы решения проблемы

Вы можете добавить приведенный ниже код в шаге 1 или 2, который нужно запустить в оболочке (в папке app)

  1. Создайте в папке app этот файл , create_customers.py

  2. Откройте папку app в терминале и выполните следующую команду

    python manage.py shell

    затем вставьте приведенный ниже код в shell

    from django.contrib.auth.models import User

    from store.models import Customer

    for user in User.objects.all(): Customer.objects.create(user=user, name=user.username, email=user.email)

Вернуться на верх