ДБ службы является нулевым в ServiceStack v4
Я уже пару лет пользуюсь бесплатной версией ServiceStack и недавно купил v4 для использования в проекте.
Я прочитал заметки о выпуске и связанные блоги, но не могу найти какие-либо рекомендации по проблеме, которая у меня возникла...
Сделав все соответствующие изменения, определенные в примечаниях к выпуску, я застрял с NullReferenceException на ServiceStack.Service.get_Db(). Вот некоторые фрагменты кода, которые могут помочь:
Global.asax...
using Funq;
using ServiceStack;
using ServiceStack.OrmLite;
using ServiceStack.Data;
using ServiceStack.Caching;
using ServiceStack.MiniProfiler;
using ServiceInterface;
using System.Web;
using System;
namespace WebRole
{
public class AppHost : AppHostHttpListenerBase
{
public AppHost() : base("Web Services", typeof(CompaniesService).Assembly) { }
public override void Configure(Container container)
{
container.Register(new OrmLiteConnectionFactory(@"Server=tcp:myServer.database.windows.net,1433;Database=myDatabase;User ID=myUser;Password=myPassword;Trusted_Connection=False;Encrypt=True;Connection Timeout=30;", SqlServerDialect.Provider));
using (var resetCompanies = container.Resolve<ResetCompaniesService>())
{
resetCompanies.Any(null);
}
ResetCompanies.cs...
using System;
using System.Collections.Generic;
using ServiceStack.OrmLite;
using ServiceStack;
using ServiceModel.Types;
namespace ServiceInterface
{
[Route("/reset-Companies", "GET,POST")]
[Api("Resets the database back to the original Top 3 movies.")]
public class ResetCompanies : IReturn<ResetCompaniesResponse>
{
}
/// <summary>
/// Define your ServiceStack web service response (i.e. Response DTO).
/// </summary>
public class ResetCompaniesResponse
{
}
/// <summary>
/// Create your ServiceStack rest-ful web service implementation.
/// </summary>
public class ResetCompaniesService : Service
{
public static List<Company> Top3Companies = new List<Company>
{
new Company
{
Code = "C1",
Name = "Company 1"
},
new Company
{
Code = "C2",
Name = "Company 2"
},
new Company
{
Code = "C3",
Name = "Company 3"
}
};
public object Any(ResetCompanies request)
{
//Executes the specified delegate against the configured database.
Db.DropAndCreateTable<Company>();
Db.SaveAll(Top3Companies);
return new ResetCompaniesResponse();
}
}
}
Исключение NullReferenceException происходит в
Db.DropAndCreateTable<Company>();
Вот трассировка стека
at ServiceStack.Service.get_Db()
at ServiceInterface.ResetCompaniesService.Any(ResetCompanies request) in c:\Users\me\Documents\Visual Studio 2013\Projects\Project1\ServiceInterface\ResetCompanies.cs:line 51
at WebRole.AppHost.Configure(Container container) in c:\Users\me\Documents\Visual Studio 2013\Projects\Project1\WebRole\Global.asax.cs:line 23
at ServiceStack.ServiceStackHost.Init()
at WebRole.Global.Application_Start(Object sender, EventArgs e) in c:\Users\me\Documents\Visual Studio 2013\Projects\Project1\WebRole\Global.asax.cs:line 35
У кого-нибудь есть идеи? Конечно, выглядит как очередное критическое изменение в v4, которое я пропустил или не знаю...
1 ответ
Встроенный класс Service ожидает разрешения IDbConnectionFactory, что можно сделать, зарегистрировав OrmLiteConnectionFactory в качестве IDbConnectionFactory
Например:
container.Register<IDbConnectionFactory>(c =>
new OrmLiteConnectionFactory(connString, SqlServerDialect.Provider));