我有一个ScoreDataModelsController,它包含以下操作方法:
public ActionResult Getnames()
{
return View(db.ScoreDataModels.ToList());
}在视图中,我有相应的ScoreDataModels文件夹,其中包含Getnames.cshtml:
@model IEnumerable<WebApplication1.Models.ScoreDataModel>
@{
ViewBag.Title = "Get Names";
Layout = "~/Views/Shared/_emptyLayout.cshtml";
}
<table class="table">
@foreach (var item in Model)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.Name)
</td>
</tr>
}
</table>一切都很好。现在,我希望使用REST将这些数据(即名称)作为json/XML访问。我设法使ApiController与标准设置一起工作,通过打开http://.../api/Andi,我从string[]获得了string[]格式的值:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
namespace WebApplication1.Controllers
{
public class AndiController : ApiController
{
// GET api/<controller>
public IEnumerable<string> Get()
{
return new string[] { "value1", "value2", "und en dritte" };
//Here I need help: ScoreDataModelsController sdm = new ScoreDataModelsController();
// var res = from r in sdm
}
// GET api/<controller>/5
public string Get(int id)
{
return "value";
}
// POST api/<controller>
public void Post([FromBody]string value)
{
}
// PUT api/<controller>/5
public void Put(int id, [FromBody]string value)
{
}
// DELETE api/<controller>/5
public void Delete(int id)
{
}
}
}现在,代替"value1,value2 .“我想从我的ScoreDataModel / ScoreDataModelsController中得到名字。
ScoreDataModel看起来是这样的。我在Visual中使用这个模型创建了控制器和由脚手架查看的视图:
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Web;
namespace WebApplication1.Models
{
public class ScoreDataModel
{
[Key]
public int ID { get; set; }
public string Name { get; set; }
public int Score { get; set; }
}
}如果您能引导我进入正确的方向,让REST与我现有的数据控制器/数据模型一起工作,我将非常感激。
发布于 2016-06-12 13:32:59
创建一个包含数据访问逻辑的中心类,如下所示:
public class DataRepository
{
private DatabaseContext db = new DatabaseContext();
public List<ScoreDataModel> GetNames()
{
return db.ScoreDataModels.ToList();
}
}现在,您可以使用这个类访问来自MVC控制器和api控制器的数据:
public class AndiController : ApiController
{
private DataRepository dbRepo = new DataRepository();
public IEnumerable<ScoreDataModel> Get()
{
List<ScoreDataModel> names = dbRepo.GetNames();
return names;
}
}发布于 2016-06-12 08:38:50
使用这个
var data= db.ScoreDataModels.ToList()
List<String>list=new List<String>();
foreach(var r in data)
{
list.add(r.Name);
}
return list;https://stackoverflow.com/questions/37772101
复制相似问题