Как сделать запрос на создание (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
словаре.