Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Thoughtfully architected, obscenely fast, thoroughly enjoyable web services for all
C# JavaScript HTML CSS ASP Pascal Other
Latest commit cc2db76 @mythz mythz drop weighting

See for an overview and the Release Notes for latest features.

Join the ServiceStack Google+ Community or follow @ServiceStack for project updates.

Simple, Fast, Versatile and full-featured Services Framework

ServiceStack is a simple, fast, versatile and highly-productive full-featured Web and Web Services Framework that's thoughtfully-architected to reduce artificial complexity and promote remote services best-practices with a message-based design that allows for maximum re-use where ServiceStack Services are able to be consumed via an array of built-in fast data formats (inc. JSON, XML, CSV, JSV, ProtoBuf and MsgPack) as well as XSD/WSDL for SOAP endpoints and Rabbit MQ and Redis MQ hosts.

Your same Services also serve as the Controller in ServiceStack's Smart Razor Views reducing the effort to serve both Web and Single Page Apps as well as Rich Desktop and Mobile Clients.

ServiceStack Services also maximize productivity for consumers providing an instant end-to-end typed API without code-gen enabling the most productive development experience for developing .NET to .NET Web Services.

Generate Instant Typed APIs from within all Major IDEs!

ServiceStack now integrates with all Major IDE's used for creating the best native experiences on the most popular platforms to enable a highly productive dev workflow for consuming Web Services, making ServiceStack the ideal back-end choice for powering rich, native iPhone and iPad Apps on iOS with Swift, Mobile and Tablet Apps on the Android platform with Java, OSX Desktop Appications as well as targetting the most popular .NET PCL platforms including Xamarin.iOS, Xamarin.Android, Windows Store, WPF, WinForms and Silverlight:

VS.NET integration with ServiceStackVS

Providing instant Native Typed API's for C#, F#, VB.NET and TypeScript directly in Visual Studio for the most popular .NET platforms including iOS and Android using Xamarin.iOS and Xamarin.Android on Windows.

Xamarin Studio integration with ServiceStackXS

Providing C# Native Types support for developing iOS and Android mobile Apps using Xamarin.iOS and Xamarin.Android with Xamarin Studio on OSX. The ServiceStackXS plugin also provides a rich web service development experience developing Client applications with Mono Develop on Linux

Xcode integration with ServiceStackXC Plugin

Providing an instant Native Typed API in Swift including generic Service Clients enabling a highly-productive workflow and effortless consumption of Web Services from native iOS and OSX Applications - directly from within Xcode!

Android Studio integration with ServiceStackIDEA

Providing an instant Native Typed API in Java including idiomatic Java Generic Service Clients supporting Sync and Async Requests by levaraging Android's AsyncTasks to enable the creation of services-rich and responsive native Java Mobile Apps on the Android platform - directly from within Android Studio!

IntelliJ integration with ServiceStackIDEA

The ServiceStack IDEA plugin is installable directly from IntelliJ's Plugin repository and enables seamless integration with IntelliJ Java Maven projects for genearting a Typed API to quickly and effortlessly consume remote ServiceStack Web Services from pure cross-platform Java Clients.

Eclipse integration with ServiceStackEclipse

The unmatched productivity offered by Java Add ServiceStack Reference is also available in the ServiceStackEclipse IDE Plugin that's installable from the Eclipse MarketPlace to provide deep integration of Add ServiceStack Reference with Eclipse Java Maven Projects enabling Java Developers to effortlessly Add and Update the references of their evolving remote ServiceStack Web Services.

ssutil.exe - Command line ServiceStack Reference tool

In addition to our growing list of supported IDE's, the ssutil.exe cross-platform command-line .NET .exe makes it easy for build servers, automated tasks and command-line runners of your favorite text editors to easily Add and Update ServiceStack References!

Simple Customer Database REST Services Example

This example is also available as a stand-alone integration test:

//Web Service Host Configuration
public class AppHost : AppSelfHostBase
    public AppHost() 
        : base("Customer REST Example", typeof(CustomerService).Assembly) {}

    public override void Configure(Container container)
        //Register which RDBMS provider to use
        container.Register<IDbConnectionFactory>(c => 
            new OrmLiteConnectionFactory(":memory:", SqliteDialect.Provider));

        using (var db = container.Resolve<IDbConnectionFactory>().Open())
            //Create the Customer POCO table if it doesn't already exist

//Web Service DTO's
[Route("/customers", "GET")]
public class GetCustomers : IReturn<GetCustomersResponse> {}

