angularjs 6 python django rest framework crossdomain api вызов проблема

Я настроил django rest framework с помощью python 3. И API отлично работает в почтальоне. Но я столкнулся с проблемой перекрестного домена, когда я называю это api через мой проект angualar 6.

ОС: Mac OS

Я включил oauth2 для аутентификации. Он хорошо работает с почтальоном

URL- адрес API: http://127.0.0.1:7777/api/v1/token/

Угловой URL-адрес сайта: http: // localhost: 5000 / # / login

Когда я вызывал это с помощью angualrjs, он показывает следующую ошибку.

Mozilla:

Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://127.0.0.1:7777/api/v1/token/. (Reason: CORS header a€?Access-Control-Allow-Origina€™ missing).

Сафари:

Failed to load resource: Origin http://localhost:5000 is not allowed by Access-Control-Allow-Origin.
XMLHttpRequest cannot load http://127.0.0.1:7777/api/v1/token/. Origin http://localhost:5000 is not allowed by Access-Control-Allow-Origin.

Хром:

 Failed to load http://127.0.0.1:7777/api/v1/token/: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:5000' is therefore not allowed access.

Параметры python settings.py cors:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django.contrib.sites',
    'django.contrib.flatpages',
    'widget_tweaks',
    'rest_framework',
    'oauth2_provider',
    'corsheaders',
] + get_core_apps() 
SITE_ID = 1


ALLOWED_HOSTS = ['127.0.0.1']
CORS_ORIGIN_WHITELIST = ('localhost:5000')
CORS_ORIGIN_ALLOW_ALL = True



MIDDLEWARE_CLASSES = [

    'django.middleware.security.SecurityMiddleware',
    'corsheaders.middleware.CorsMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

Я также установил oscarcommerce, oauth2, django rest framework. Я настроил три других веб-сайта в моей системе с angularjs6 и python 2.7. Все работают нормально. Эта проблема возникает только в этом проекте python 3.

angularjs,django,python-3.x,django-rest-framework,cross-browser,

0

Ответов: 2


0

Добавьте код ниже в свой файл settings.py

# Corsheaders settings
CORS_ORIGIN_ALLOW_ALL = True
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_WHITELIST = ('*')

это будет работать....


0

Попробуй это:

ALLOWED_HOSTS = []

CORS_ORIGIN_WHITELIST = (    
'127.0.0.1:7777',
'localhost:5000')

CORS_ORIGIN_ALLOW_ALL = True

Также обратитесь к этой ссылке для получения дополнительной информации.

angularjs, Джанго, питон-3.x, Джанго-отдых-рамка, кросс-браузер,
Похожие вопросы