Bỏ qua để đến Nội dung
Menu
Câu hỏi này đã bị gắn cờ
10 Trả lời
30792 Lượt xem

Can't I use Odoo endpoints from controller as API? from postman I can get this data. If I can then, my fetch function from JS layer providing this error. I'll be grateful if you can help me to find the problem.


Here is my controller structure,


@http.route('/task/get', type='json', auth='none', cors="*", csrf="False")
def get_task_data(self):
print("Function Called")
if request.httprequest.method == "GET":

data = {
'name': 'Tarikol Islam',
'age': '25',
}
# return json.dump(data) # Tried this one too
return data

//and Here is my JS fetch request,

async function getAllData(url = "http://localhost:8069/task/get") {
const response = await fetch(url, {
method: "GET",
mode: "cors",
cache: "no-cache",
credentials: "same-origin",
headers: {
"Content-Type": "application/json",
},
redirect: "follow",
referrerPolicy: "no-referrer",
});
const data = await response.json();
console.log(data);
}

and the error(In tittle) show in chrome console is,


Uncaught (in promise) SyntaxError: 

Bad Request

Invalid JSON data: ''


Ảnh đại diện
Huỷ bỏ

1.Ensure that the server is properly handling the request and returning a valid JSON response.
2. Test the API endpoint using tools like Postman or cURL to verify the response.
3.Check the URL to ensure it is correct and accessible.
4.If the server is returning a non-empty response but it still fails to parse as JSON,
double check the formatting of the response.Ensure that it starts with a {character and ends with a } character, representing a valid JSON object. If the response
is an array, make sure it starts with a [ character and ends with a ] character.

Tác giả

POSTMAN can got response successfully but have to give empty {} in body of 'GET' request.

Câu trả lời hay nhất
Looking to enhance your brand’s reputation? <a href="https://reviewexpress.net/product/trustpilot-reviews/">Buy Trustpilot Reviews</a> can help you stand out! Get authentic feedback that drives trust and attracts customers. Contact us today at +918302803616 to learn more and start transforming your online presence!

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

Great rhythm and challenging gameplay! Even though it's simple,  Friday Night Funkin' is really addictive and makes me want to play more.

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

Retrieve data successfully using Postman but still error

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

Hi Hru?

Ảnh đại diện
Huỷ bỏ

seo service london http://truediamond.co.uk/Wow! Thank you! I permanently needed to write on my blog something like that.

Câu trả lời hay nhất

How could i resolve this issue for my sell tickets online page

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

It's trying to parse the error response of a missing asset. 

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

thank you!

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

Thanks for the answer!

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

Any update?

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất
  1. Make sure that your controller is correctly receiving the request and returning a valid JSON response. In your case, you are returning a dictionary object data. To ensure that it is returned as JSON, you can modify your code as follows:
pythonCopy codeimport json

@http.route('/task/get', type='json', auth='none', cors="*", csrf="False")
def get_task_data(self):
    if request.httprequest.method == "GET":
        data = {
            'name': 'Tarikol Islam',
            'age': '25',
        }
        return json.dumps(data)

By using json.dumps(data), you are converting the Python dictionary data into a JSON string.

  1. In your JavaScript code, you can modify the fetch request to handle the response properly:
javascriptCopy codeasync function getAllData(url = "http://localhost:8069/task/get") {
  const response = await fetch(url, {
    method: "GET",
    mode: "cors",
    cache: "no-cache",
    credentials: "same-origin",
    headers: {
      "Content-Type": "application/json",
    },
    redirect: "follow",
    referrerPolicy: "no-referrer",
  });
  const data = await response.json();
  console.log(data);
}

getAllData();

The response.json() method parses the response body as JSON, so you can access the data as a JavaScript object.

Make sure to replace http://localhost:8069/task/get with the correct URL and port of your Odoo instance.

With these modifications, your controller should return valid JSON data, and your JavaScript code should be able to fetch and handle the response correctly.

If you are still experiencing issues, please provide any additional error messages or details from the console that could help in identifying the problem.


Ảnh đại diện
Huỷ bỏ
Tác giả

I copied exactly what you write, but problem remains. Basically in returns it got a html response, and make an error.
undefined:1
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
SyntaxError: Unexpected token < in JSON at position 0
at JSON.parse (<anonymous>)

Bài viết liên quan Trả lời Lượt xem Hoạt động
2
thg 5 22
13742
2
thg 4 22
3967
1
thg 4 22
3053
1
thg 11 23
9922
0
thg 11 23
2017