Angular post request to c# web api 2 RESTful web service
up vote
0
down vote
favorite
I'm trying to send a http post request from angular client to C# web API 2 RESTful web service.
My client:
var userId = "123456";
var password = "654321";
const headersContent = new Headers().set('Content-Type', 'application/x-www-form-urlencoded');
var url = "http://localhost:35615/login"
this.http.post(url, {
"userId": userId,
"password": password
}, {withCredentials: true}).subscribe(res => {
console.log(res);
});
My Server:
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] string parameters)
{
//Deserialize the parameters.
}
My problem is the parameters var is null although the post request in the network tab in chrome includes the data.
Can someone explain me what I'm doing wrong and how can I fix it?
Thank you!
c# angular rest http asp.net-web-api2
add a comment |
up vote
0
down vote
favorite
I'm trying to send a http post request from angular client to C# web API 2 RESTful web service.
My client:
var userId = "123456";
var password = "654321";
const headersContent = new Headers().set('Content-Type', 'application/x-www-form-urlencoded');
var url = "http://localhost:35615/login"
this.http.post(url, {
"userId": userId,
"password": password
}, {withCredentials: true}).subscribe(res => {
console.log(res);
});
My Server:
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] string parameters)
{
//Deserialize the parameters.
}
My problem is the parameters var is null although the post request in the network tab in chrome includes the data.
Can someone explain me what I'm doing wrong and how can I fix it?
Thank you!
c# angular rest http asp.net-web-api2
add a comment |
up vote
0
down vote
favorite
up vote
0
down vote
favorite
I'm trying to send a http post request from angular client to C# web API 2 RESTful web service.
My client:
var userId = "123456";
var password = "654321";
const headersContent = new Headers().set('Content-Type', 'application/x-www-form-urlencoded');
var url = "http://localhost:35615/login"
this.http.post(url, {
"userId": userId,
"password": password
}, {withCredentials: true}).subscribe(res => {
console.log(res);
});
My Server:
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] string parameters)
{
//Deserialize the parameters.
}
My problem is the parameters var is null although the post request in the network tab in chrome includes the data.
Can someone explain me what I'm doing wrong and how can I fix it?
Thank you!
c# angular rest http asp.net-web-api2
I'm trying to send a http post request from angular client to C# web API 2 RESTful web service.
My client:
var userId = "123456";
var password = "654321";
const headersContent = new Headers().set('Content-Type', 'application/x-www-form-urlencoded');
var url = "http://localhost:35615/login"
this.http.post(url, {
"userId": userId,
"password": password
}, {withCredentials: true}).subscribe(res => {
console.log(res);
});
My Server:
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] string parameters)
{
//Deserialize the parameters.
}
My problem is the parameters var is null although the post request in the network tab in chrome includes the data.
Can someone explain me what I'm doing wrong and how can I fix it?
Thank you!
c# angular rest http asp.net-web-api2
c# angular rest http asp.net-web-api2
asked Nov 7 at 13:04
KonRow
206
206
add a comment |
add a comment |
4 Answers
4
active
oldest
votes
up vote
1
down vote
accepted
You are passing an anonymous object with properties "UserId" and "Password".
Make a Data Contract class which has those 2 properties as strings and use it in the parameters of your REST method.
public IHttpActionResult LoginReq([FromBody] User user) { ... }
add a comment |
up vote
1
down vote
If you are passing an object from your Angular POST request the Web API POST method can be changed to accept an User defined type as parameter to read it from the request body.
You can create the below user defined type in C# to bind UserId and Password properties from your angular Post request
public class UserLogin
{
public int UserId { get; set; }
public string Password { get; set; }
}
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] UserLogin user)
{
//Deserialize the parameters.
}
I would recommend going through this documentation to read more about parameter binding in Web API. Believe me its worth your time.
add a comment |
up vote
0
down vote
You post userId
and password
, but expect String parameters
. Change to String userId
, String password
. The Modelbinder only will bind matching properties.
Tried to do it like this LoginReq([FromBody] string userId, [FromBody] string password) - same result, the parameters are null
– KonRow
Nov 7 at 13:10
try parameter=value without qoutes in the post, so userId:userId, password:password
– Cookinski
Nov 7 at 13:13
add a comment |
up vote
0
down vote
Just add JSON.stringify()
you are sending an object to the server which expects only a string as a parameter so make it as a string and pass the value otherwise create a model with userid
and password
in your server side and mention that object
let obj = {
"userId": userId,
"password": password
};
this.http.post(url, JSON.stringify(obj), {withCredentials: true}).subscribe(res => {
console.log(res);
});
The above code will work with the string parameters
- Going forward try to use model and pass the object from Angular
Happy Coding !!
add a comment |
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
1
down vote
accepted
You are passing an anonymous object with properties "UserId" and "Password".
Make a Data Contract class which has those 2 properties as strings and use it in the parameters of your REST method.
public IHttpActionResult LoginReq([FromBody] User user) { ... }
add a comment |
up vote
1
down vote
accepted
You are passing an anonymous object with properties "UserId" and "Password".
Make a Data Contract class which has those 2 properties as strings and use it in the parameters of your REST method.
public IHttpActionResult LoginReq([FromBody] User user) { ... }
add a comment |
up vote
1
down vote
accepted
up vote
1
down vote
accepted
You are passing an anonymous object with properties "UserId" and "Password".
Make a Data Contract class which has those 2 properties as strings and use it in the parameters of your REST method.
public IHttpActionResult LoginReq([FromBody] User user) { ... }
You are passing an anonymous object with properties "UserId" and "Password".
Make a Data Contract class which has those 2 properties as strings and use it in the parameters of your REST method.
public IHttpActionResult LoginReq([FromBody] User user) { ... }
edited Nov 12 at 12:30
answered Nov 7 at 13:21
Julian Peil
657
657
add a comment |
add a comment |
up vote
1
down vote
If you are passing an object from your Angular POST request the Web API POST method can be changed to accept an User defined type as parameter to read it from the request body.
You can create the below user defined type in C# to bind UserId and Password properties from your angular Post request
public class UserLogin
{
public int UserId { get; set; }
public string Password { get; set; }
}
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] UserLogin user)
{
//Deserialize the parameters.
}
I would recommend going through this documentation to read more about parameter binding in Web API. Believe me its worth your time.
add a comment |
up vote
1
down vote
If you are passing an object from your Angular POST request the Web API POST method can be changed to accept an User defined type as parameter to read it from the request body.
You can create the below user defined type in C# to bind UserId and Password properties from your angular Post request
public class UserLogin
{
public int UserId { get; set; }
public string Password { get; set; }
}
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] UserLogin user)
{
//Deserialize the parameters.
}
I would recommend going through this documentation to read more about parameter binding in Web API. Believe me its worth your time.
add a comment |
up vote
1
down vote
up vote
1
down vote
If you are passing an object from your Angular POST request the Web API POST method can be changed to accept an User defined type as parameter to read it from the request body.
You can create the below user defined type in C# to bind UserId and Password properties from your angular Post request
public class UserLogin
{
public int UserId { get; set; }
public string Password { get; set; }
}
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] UserLogin user)
{
//Deserialize the parameters.
}
I would recommend going through this documentation to read more about parameter binding in Web API. Believe me its worth your time.
If you are passing an object from your Angular POST request the Web API POST method can be changed to accept an User defined type as parameter to read it from the request body.
You can create the below user defined type in C# to bind UserId and Password properties from your angular Post request
public class UserLogin
{
public int UserId { get; set; }
public string Password { get; set; }
}
[Route("login")]
[HttpPost]
public IHttpActionResult LoginReq([FromBody] UserLogin user)
{
//Deserialize the parameters.
}
I would recommend going through this documentation to read more about parameter binding in Web API. Believe me its worth your time.
answered Nov 7 at 15:53
Karthik
315
315
add a comment |
add a comment |
up vote
0
down vote
You post userId
and password
, but expect String parameters
. Change to String userId
, String password
. The Modelbinder only will bind matching properties.
Tried to do it like this LoginReq([FromBody] string userId, [FromBody] string password) - same result, the parameters are null
– KonRow
Nov 7 at 13:10
try parameter=value without qoutes in the post, so userId:userId, password:password
– Cookinski
Nov 7 at 13:13
add a comment |
up vote
0
down vote
You post userId
and password
, but expect String parameters
. Change to String userId
, String password
. The Modelbinder only will bind matching properties.
Tried to do it like this LoginReq([FromBody] string userId, [FromBody] string password) - same result, the parameters are null
– KonRow
Nov 7 at 13:10
try parameter=value without qoutes in the post, so userId:userId, password:password
– Cookinski
Nov 7 at 13:13
add a comment |
up vote
0
down vote
up vote
0
down vote
You post userId
and password
, but expect String parameters
. Change to String userId
, String password
. The Modelbinder only will bind matching properties.
You post userId
and password
, but expect String parameters
. Change to String userId
, String password
. The Modelbinder only will bind matching properties.
answered Nov 7 at 13:07
Cookinski
715
715
Tried to do it like this LoginReq([FromBody] string userId, [FromBody] string password) - same result, the parameters are null
– KonRow
Nov 7 at 13:10
try parameter=value without qoutes in the post, so userId:userId, password:password
– Cookinski
Nov 7 at 13:13
add a comment |
Tried to do it like this LoginReq([FromBody] string userId, [FromBody] string password) - same result, the parameters are null
– KonRow
Nov 7 at 13:10
try parameter=value without qoutes in the post, so userId:userId, password:password
– Cookinski
Nov 7 at 13:13
Tried to do it like this LoginReq([FromBody] string userId, [FromBody] string password) - same result, the parameters are null
– KonRow
Nov 7 at 13:10
Tried to do it like this LoginReq([FromBody] string userId, [FromBody] string password) - same result, the parameters are null
– KonRow
Nov 7 at 13:10
try parameter=value without qoutes in the post, so userId:userId, password:password
– Cookinski
Nov 7 at 13:13
try parameter=value without qoutes in the post, so userId:userId, password:password
– Cookinski
Nov 7 at 13:13
add a comment |
up vote
0
down vote
Just add JSON.stringify()
you are sending an object to the server which expects only a string as a parameter so make it as a string and pass the value otherwise create a model with userid
and password
in your server side and mention that object
let obj = {
"userId": userId,
"password": password
};
this.http.post(url, JSON.stringify(obj), {withCredentials: true}).subscribe(res => {
console.log(res);
});
The above code will work with the string parameters
- Going forward try to use model and pass the object from Angular
Happy Coding !!
add a comment |
up vote
0
down vote
Just add JSON.stringify()
you are sending an object to the server which expects only a string as a parameter so make it as a string and pass the value otherwise create a model with userid
and password
in your server side and mention that object
let obj = {
"userId": userId,
"password": password
};
this.http.post(url, JSON.stringify(obj), {withCredentials: true}).subscribe(res => {
console.log(res);
});
The above code will work with the string parameters
- Going forward try to use model and pass the object from Angular
Happy Coding !!
add a comment |
up vote
0
down vote
up vote
0
down vote
Just add JSON.stringify()
you are sending an object to the server which expects only a string as a parameter so make it as a string and pass the value otherwise create a model with userid
and password
in your server side and mention that object
let obj = {
"userId": userId,
"password": password
};
this.http.post(url, JSON.stringify(obj), {withCredentials: true}).subscribe(res => {
console.log(res);
});
The above code will work with the string parameters
- Going forward try to use model and pass the object from Angular
Happy Coding !!
Just add JSON.stringify()
you are sending an object to the server which expects only a string as a parameter so make it as a string and pass the value otherwise create a model with userid
and password
in your server side and mention that object
let obj = {
"userId": userId,
"password": password
};
this.http.post(url, JSON.stringify(obj), {withCredentials: true}).subscribe(res => {
console.log(res);
});
The above code will work with the string parameters
- Going forward try to use model and pass the object from Angular
Happy Coding !!
answered Nov 7 at 13:34
Rahul Swamynathan
786212
786212
add a comment |
add a comment |
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53190029%2fangular-post-request-to-c-sharp-web-api-2-restful-web-service%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown