我有一个ASP.Net Core 2.0项目,我将其用作web api。客户端使用Angular 4完成。当我将我的表单数据从我的角度服务发布到我的API时,服务器端的模型属性始终为null。我不确定我在这里做错了什么。我尝试过使用application/json
和application/x-www-form-urlencoded
的各种组合。我还尝试了[FromBody]
和[FromForm]
属性,在这两种情况下,我的模型上的属性都为空。
在我的帖子中,我是否在角度方面做错了什么?
我已经验证我发布的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));
}
}