Как сделать запрос на создание (POST) с помощью api в django

Я хочу создавать новые данные, когда любой пользователь делает любой запрос, например, Create Export Delete или Update, но сейчас я работаю над Export... У меня есть два url, один из которых имеет данные таблиц (average_data urls) и один url, который имеет (audit_logs url) данные пользователя, которые будут созданы после того, как любой пользователь загрузит pdf формат данных... так что в основном я хочу показать, какой пользователь в какое время и какое действие он делает, он получит это на audit_logs url

Я делаю запрос поста в data/views, но получаю ошибку bad request at /audit_logs/create/

views.py

def averagePDF(request):
global fromDate
global toDate
global site
global device
global parameters
global interval
global data
headers = {
    'authorization': "Bearer X...............",
}
devices_url = "http://127.0.0.1:8000/stations/list"
devices_params = {
    'id': device
}
devices = requests.request("GET", devices_url, headers=headers, params=devices_params)
response = HttpResponse()
response['Content-Disposition'] = 'attachment; filename=Average Data.pdf'

elements = []


company_name = Paragraph(devices.json()[0]['site'], header_style)
elements.append(company_name)

report_data = Paragraph("Date: " + fromDate + " to " + toDate + " Station: " + devices.json()[0]['station'], title_style)
elements.append(report_data)

styles = getSampleStyleSheet()
styleN = styles['Normal']
styleN.wordWrap = 'CJK'

file_data = []
header = []
header.append("Timestamp")
header.append("Station")
for parameter in parameters:
    header.append(parameter)
file_data.append(header)
data2 = [[Paragraph(cell, styleN) for cell in row] for row in file_data]
width = (PAGE_WIDTH-50) / len(header)
table_header = Table(data2, colWidths=width, style=table_header_style)
elements.append(table_header)
table_data = []
for key, values in data.items():
    raw_data = []
    raw_data.append(str(key))
    raw_data.append(devices.json()[0]['station'])
    for value in values:
        raw_data.append(str(value))
    table_data.append(raw_data)
table_data2 = [[Paragraph(cell, styleN)for cell in row] for row in table_data]
tableRaw = LongTable(table_data2, colWidths=width, style=table_style)
elements.append(tableRaw)
doc.title = "Average Data"
meta_data = request.META.get('HTTP_X_FORWARDED_FOR')
if meta_data:
    ip = meta_data.split(',')[-1].strip()
else:
    ip = request.META.get('REMOTE_ADDR')
**now=datetime.datetime.now()
# date_time = now.strftime('%Y-%m-%dT%H:%M:%S.%f')
username=str(request.user)
action_type="Export"
action="Export"
ip_address=ip
audit_url="http://127.0.0.1:8000/audit_logs/create/"
audit_parms={
    "username":username,
    "action_type":action_type,
    "action":action,
    "ip_address":ip_address
    }
audit_obj=requests.post(audit_url, headers=headers, params=audit_parms)
print(audit_obj.json())**

когда я публикую ответ, он дает мне следующий ответ

{'username': 'abcpadmin', 'action_type': 'Export', 'action': 'Export', 'ip_address': '127.0.0.1'}

Неправильный запрос: /audit_logs/create/ [15/Nov/2021 16:08:24] "POST /audit_logs/create/?username=abcpadmin&action_type=Export&action=Export&ip_address=127.0.0.1 HTTP/1.1" 400 160 <Ответ [400]> {'username': ['Это поле обязательно.'], 'action_type': ['Это поле обязательно.'], 'action': ['Это поле обязательно.'], 'ip_address': ['Это поле обязательно.']}

Вам стоит взглянуть на djangorestframework https://www.django-rest-framework.org/tutorial/2-requests-and-responses/

Это рекомендуемый способ написания API с помощью django.

Когда вы используете requests для post в вашем случае, вам нужно передать data вместо params

Должно быть :

audit_obj=requests.post(audit_url, headers=headers, data=audit_parms)

Технически, когда вы делаете requests.post(url=your_url, params=your_params), url будет выглядеть как https://localhost?key=value с ключом значением в params словаре.

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