POST上的模型绑定失败

时间:2017-09-26 15:33:15

标签: c# angular asp.net-core angular-http

我有一个ASP.Net Core 2.0项目,我将其用作web api。客户端使用Angular 4完成。当我将我的表单数据从我的角度服务发布到我的API时,服务器端的模型属性始终为null。我不确定我在这里做错了什么。我尝试过使用application/jsonapplication/x-www-form-urlencoded的各种组合。我还尝试了[FromBody][FromForm]属性,在这两种情况下,我的模型上的属性都为空。

在我的帖子中,我是否在角度方面做错了什么?

enter image description here

我已经验证我发布的json字符串(显示在屏幕截图中)包含我预期的表单数据。它虽然在服务器上到达null。

这是我的角色服务

import { Injectable, OnInit } from '@angular/core';
import { Http, URLSearchParams, Headers, RequestOptions, Response } from '@angular/http';
import 'rxjs/add/operator/toPromise';
import 'rxjs/add/operator/mergeMap';

import { CryptoData } from './cryptodata.interface';
import { Result } from './result.model';

@Injectable()
export class EncryptService implements OnInit {
    private options: RequestOptions;

    constructor(private http: Http) {
        this.options = new RequestOptions({
                headers: new Headers({ 'Content-Type': 'application/x-www-form-urlencoded' })
            })
    }

    ngOnInit() {
    }

    encrypt(data: CryptoData): Promise<Result> {
        let json: any = JSON.stringify(data);

        return this.http
        .post('/api/encrypt', json, this.options)
        .toPromise()
        .then(response => response.json());
    }

    decrypt(data: CryptoData) {

    }
}

这是我的控制者:

[Produces("application/json")]
[AllowAnonymous]
public class CryptoController : Controller
{
    [HttpPost("~/api/Encrypt")]
    public IActionResult Encrypt([FromForm] CryptoRequest request)
    {
        // Testing
        return base.Ok(new Result(data: request.Content));
    }
}

1 个答案:

答案 0 :(得分:1)

[FromBody] Content-Type:application / json 在asp net core中使用相同的请求对我很有效。我从firefox中的插件发送了数据:{ "key" : "1", "content" : "cont" }

enter image description here