ASP.NET 5 с MongoDB

Попытка получить веб-сайт ASP.NET 5, интегрированный с драйвером С# MongoDB, но столкнувшись с несколькими проблемами.

Прежде всего, приведенные здесь примеры http://docs.mongodb.org/ecosystem/drivers/csharp/ отмечены как устаревшие.

Во-вторых, я получаю действительно странные ошибки компиляции (тип или пространство имен не может быть найдено), когда я пытаюсь построить, даже если все выглядит нормально в среде IDE.

Здесь мой самый основной HomeController.cs

using Microsoft.Framework.DependencyInjection;
using Microsoft.AspNet.Mvc;
using MongoDB.Driver;
using System;

namespace Docker.Web.Controllers
{
    public class HomeController : Controller
    {
        private AppSettings _appSettings;

        public HomeController(IServiceProvider serviceProvider)
        {
            _appSettings = serviceProvider.GetService<AppSettings>();
        }

        public IActionResult Index()
        {
            var server = new MongoClient(_appSettings.MongoConnection).GetServer();
            var database = server.GetDatabase(_appSettings.MongoDatabase);

            return View();
        }
    }
}

Основной вопрос: могу ли я использовать драйвер С# MongoDB с ASP.NET 5?

Использование предварительного просмотра Visual Studio 2015 и таргетинга версии KRE KRE-CoreCLR-x86.1.0.0-beta2

Любая помощь очень ценится!

Ответ 1

Драйвер С# не поддерживается в CoreCLR, но поддерживается в полном режиме CLR451.

Я создал образец проекта с использованием VS2015 CTP

project.json

{
    "version": "1.0.0-*",
    "dependencies": {
        "mongocsharpdriver": "1.10.0.0"
    },

    "frameworks": {
        "aspnet50": {
            "dependencies": {
            }
        }
    }
}

Код

using System;
using System.Linq;
using MongoDB.Driver.Linq;
namespace MongoDBvNext
{
    public class Class1
    {
        public Class1()
        {
            var client = new MongoDB.Driver.MongoClient("");
            var server = client.GetServer();
            var db = server.GetDatabase("samples");
            var samples = db.GetCollection<Sample>("samples");
            samples.Insert(new Sample { Name = "sample" });
            var sample = samples.AsQueryable<Sample>().Where(x => x.Name == "Sample").FirstOrDefault();
            if (sample == null)
                Console.WriteLine("id: {0} name: {1} ", sample.Id.ToString(), sample.Name);
            else
                Console.WriteLine("Data does not exists");
        }

        public class Sample
        {
            public string Name { get; set; }
            public MongoDB.Bson.ObjectId Id { get; set; }
        }
    }
}

Ответ 2

Вы можете использовать MongoDB с визуальной студией 2015 (обновлено 10 ноября).

удалите 1 строку из project.json;

"frameworks": {
    "dnx451": { }, // don't forget to remove ','
    "dnxcore50": { } // remove this line
}

теперь вы можете создать свое решение без каких-либо ошибок или предупреждений.

enter image description hereenter image description here