python - 您可能没有在您的 API 中包含相关模型,或者在此字段上错误地配置了 `lookup_field` 属性

标签 python django django-rest-framework

我正在尝试在两个实体之间设置查找字段,但我无法修复此错误。

我已经尝试过这些解决方案,但没有一个对我有用(我做错了什么?):

Django Rest Framework, improperly configured lookup field

Django Rest Framework - Could not resolve URL for hyperlinked relationship using view name "user-detail"

DRF Could not resolve URL for hyperlinked relationship using view name on PrimaryKeyRelatedField

这是我的代码 型号:

class Category(models.Model):
    title = models.CharField(max_length=50, unique=True)
    slug = models.SlugField(max_length=80, default='')

    def __str__(self):
        return self.title

class Option(models.Model):
    title = models.CharField(max_length=80)
    slug = models.SlugField(max_length=80, unique=True)
    description = models.CharField(max_length=250)
    price = models.DecimalField(max_digits=7,  decimal_places=2)
    category = models.ForeignKey(Category, related_name='options', on_delete=models.CASCADE)
    photo = models.ImageField(upload_to='options', null=True)

    class Meta:
        ordering = ['title']
    
    def __str__(self):
        return self.title

序列化器:

class CategorySerializer(serializers.HyperlinkedModelSerializer):
    options = serializers.HyperlinkedRelatedField(many=True, view_name='option-detail', read_only=True)
    class Meta:
        model = Category
        fields = ('url', 'slug', 'title', 'options')
        lookup_field = 'slug'
        extra_kwargs = {
            'url': {'lookup_field': 'slug'}
        }

class OptionSerializer(serializers.HyperlinkedModelSerializer):
    category = serializers.ReadOnlyField(source='category.title')
    class Meta:
        model = Option
        fields = ('url', 'slug', 'title', 'description', 'price', 'category')
        lookup_field = 'slug'
        extra_kwargs = {
            'url': {'lookup_field': 'slug'},
            'category': {'lookup_field': 'slug'}
        }

观点:

class CategoryViewSet(viewsets.ReadOnlyModelViewSet):
    """
    Returns the Category list or the requested one
    """
    queryset = Category.objects.all()
    serializer_class = CategorySerializer
    lookup_field = 'slug'

class OptionViewSet(viewsets.ReadOnlyModelViewSet):
    """
    Returns the Option list or the requested one
    """
    queryset = Option.objects.all()
    serializer_class = OptionSerializer
    lookup_field = 'slug'

网址:

router = DefaultRouter()
router.register(r'options', views.OptionViewSet)
router.register(r'categories', views.CategoryViewSet)

urlpatterns = [
    path('', include(router.urls)),
]

这适用于 Option 模型。当我点击“[localhost]/options/” url 时,它会正确列出选项,而当我点击“[localhost]/options/some-option-slug”时,它会返回正确的选项。

但是这些都不适用于类别模型。调用“[localhost]/categories/”返回“无法使用 View 名称“option-detail”解析超链接关系的 URL。您可能未能在 API 中包含相关模型,或者未正确配置 lookup_field 此字段的属性。”。调用“[localhost]/categories/category-slug/”返回 404 Not Found。

我的django版本是4.0.1,我的Django Rest Framework版本是3.13.1

编辑 正如@code-apprendice 所建议的,这里是 print('router') 的输出: [, , , , , , , , , ]

DRF 正确生成了 View 选项列表、选项详细信息、类别列表和类别详细信息

最佳答案

为 CategorySerializer 中的选项定义 lookup_field 属性解决了这个问题。

这是 CategorySerializer 类:

class CategorySerializer(serializers.HyperlinkedModelSerializer):
options = serializers.HyperlinkedRelatedField(
    view_name='option-detail',
    lookup_field = 'slug',
    many=True,
    read_only=True)

class Meta:
    model = Category
    fields = ('url', 'slug', 'title', 'options')
    lookup_field = 'slug'
    extra_kwargs = {
        'url': {'lookup_field': 'slug'}
    }

问题是 CategorySerializer 设置了一个显式选项 HyperlinkedRelatedField 并且它的 lookup_field 也需要配置。

请随意编辑此答案以添加更深入的解释。

关于python - 您可能没有在您的 API 中包含相关模型,或者在此字段上错误地配置了 `lookup_field` 属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71312665/

相关文章:

python - 将函数应用于 Python 中列表的一个元素

django - Postgres : Password authentication failed for user "user". 角色 "user"不存在

python - 我可以安全地将离线生成的 settings.py 文件复制到远程服务器吗?

django - 如何使 Django REST Framework 中的所有超链接相对?

python - 在 Django Rest Framework 自定义异常处理程序响应数据中包含请求数据

python - 从 Webscrape 中过滤和格式化数据帧

python - Django 消息显示两次

django - 如何使用 {format} drf-yasg 排除请求?

Python/Flask错误: “ImportError: cannot import name _compare_digest”

python - 如何将Django模板中的{{fieldset.fields}}转换为字符串?