【问题标题】:Http Post request not sending requests on AngularHttp Post 请求未在 Angular 上发送请求
【发布时间】:2018-04-18 22:02:08
【问题描述】:

我正在尝试学习如何使用 Http(不是 Http 客户端)向我的 api 服务发送 http post 请求,但甚至没有收到请求。

URL 正确,API 名称也正确(它们匹配)...

从对某些类型的用户在 cmets 中进行的第一次分析来看,问题似乎与 API 服务器有关,该服务器无法访问并且似乎不存在。

你能告诉我我做错了什么吗?

这是我的代码。

REGISTRATION COMPONENT .ts 方法(调用 USER SERVICE):

registerUser({ value, valid }: { value: UserRegistration, valid: boolean }) {
    this.submitted = true;
    this.isRequesting = true;
    this.errors='';
    if(valid)
    {
        this.userService.register(value.email,value.password,value.firstName,value.lastName,value.location)
                  .finally(() => this.isRequesting = false)
                  .subscribe(
                    result  => {if(result){
                        this.router.navigate(['/login'],{queryParams: {brandNew: true,email:value.email}});                         
                    }},
                    errors =>  this.errors = errors);
    }      
 } 

USER SERVICE .ts(由 REGISTRATION COMPONENT 调用):

register(email: string, password: string, firstName: string, lastName: string,location: string): Observable<UserRegistration> {
let body = JSON.stringify({ email, password, firstName, lastName,location });
let headers = new Headers({ 'Content-Type': 'application/json' });
    let options = new RequestOptions({ headers: headers });

    console.log(this.baseUrl); //URL is correct

return this.http.post(this.baseUrl + "/Accounts/NewUser", body, options)
  .map(res => true)
  .catch(this.handleError);
 }  

API方法

