[关闭]
@lsmn 2016-01-29T01:04:48.000000Z 字数 1284 阅读 2181

Suave 1.0发布,一个面向F#的Web服务器和开发库

F# .NET Web


摘要

近日,Suave 1.0发布,为.NET开发带来了一个新的Web开发库。Suave包含一个轻量级的、完全异步的Web服务器以及一个描述HTTP处理管道的语义模型。Suave可以运行在多种平台和操作系统上,包括Windows、OSX、Linux、.NET和Mono。虽然可以在任何.NET语言中使用,但Suave“连结符(combinators)”和类型是设计用于F#的。

正文

近日,Suave 1.0发布,为.NET开发带来了一个新的Web开发库。Suave包含一个轻量级的、完全异步的Web服务器以及一个描述HTTP处理管道的语义模型。Suave可以运行在多种平台和操作系统上,包括Windows、OSX、Linux、.NET和Mono。虽然可以在任何.NET语言中使用,但Suave“连结符(combinators)”和类型是设计用于F#的。

Suave的编程模型是借助连结符使用较小的函数创建较大的函数。Suave维护者Henrik Feldt是这样解释的:

连结符是高阶函数,可以用不同的方式组合,达到不同的效果,生成HTTP响应。

Suave有像OK "Hello"notFound这样的连结符及其他许多底层HTTP结构,使开发人员可以编写任何种类的Web服务。在Suave中,我们使用类型WebPart操作函数域,其中type WebPart = HttpContext -async<HttpContext option>

类型option为我们使用success/fail语义及解析成不同的路由提供了可能。

我们使用一个名为choose的函数,它接受一个WebPart列表,并按顺序为每个WebPart提供一个HttpContext,直到其中一个WebPart返回Some HttpContextHttpContext中包含已经编码好的响应,服务器将发送给HTTP客户端。

我们还使用一个>=>操作符组合WebPart及解析路由。

下面是使用Suave实现经典的“Hello World!”示例。该应用程序会使用“Hello World!”响应它收到的所有请求。

open Suave
startWebServer defaultConfig (Successful.OK "Hello World!")

下面的例子展示了如何匹配路由以及没有匹配的路由时返回404页面:

let app : WebApp =
   choose[
     path "/foo" >=> OK "foo"
     path "/bar" >=> OK "bar"
     notFound "no handlers found."
   ]
startWebServer defaultConfig app

Suave是一个开源项目,托管在GitHub上。Suave官方网站提供了文档和示例。此外,InfoQ还对Henrik Feldt进行了更广泛的采访,他就Suave是什么以及如何使用讲述了更多的细节。

查看英文原文:Release 1.0 of Suave, a Web Server and Development Library for F#

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注