Я использую колбу для создания некоторых конечных точек для проекта блокчейна.Мне нужно принять данные JSON от клиента AJAX.Так как это кроссовая платформа, я использую фляжки.Но я не могу найти решение.Это не работает
Я уже пытался сделать
from flask import Flask
from flask_cors import CORS
app = Flask(__name__)
CORS(app, origin = '*')
В основном мой клиентский код выглядит следующим образом.
$.ajax({
url: 'http://localhost:8080/ratings/new',
dataType: 'json',
type: 'POST',
contentType: 'application/json',
data: json1,
crossDomain: true,
xhrFields: {
withCredentials: true
},
processData: false,
beforeSend: function (xhr) {
//xhr.setRequestHeader('Content-Type', 'application/json; charset=utf-8');
xhr.setRequestHeader('Access-Control-Allow-Origin', '*');
},
success: function (data, textStatus, jQxhr)
{
$('body').append(data);
console.log(data);
},
error: function (jqXhr, textStatus, errorThrown) {
console.log(errorThrown);
}
});
И на моем сервере у меня есть конечная точка
@app.route('/ratings/new', methods = ['POST','OPTIONS'])
def rating():
values = request.get_json()
if values == None:
return "No data received", 400
#ratings = values['rating']
index = blockchain.new_ratings(values)
response = {
'Message': f'New transaction will be added to the block {index}',
}
response = jsonify(response)
response.headers.add('Access-Control-Allow-Origin','*')
return response, 201
На стороне сервера я не получаю необходимые данные, а на стороне клиента я получаю следующую ошибку.
Access to XMLHttpRequest at 'http://localhost:8080/ratings/new' from origin 'null' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: The value of the 'Access-Control-Allow-Credentials' header in the response is '' which must be 'true' when the request's credentials mode is 'include'. The credentials mode of requests initiated by the XMLHttpRequest is controlled by the withCredentials attribute.
Пожалуйста, помогите мне решить эту проблему.Заранее спасибо.