[Route("api/[controller]")] 
public class AccountsController : Controller
{
    //...
    // POST api/Accounts/Newuser
    [HttpPost("NewUser")]
    public async Task<IActionResult> NewUser([FromBody]RegistrationViewModel model)
    {
         //....

根据要求:

网络铬标签

Network

标题详情

Headers

在哪里预览显示“加载响应数据失败”

控制台错误:

Error


根据要求:

Startup.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.SpaServices.Webpack;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.EntityFrameworkCore;
using MyFirstAngularApp.Data;
using MyFirstAngularApp.Models;
using MyFirstAngularApp.Auth;
using Microsoft.Extensions.DependencyInjection.Extensions;
using Microsoft.AspNetCore.Http;
using Microsoft.IdentityModel.Tokens;
using Microsoft.AspNetCore.Authentication.JwtBearer;
using MyFirstAngularApp.Helpers;
using MyFirstAngularApp.Models.Entities;
using Microsoft.AspNetCore.Identity;
using System.Text;
using AutoMapper;
using FluentValidation.AspNetCore;

namespace MyFirstAngularApp
{
    public class Startup
    {
        private const string SecretKey = //MY SECRET KEY
        private readonly SymmetricSecurityKey _signingKey = new SymmetricSecurityKey(Encoding.ASCII.GetBytes(SecretKey));

        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddMvc();

            //connecting to database
            var connectionString = //MY CONNECTION STRING
            services.AddDbContext<MyDataContext>(options => options.UseSqlServer(connectionString));

            //connect to authentication database
            var connectionEntityString = //ANOTHER CONNECION STRING
            services.AddDbContext<ApplicationDbContext>(options => options.UseSqlServer(connectionEntityString));

            //managing tokens
            services.AddSingleton<IJwtFactory, JwtFactory>();

            services.TryAddTransient<IHttpContextAccessor, HttpContextAccessor>();

            // jwt wire up
            // Get options from app settings
            var jwtAppSettingOptions = Configuration.GetSection(nameof(JwtIssuerOptions));

            // Configure JwtIssuerOptions
            services.Configure<JwtIssuerOptions>(options =>
            {
                options.Issuer = jwtAppSettingOptions[nameof(JwtIssuerOptions.Issuer)];
                options.Audience = jwtAppSettingOptions[nameof(JwtIssuerOptions.Audience)];
                options.SigningCredentials = new SigningCredentials(_signingKey, SecurityAlgorithms.HmacSha256);
            });

            var tokenValidationParameters = new TokenValidationParameters
            {
                ValidateIssuer = true,
                ValidIssuer = jwtAppSettingOptions[nameof(JwtIssuerOptions.Issuer)],

                ValidateAudience = true,
                ValidAudience = jwtAppSettingOptions[nameof(JwtIssuerOptions.Audience)],

                ValidateIssuerSigningKey = true,
                IssuerSigningKey = _signingKey,

                RequireExpirationTime = false,
                ValidateLifetime = true,
                ClockSkew = TimeSpan.Zero
            };

            services.AddAuthentication(options =>
            {
                options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
                options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;

            }).AddJwtBearer(configureOptions =>
            {
                configureOptions.ClaimsIssuer = jwtAppSettingOptions[nameof(JwtIssuerOptions.Issuer)];
                configureOptions.TokenValidationParameters = tokenValidationParameters;
                configureOptions.SaveToken = true;
            });

            // api user claim policy
            services.AddAuthorization(options =>
            {
                options.AddPolicy("ApiUser", policy => policy.RequireClaim(Constants.Strings.JwtClaimIdentifiers.Rol, Constants.Strings.JwtClaims.ApiAccess));
            });

            // add identity
            var builder = services.AddIdentityCore<AppUser>(o =>
            {
                // configure identity options
                o.Password.RequireDigit = false;
                o.Password.RequireLowercase = false;
                o.Password.RequireUppercase = false;
                o.Password.RequireNonAlphanumeric = false;
                o.Password.RequiredLength = 6;
            });
            builder = new IdentityBuilder(builder.UserType, typeof(IdentityRole), builder.Services);
            builder.AddEntityFrameworkStores<ApplicationDbContext>().AddDefaultTokenProviders();

            services.AddAutoMapper();
            services.AddMvc().AddFluentValidation(fv => fv.RegisterValidatorsFromAssemblyContaining<Startup>());
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
                app.UseWebpackDevMiddleware(new WebpackDevMiddlewareOptions
                {
                    HotModuleReplacement = true
                });
            }
            else
            {
                app.UseExceptionHandler("/Home/Error");
            }

            app.UseStaticFiles();

            app.UseMvc(routes =>
            {
                routes.MapRoute(
                    name: "default",
                    template: "{controller=Home}/{action=Index}/{id?}");

                routes.MapSpaFallbackRoute(
                    name: "spa-fallback",
                    defaults: new { controller = "Home", action = "Index" });
            });
        }
    }
}

【问题讨论】:

    标签: c# angular


    【解决方案1】:

    让你尝试在启动类中配置

          if (env.IsDevelopment())
      {
        app.UseDeveloperExceptionPage();
      }
    
      app.UseExceptionHandler(
      builder =>
      {
        builder.Run(
                async context =>
                {
                  context.Response.StatusCode = (int)HttpStatusCode.InternalServerError;
                  context.Response.Headers.Add("Access-Control-Allow-Origin", "*");
    
                  var error = context.Features.Get<IExceptionHandlerFeature>();
                  if (error != null)
                  {
                    await context.Response.WriteAsync(error.Error.Message).ConfigureAwait(false);
                  }
                });
      });
    
      app.UseDefaultFiles();
      app.UseStaticFiles();
      app.UseMvc();
    

    【讨论】:

      【解决方案2】:

      下面的代码和应用程​​序存在两个问题:

      首先是我没有使用用户 Stefan 在他的回答中建议的 startup.cs 配置。

      第二个是我将静态端口地址传递给我的 URL。
      根据 cmets 中用户 Deadpool 的建议,我已经通过在我的服务模块中使用 this._apiURI = '/api'; 而不是 this._apiURI = 'http://localhost:5000/api'; 解决了

      【讨论】:

        猜你喜欢
        • 2018-08-04
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2019-09-15
        • 2020-07-14
        相关资源
        最近更新 更多