Hallo Ich entwickle eine Anwendung mit Web API 2 und Zugriff auf Anrufe über angularjs. Ich erstellte Web-API-Anrufe und gehostet in IIS-Server (öffentliche IP). Ich greife auf die web api2-Methoden im folgenden Format zu.Nicht in der Lage, auf Web-API-Aufrufe in einem API/Controller-Format zuzugreifen
$http.post('http://111.93.133.98:4500/api/NCT_Login/', credentials).success(function (response) { alert(response); });
Dies ist meine Web-API-Datei config.cs.
routeTemplate: "api/{controller}/{id}"
Dies ist mein Controller-Code.
public class NCT_LoginController : ApiController
{
public NCTEntities entityObject = new NCTEntities();
[EnableCors(origins: "*", headers: "*", methods: "GET, POST, PUT, DELETE")]
public IHttpActionResult Post(LoginClass obj)
{
try
{
if (ModelState.IsValid)
{
obj.User_Password = PasswordEncryption.sha256_hash(obj.User_Password);
bool result = (from c in entityObject.NCT_UserRegistration where obj.User_Name ==c.User_Name && obj.User_Password == c.User_Password select c).Any();
if(result==true)
{
obj.UserRole = (from c in entityObject.NCT_UserRegistration where obj.User_Name == c.User_Name && obj.User_Password == c.User_Password select c.User_Role).FirstOrDefault();
obj.Success = 0;
obj.User_Password = "";
var response = Request.CreateResponse(HttpStatusCode.OK, obj);
var newSessionId = new SessionIDManager().CreateSessionID(HttpContext.Current);
var cookie = new CookieHeaderValue("session-id", newSessionId);
cookie.Expires = DateTimeOffset.Now.AddDays(1);
cookie.Domain = Request.RequestUri.Host;
cookie.Path = "/";
response.Headers.AddCookies(new[] { cookie });
return ResponseMessage(response);
}
else
{
return Content(HttpStatusCode.BadRequest, 1);
}
}
else
{
return Content(HttpStatusCode.BadRequest, 1);
}
}
catch (DbEntityValidationException e)
{
foreach (var eve in e.EntityValidationErrors)
{
Console.WriteLine("Entity of type \"{0}\" in state \"{1}\" has the following validation errors:",
eve.Entry.Entity.GetType().Name, eve.Entry.State);
foreach (var ve in eve.ValidationErrors)
{
Console.WriteLine("- Property: \"{0}\", Error: \"{1}\"",
ve.PropertyName, ve.ErrorMessage);
}
}
throw;
}
}
Wenn i api von Route Vorlage entferne ich bin in der Lage api zugreifen und wenn ich api.NCT_Login setzen dann Preflight-Fehler Ich erhalte. Ich bin mir nicht sicher, was ich hier vermisse. Jede Hilfe wäre willkommen. Vielen Dank.
Bitte teilen Sie die komplette Controller-Klasse –
Vielen Dank. Ich habe aktualisiert. –
Wir brauchen auch den Namen der Controller-Klasse :) –