• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ServiceStack: A simple, fast, versatile and highly-productive full-featured Web ...

原作者: [db:作者] 来自: 网络 收藏 邀请

Follow @ServiceStack or view the docs, use StackOverflow or the Customer Forums for support.

View the Release Notes for latest features or see servicestack.net/features for an overview.

Simple, Fast, Versatile and full-featured Services Framework

ServiceStack is a simple, fast, versatile and highly-productive full-featured Web andWeb Services Framework that'sthoughtfully-architected to reduce artificial complexity and promoteremote services best-practiceswith a message-based designthat allows for maximum re-use that can leverage an integratedService Gatewayfor the creation of loosely-coupledModularized Service Architectures.ServiceStack Services are consumable via an array of built-in fast data formats (inc.JSON,XML,CSV,JSV,ProtoBuf,Wire andMsgPack)as well as XSD/WSDL for SOAP endpoints andRabbit MQ,Redis MQ andAmazon SQS MQ hosts.

Its design and simplicity focus offers an unparalleled suite of productivity features that can be declaratively enabledwithout code, from creating fully queryable Web API's with just a single Typed Request DTO withAuto Query supportingevery major RDBMSto the built-in support forAuto Batched Requestsor effortlessly enabling rich HTTP Caching andEncrypted Messagingfor all your existing services via Plugins.

Your same Services also serve as the Controller in ServiceStack's Smart Razor Viewsreducing the effort to serve bothWeb and Single Page Apps as well asRich Desktop and Mobile Clients that are able to deliver instant interactiveexperiences using ServiceStack's real-time Server Events.

ServiceStack Services also maximize productivity for consumers providing aninstant end-to-end typed API without code-gen enablingthe 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 platformsto enable a highly productive dev workflow for consuming Web Services, making ServiceStack the ideal back-end choice for poweringrich, native iPhone and iPad Apps on iOS with Swift, Mobile and Tablet Apps on the Android platform with Java, OSX Desktop Applicationsas well as targeting 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 forC#,TypeScript,F# andVB.NETdirectly in Visual Studio for themost popular .NET platforms including iOS and Android usingXamarin.iOS andXamarin.Android on Windows.

Xamarin Studio integration with ServiceStackXS

Providing C# Native Typessupport for developing iOS and Android mobile Apps usingXamarin.iOS andXamarin.Android withXamarin Studio on OSX. The ServiceStackXS plugin also provides a rich web servicedevelopment experience developing Client applications withMono Develop on Linux

Xcode integration with ServiceStackXC Plugin

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

Android Studio integration with ServiceStackIDEA

Providing an instant Native Typed API in Javaand Kotlinincluding idiomatic Java Generic Service Clients supporting Sync and Async Requests by leveraging Android's AsyncTasks to enable the creation of services-rich and responsive native Java or Kotlin 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 generating a Typed API to quickly and effortlessly consume remote ServiceStack Web Services from pure cross-platform Java or Kotlin Clients.

Eclipse integration with ServiceStackEclipse

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

servicestack-cli - Simple command-line utilities for ServiceStack

In addition to our growing list of supported IDE's, the servicestack-clicross-platform command-line npm scripts makes it easy for build servers, automated tasks and command-line runners of yourfavorite 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 Configurationpublic 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            db.CreateTableIfNotExists<Customer>();        }    }}//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 Modelpublic class Customer{    [AutoIncrement]    public int Id { get; set; }    public string Name { get; set; }}//Web Services Implementationpublic 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 };        Db.Save(customer);        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;        Db.Update(customer);        return customer;    }    public void Delete(DeleteCustomer request)    {        Db.DeleteById<Customer>(request.Id);    }}

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 /customersvar all = client.Get(new GetCustomers());                         // Count = 0//POST /customersvar customer = client.Post(new CreateCustomer { Name = "Foo" });//GET /customer/1customer = client.Get(new GetCustomer { Id = customer.Id });      // Name = Foo//GET /customersall = client.Get(new GetCustomers());                             // Count = 1//PUT /customers/1customer = client.Put(    new UpdateCustomer { Id = customer.Id, Name = "Bar" });       // Name = Bar//DELETE /customers/1client.Delete(new DeleteCustomer { Id = customer.Id });//GET /customersall = client.Get(new GetCustomers());                             // Count = 0

Same code also works with Android, iOS, Xamarin.Forms, UWP and WPF clients.

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

Calling from TypeScript

const client = new JsonServiceClient(baseUrl);const { results } = await client.get(new GetCustomers());

Calling from Swift

let client = JsonServiceClient(baseUrl: BaseUri)client.getAsync(GetCustomers())    .then {        let results = $0.results;    }

Calling from Java

JsonServiceClient client = new JsonServiceClient(BaseUri);GetCustomersResponse response = client.get(new GetCustomers());List<Customer> results = response.results; 

Calling from Kotlin

val client = JsonServiceClient(BaseUri)val response = client.get(GetCustomers())val results = response.results

Calling from Dart

var client = new JsonServiceClient(BaseUri);var response = await client.get(GetCustomers());var results = client.results;

Calling from jQuery using TypeScript Definitions

$.getJSON($.ss.createUrl("/customers", request), request, (r: GetCustomersResponse) => {    var results = r.results;});

Using TypeScript Definitions with Angular HTTP Client:

this.http.get<GetCustomersResponse>(createUrl('/customers', request)).subscribe(r => {    this.results = r.results;});

Calling from jQuery

$.getJSON(baseUri + "/customers", function(r) {	var results = r.results;});

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

Getting Started

Release Notes

Download

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

Copying

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 https://servicestack.net/pricing for details.

Contributing

Contributors need to approve the Contributor License Agreement before any code will be reviewed, see the Contributing docs 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:

Find out More

Follow @ServiceStack and+ServiceStack for project updates.


Core Team

Contributors

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