public class GetCustomersResponse
    public List<Customer> Results { get; set; } 

[Route("/customers/{Id}", "GET")]
public class GetCustomer : IReturn<Customer>
    public int Id { get; set; }

[Route("/customers", "POST")]
public class CreateCustomer : IReturn<Customer>
    public string Name { get; set; }

[Route("/customers/{Id}", "PUT")]
public class UpdateCustomer : IReturn<Customer>
    public int Id { get; set; }

    public string Name { get; set; }

[Route("/customers/{Id}", "DELETE")]
public class DeleteCustomer : IReturnVoid
    public int Id { get; set; }

// POCO DB Model
public class Customer
    public int Id { get; set; }

    public string Name { get; set; }

//Web Services Implementation
public class CustomerService : Service
    public object Get(GetCustomers request)
        return new GetCustomersResponse { Results = Db.Select<Customer>() };

    public object Get(GetCustomer request)
        return Db.SingleById<Customer>(request.Id);

    public object Post(CreateCustomer request)
        var customer = new Customer { Name = request.Name };
        return customer;

    public object Put(UpdateCustomer request)
        var customer = Db.SingleById<Customer>(request.Id);
        if (customer == null)
            throw HttpError.NotFound("Customer '{0}' does not exist".Fmt(request.Id));

        customer.Name = request.Name;

        return customer;

    public void Delete(DeleteCustomer request)

Calling the above REST Service from any C#/.NET Client

No code-gen required, can re-use above Server DTOs:

var client = new JsonServiceClient(BaseUri);

//GET /customers
var all = client.Get(new GetCustomers());                         // Count = 0

//POST /customers
var customer = client.Post(new CreateCustomer { Name = "Foo" });

//GET /customer/1
customer = client.Get(new GetCustomer { Id = customer.Id });      // Name = Foo

//GET /customers
all = client.Get(new GetCustomers());                             // Count = 1

//PUT /customers/1
customer = client.Put(
    new UpdateCustomer { Id = customer.Id, Name = "Bar" });       // Name = Bar

//DELETE /customers/1
client.Delete(new DeleteCustomer { Id = customer.Id });

//GET /customers
all = client.Get(new GetCustomers());                             // Count = 0

Same code also works with PCL Clients in Xamarin iOS/Android, Windows Store Apps

F# and VB.NET can re-use same .NET Service Clients and DTO's

Calling from Java

JsonServiceClient client = new JsonServiceClient(BaseUri);

GetCustomersResponse all = client.get(new GetCustomers());

Calling from Swift

var client = JsonServiceClient(baseUrl: BaseUri)

let response = client.get(GetCustomers())

Calling from jQuery using TypeScript

$.getJSON($.ss.createUrl("/customers", request), request, 
    function (r: dtos.GetCustomersResponse) {
        alert(r.Results.length == 1);

Calling from jQuery

$.getJSON(baseUri + "/customers", function(r) {
    alert(r.Results.length == 1);

Calling the from Dart JsonClient

var client = new JsonClient(baseUri);
    .then((r) => alert(r.Results.length == 1)); 

That's all the application code required to create and consume a simple database-enabled REST Web Service!

Getting Started

Release Notes


If you have NuGet installed, the easiest way to get started is to:

Install ServiceStack via NuGet.

Latest v4+ on NuGet is a commercial release with free quotas.

Docs and Downloads for older v3 BSD releases

Live Demos

The Definitive list of Example Projects, Use-Cases, Demos, Starter Templates


Since September 2013, ServiceStack source code is available under GNU Affero General Public License/FOSS License Exception, see license.txt in the source. Alternative commercial licensing is also available, see for details.


Contributors need to approve the Contributor License Agreement before any code will be reviewed, see the Contributing wiki for more details. All contributions must include tests verifying the desired behavior.

OSS Libraries used

ServiceStack includes source code of the great libraries below for some of its core functionality. Each library is released under its respective licence:

Similar open source projects

Similar Open source .NET projects for developing or accessing web services include:

  • Nancy Fx - A Sinatra-inspired lightweight Web Framework for .NET:
  • Fubu MVC - A "Front Controller" pattern-style MVC framework designed for use in web applications built on ASP.NET:
  • Rest Sharp - An open source REST client for .NET

Find out More

Follow @ServiceStack and +ServiceStack for project updates.

Core Team


A big thanks to GitHub and all of ServiceStack's contributors:

Runs on both Mono and .NET (Live preview hosted on Mono / Ubuntu)

Something went wrong with that request. Please try again.