IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Angular Discussion :

Requete bloquée par CORS entre un client angular et une web api 2.0 .net framework


Sujet :

Angular

  1. #1
    Membre habitué Avatar de Nadinette
    Femme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2012
    Messages
    264
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2012
    Messages : 264
    Points : 144
    Points
    144
    Par défaut Requete bloquée par CORS entre un client angular et une web api 2.0 .net framework
    Salut,

    J'ai bien vu qu'il y avait eu des échanges sur le sujet (j'ai d'ailleurs suivi les conseils) et malgrès ça, j'ai toujours l'erreur :

    Access to XMLHttpRequest at aaaa from origin bbbb has been blocked by CORS policy: Response to preflight request doesn't pass access control check: It does not have HTTP ok status.

    Lorsque j'essaye d'accéder à mon api depuis mon client angular.

    Voici mon code angular :

    environment.ts
    Code TypeScript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    export const environment = {
      production: false,
      language:"fr-fr",
      BBApiServiceEndPoint: "http://BB2/api/",
      httpOptions : {
        headers: new HttpHeaders({
          'Access-Control-Allow-Origin':'http://BB2/*',
          'Access-Control-Allow-Headers' : 'X-Requested-With, Content-Type',
          'Access-Control-Allow-Methods' : 'POST, GET, OPTION',
          'Content-Type':  'application/json'
        })
      }
    };

    BBApiService.ts
    Code TypeScript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
      getAllTests(): Observable<any> {
        var endPointUrl : string = (new ApiHelperService()).buildBBUri("bbAllTests");
        var data:any;
        return this.http
          .get<BbTest>(endPointUrl,environment.httpOptions);
      }
    }

    Côté .net :
    WebApiConfig.cs
    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
        public static class WebApiConfig
        {
            public static void Register(HttpConfiguration config)
            {
                // Web API configuration and services
                config.EnableCors();
     
                // Web API routes
                config.MapHttpAttributeRoutes();
     
                config.Routes.MapHttpRoute(
                    name: "DefaultApi",
                    routeTemplate: "api/{language}/{controller}/{id}",
                    defaults: new { language = PortalEnvironment.DefaultLanguage, id = RouteParameter.Optional }
                );
     
                config.Formatters.Remove(config.Formatters.XmlFormatter);
            }
        }

    dans le web.config
    Code xml : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <system.webServer>
            <httpProtocol>
                <customHeaders>
                    <add name="Access-Control-Allow-Origin"
                         value="*" />
                </customHeaders>
            </httpProtocol>
    </system.webServer>

    Dans ma web API:
    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
            [HttpGet]
            [Route("api/{language}/bbAllTests")]
            [EnableCors("*", "*", "*")]
            public string Profiles()
            {
                string toReturn = "";
                try
                {
                    Assembly currentAssembly = Assembly.GetAssembly(this.GetType());
                    var profiles = CommonContractsAndTools.ConfigTools.GetResourceFileText(currentAssembly, "profiles." + PortalEnvironment.Env + ".config");
                    var xDocument = XDocument.Parse(profiles);
                    var sb = new StringBuilder();
                    JsonSerializer.Create().Serialize(new CustomJsonWriter(new StringWriter(sb)), xDocument.FirstNode);
                    toReturn = sb.ToString();
                    BBLogger.Info("Profiles successfully found");
                }
                catch (Exception ex)
                {
                    BBLogger.Error(ex);
                }
                return toReturn;
            }

    Je ne comprends pas pourquoi ça ne fonctionne pas.

    Ne m'envoyez pas dans google j'ai lu plusieurs pages qui me disent de faire ce que j'ai fait, il doit manquer un truc quelque part, je ne trouve pas.

    D'avance merci pour votre aide

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2019
    Messages
    707
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2019
    Messages : 707
    Points : 1 030
    Points
    1 030
    Par défaut
    pour ma part, j'ai eu le meme problème mais sur un serveur apache. j'ai du en plus, ajouter dans .htaccess des allow origin
    je ne connais pas les serveurs pour .net et si il y a une chose similaire...

  3. #3
    Membre habitué Avatar de Nadinette
    Femme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2012
    Messages
    264
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2012
    Messages : 264
    Points : 144
    Points
    144
    Par défaut
    Une vrai galère, ça fait plusieurs jours que je tourne en rond, je deviens dingue !

  4. #4
    Membre à l'essai
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2019
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2019
    Messages : 13
    Points : 21
    Points
    21
    Par défaut
    dans l'outil de dev du navigateur
    dans reseau (network)

    voir l'onglet : headers
    ensuite la partie : responses headers
    access-control-allow-origin: https://xxxxxxxxx.xx

    est ce que dans la réponse retourné par ton serveur et donc dans : access-control-allow-origin: https://xxxxxxxxx.xx
    il y a bien l'url de ton site ?

    ce qui fait que dans la réponse provenant du serveur, il indique au navigateur qu'il autorise le site : https://xxxxxxxxx.xx à communiquer avec lui

  5. #5
    Membre habitué Avatar de Nadinette
    Femme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2012
    Messages
    264
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2012
    Messages : 264
    Points : 144
    Points
    144
    Par défaut
    Bon, j'ai trouvé. C'est côté client qu'il ne fallait pas mettre les options dans la requête.

    J'ai créé un filtre
    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    using System;
    using System.Web.Mvc;
     
    public class AllowCrossSiteAttribute : ActionFilterAttribute
    {
        public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
            filterContext.RequestContext.HttpContext.Response.AddHeader("Access-Control-Allow-Origin", "*");
            filterContext.RequestContext.HttpContext.Response.AddHeader("Access-Control-Allow-Headers", "*");
            filterContext.RequestContext.HttpContext.Response.AddHeader("Access-Control-Allow-Credentials", "false");
            base.OnActionExecuting(filterContext);
        }
    }

    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
      getAllTests(): Observable<any> {
        var endPointUrl : string = (new ApiHelperService()).buildBBUri("bbAllTests");
        var data:any;
        return this.http
          .get<BbInventory>(endPointUrl);
      }

    Là ça fonctionne...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 3
    Dernier message: 23/03/2011, 17h11
  2. sécurité et confidentialité entre un client et un serveur web
    Par contremaitre dans le forum Sécurité
    Réponses: 4
    Dernier message: 06/01/2010, 21h24
  3. Clients présents par mois entre 2 dates
    Par Bragon35 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 26/09/2009, 22h49
  4. client ftp bloqué par parefeu windows
    Par seneque dans le forum Windows XP
    Réponses: 7
    Dernier message: 10/09/2009, 09h37
  5. Réponses: 2
    Dernier message: 26/03/2008, 00h01

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo