admin管理员组文章数量:1352035
I have had a hunt around but can't seem to find an answer that works. I am following Dennis Ivy's Django tutorial for an e-merce website but I have run in to an issue where I am trying to add an item to my cart but nothing happens, checking the console I am getting these two errors:
POST http://127.0.0.1:8000/update_item/ 500 (Internal Server Error)
updateUserOrder @ cart.js:26 (The fetch line)
(anonymous) @ cart.js:15 (when the function is called)
127.0.0.1/:1 Uncaught (in promise) SyntaxError: Unexpected token < in JSON at position 0
omise.then (async)
updateUserOrder @ cart.js:39 (the second .then)
(anonymous) @ cart.js:15 (when the function is called)
Here is my JavaScript cart.js updateUserOrder function:
function updateUserOrder(productId, action) {
console.log('User is logged in, sending data...')
var url = '/update_item/'
fetch(url, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'X-CSRFToken': csrftoken,
},
body: JSON.stringify({ 'productId': productId, 'action': action })
})
.then((response) => {
return response.json()
})
.then((data) => {
location.reload()
});
}
Here is my view updateItem
:
def updateItem(request):
data = json.loads(request.body)
productId = data['productId']
action = data['action']
print('Action:', action)
print('Product:', productId)
customer = request.user.customer
product = Product.objects.get(id=productId)
order, created = Order.objects.get_or_create(customer=customer, plete=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)
Here is my URL including import:
from checkout.views import updateItem
path('update_item/', updateItem, name="update_item"),
Thanks in advance!
I have had a hunt around but can't seem to find an answer that works. I am following Dennis Ivy's Django tutorial for an e-merce website but I have run in to an issue where I am trying to add an item to my cart but nothing happens, checking the console I am getting these two errors:
POST http://127.0.0.1:8000/update_item/ 500 (Internal Server Error)
updateUserOrder @ cart.js:26 (The fetch line)
(anonymous) @ cart.js:15 (when the function is called)
127.0.0.1/:1 Uncaught (in promise) SyntaxError: Unexpected token < in JSON at position 0
omise.then (async)
updateUserOrder @ cart.js:39 (the second .then)
(anonymous) @ cart.js:15 (when the function is called)
Here is my JavaScript cart.js updateUserOrder function:
function updateUserOrder(productId, action) {
console.log('User is logged in, sending data...')
var url = '/update_item/'
fetch(url, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'X-CSRFToken': csrftoken,
},
body: JSON.stringify({ 'productId': productId, 'action': action })
})
.then((response) => {
return response.json()
})
.then((data) => {
location.reload()
});
}
Here is my view updateItem
:
def updateItem(request):
data = json.loads(request.body)
productId = data['productId']
action = data['action']
print('Action:', action)
print('Product:', productId)
customer = request.user.customer
product = Product.objects.get(id=productId)
order, created = Order.objects.get_or_create(customer=customer, plete=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)
Here is my URL including import:
from checkout.views import updateItem
path('update_item/', updateItem, name="update_item"),
Thanks in advance!
Share Improve this question edited Jul 28, 2020 at 9:42 marc_s 756k184 gold badges1.4k silver badges1.5k bronze badges asked Jul 15, 2020 at 16:11 OwenCOwenC 131 gold badge1 silver badge3 bronze badges 1- Did you solve it? I'm getting the same two error. – Fahim Ahmed Commented Jan 28, 2021 at 9:42
2 Answers
Reset to default 7About first error POST http://127.0.0.1:8000/update_item/ 500 (Internal Server Error)
, you need to check server logs.
About second error 127.0.0.1/:1 Uncaught (in promise) SyntaxError: Unexpected token < in JSON at position 0
, the Promise returned from fetch() won’t reject on HTTP error status even if the response is an HTTP 500. Instead, it will resolve normally (with ok status set to false). So you need to add codes checking the response in then()
like below.
...
.then((response) => {
if (!response.ok) {
// error processing
throw 'Error';
}
return response.json()
})
...
In ur JavaScript file in location.reload() You shouldn't add a semi-colon after that curly brace and parentheses })
本文标签: djangoFetch returning 500(internal server error) JavaScriptStack Overflow
版权声明:本文标题:django - Fetch returning 500(internal server error) JavaScript - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743897643a2558083.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论