So senden Sie eine Liste von IDs über Multipart/Formulardaten im Django REST FrameworkPython

Python-Programme
Guest
 So senden Sie eine Liste von IDs über Multipart/Formulardaten im Django REST Framework

Post by Guest »

Ich arbeite an einer Django REST Framework API, bei der ich eine Liste von IDs in einer Multipart-/Formulardatenanforderung senden muss, um eine Viele-zu-Viele-Beziehung in der Datenbank zu erstellen. Während bei der Verwendung von JSON als Anforderungsformat alles perfekt funktioniert, treten beim Wechsel zu Multipart/Formulardaten Probleme auf, da die Liste der IDs nicht korrekt serialisiert wird.
Hier ist mein Serializer:< /p>

Code: Select all

class AddOrUpdateContractSerializer(serializers.ModelSerializer):
deputy_agent = serializers.ListField(
child=serializers.IntegerField(), required=False, allow_empty=False
)
product_type = serializers.ListField(
child=serializers.IntegerField(), required=False, allow_empty=False
)
referral_type = serializers.ListField(
child=serializers.IntegerField(), required=False, allow_empty=False
)
customer_id = serializers.IntegerField(required=False)

class Meta:
model = Contract
exclude = ["id", "product", "is_deleted", "state", "customer"]
Hier ist meine Ansicht

Code: Select all

class AddContract(APIView):
@extend_schema(request=AddOrUpdateContractSerializer, tags=["contract"])
def post(self, request):
serialized_data = AddOrUpdateContractSerializer(data=request.data)
if serialized_data.is_valid(raise_exception=True):
service = ContractService(
serialized_data=serialized_data.validated_data, user=request.user
)
service.create_contract()
return Response(
status=status.HTTP_200_OK,
data={"detail": "contract created successfully"},
)
Und der Service zur Vertragserstellung:

Code: Select all

def create_contract(self):
items = ["customer_id", "deputy_agent", "product_type", "referral_type"]

customer = CustomerSelector.get_customer_by_id(
self.serialized_data.get("customer_id", None)
)
deputy_agent = self.serialized_data.get("deputy_agent", None)
product_type = self.serialized_data.get("product_type", None)
referral_type = self.serialized_data.get("referral_type", None)

self.remove_unnecessary_items(items)

contract = Contract(customer=customer, **self.serialized_data)

contract.full_clean()
contract.save()

if deputy_agent:
deputy_agents = DeputyAgent.objects.filter(id__in=deputy_agent)
contract.deputy_agent.add(*deputy_agents)

if product_type:
product_types = ComboBoxsOptions.objects.filter(id__in=product_type)
contract.product_type.add(*product_types)

if referral_type:
referral_types = ComboBoxsOptions.objects.filter(id__in=referral_type)
contract.referral_type.add(*referral_types)
PROBLEM
Beim Senden der Daten als Multipart-/Formulardaten werden Listen wie Deputy_Agent, Product_Type und Referral_Type angezeigt als Zeichenfolgen anstelle von Listen erhalten
Warum ich Multipart-/Formulardaten benötige
Ich kann JSON nicht verwenden, da ich auch Bilddateien hochladen muss diese IDs in derselben Anfrage.
Beispielanfrage

Code: Select all

Content-Type: multipart/form-data

customer_id: 1
deputy_agent: [1, 2, 3]
product_type: [4, 5, 6]
image: 
Frage
Wie kann ich Listen von IDs in Multipart-/Formulardaten im Django REST Framework ordnungsgemäß verarbeiten? Gibt es eine bewährte Vorgehensweise oder einen Workaround für dieses Problem?

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post