Looking for servicestack Answers? Try Ask4KnowledgeBase
Looking for servicestack Keywords? Try Ask4Keywords

servicestackEmpezando con serviceestack


Observaciones

Esta sección proporciona una descripción general de qué es la pila de servicio y por qué un desarrollador puede querer usarla.

También debe mencionar cualquier tema importante dentro de la pila de servicio, y vincular a los temas relacionados. Dado que la Documentación para servicestack es nueva, es posible que deba crear versiones iniciales de esos temas relacionados.

Instalación o configuración

Puedes instalar ServiceStack de 3 maneras:

  • Plantillas completas de estudio visual (auto alojado)
  • Comience desde cero, ejecute ServiceStack Self hosting (aplicación de consola)
  • Ejecute ServiceStack dentro de Asp.net MVC.

Plantillas de estudio visual completas

Puede encontrar información sobre estos aquí: https://github.com/ServiceStack/ServiceStackVS .

  1. Descargue el complemento de estudio visual de servicestack: https://visualstudiogallery.msdn.microsoft.com/5bd40817-0986-444d-a77d-482e43a48da7
  2. Comienza un nuevo proyecto en Visual Studio y elige una de las plantillas.

Empezar desde cero (Selfhosted)

Para obtener una guía completa, vaya aquí: https://github.com/ServiceStack/ServiceStack/wiki/Self-hosting

Para configurar:

  1. Hacer una aplicación de consola
  2. instalar ServiceStack a través de nuget: Install-Package ServiceStack
  3. Configura tu código base. ServiceStack usa un AppHost para AppHost todo junto:
 //This your main entry point of the application
 public class AppHost : AppSelfHostBase {
    public AppHost() 
      : base("HttpListener Self-Host", typeof(HelloService).Assembly) {}

    public override void Configure(Funq.Container container) { }
}

//Run it!
static void Main(string[] args)
{
    var listeningOn = args.Length == 0 ? "http://*:1337/" : args[0];
    var appHost = new AppHost()
        .Init()
        .Start(listeningOn);

    Console.WriteLine("AppHost Created at {0}, listening on {1}", 
        DateTime.Now, listeningOn);

    Console.ReadKey();
}
 

Ahora puedes comenzar a desarrollar tus servicios api.

Integración de mvc

Para obtener la guía de integración de Mvc completa: https://github.com/ServiceStack/ServiceStack/wiki/Mvc-integration

Primero descargue sus paquetes nuget: Install-Package ServiceStack.Mvc

Configure su ServiceStack Apphost

public class AppHost : AppHostBase
{
    public AppHost() : base("MVC 4", typeof(MyServices).Assembly) {}

    public override void Configure(Container container)
    {            
        SetConfig(new HostConfig { 
            HandlerFactoryPath = "api" 
        });

        ControllerBuilder.Current.SetControllerFactory(
            new FunqControllerFactory(container));
    }
}

//Bootstrap your appHost through MVC Global.asax:
public class Global : System.Web.HttpApplication
{
    protected void Application_Start(object sender, EventArgs e)
    {
        new AppHost().Init();
    }
}
 

Ahora para ejecutar los servicios de ServiceStack, podemos agregar web.Config para hacer que ServicStack se ejecute en una ruta determinada, por ejemplo: /api/*

<location path="api">
  <system.web>
    <httpHandlers>
      <add path="*" type="ServiceStack.HttpHandlerFactory, ServiceStack" 
           verb="*"/>
    </httpHandlers>
  </system.web>

  <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
    <validation validateIntegratedModeConfiguration="false" />
    <handlers>
      <add path="*" name="ServiceStack.Factory" 
           type="ServiceStack.HttpHandlerFactory, ServiceStack" verb="*" 
           preCondition="integratedMode" 
           resourceType="Unspecified" allowPathInfo="true" />
    </handlers>
  </system.webServer>
</location>