- Я создал сборку (dll) со следующими классами:
Person.cs
[Table("People")]
public class Person
{
[Key]
public int ID { get; set; }
public string Name { get; set; }
}
DataContext.cs
public class DataContext : DbContext
{
public DbSet<Person> People { get; set; }
public DataContext()
: base("name=DataConnection")
{
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
base.OnModelCreating(modelBuilder);
}
}
Calc.cs
public class Calc
{
public int Sum(int num1, int num2)
{
return num1 + num2;
}
}
При использовании Nuget установлен следующий пакет:
Install-Package EFCodeFirst.SqlServerCompact
Я создал новый
сайт MVC 3 Я добавил ссылку dll на ранее созданный
Я изменил следующие действия на HomeController
HomeController.cs
public ActionResult Index()
{
ViewBag.Message = "Sample Security Error";
return View();
}
public ActionResult Sum(int num1, int num2)
{
ViewBag.Message = "Sample Security Error";
return View("Index", num1 + num2);
}
Добавлен новый контроллер
PeopleController.cs
public ActionResult Index()
{
using (var db = new DataContext())
{
var people = from p in db.People
select p;
return View(people.ToList());
}
}
Я изменил View/Home
со следующим кодом:
Index.cshtml
@model int?
@{
ViewBag.Title = "Home Page";
}
<h2>@ViewBag.Message</h2>
@Html.ActionLink("Sum", "Sum", new { num1 = 2, num2 = 4})
@if (Model.HasValue)
{
<p>The value is: @Model.Value</p>
}
else
{
<p>No value</p>
}
Новый View/People
Индекс.cshtml
@model IEnumerable<Error.SecurityException.Model.Person>
@{
ViewBag.Title = "People";
}
<h2>@ViewBag.Title</h2>
<ul>
@foreach (var item in Model)
{
<li>@item.Name</li>
}
</ul>
В Web.config я добавил строку подключения
<connectionStrings>
<add name="DataConnection" connectionString="Data Source=|DataDirectory|Data.sdf;" providerName="System.Data.SqlServerCe.4.0" />
</connectionStrings>
App_Data
, папка создала базу данных Data.sdf
с тем жеструктура как класс Person.cs
.
С помощью Nuget установлен следующий пакет:
Install-Package EFCodeFirst.SqlServerCompact
Result
Код в локальном IIS работал отлично!
Суммарные значения
Показать людей
Ошибка
Когда я публиковал сайт, пытаясь отобразить людей, показывалось сообщение об ошибке безопасности;
System.Security.SecurityException: Запрос не выполнен.
Суммарные значения обычно делаются!
Я опубликовал проект этот адрес.
Нажав на меню People
, вы увидите ошибку!
Сжать пример проекта и опубликовать по адресу по этому адресу .
Я ценю помощь!