zoukankan      html  css  js  c++  java
  • elsa-core:2.Hello World: HTTP

    在本快速入门中,我们将了解一个执行工作流的最小 ASP.NET Core 应用程序。工作流将侦听传入的 HTTP 请求并写回一个简单的响应。

    我们将:

    •  创建 ASP.NET Core 应用程序。
    •  使用 Elsa 的 Workflow Builder API 以编程方式定义工作流定义,当 HTTP 请求从指定的 URL 传入时,该 API 会执行。

     


    项目

    创建一个名为 ElsaQuickstarts.WebApp.HelloWorld 的新的空 ASP.NET Core 项目:

    dotnet new web -n "ElsaQuickstarts.WebApp.HelloWorld"

    CD 到创建的项目文件夹中:

    cd ElsaQuickstarts.WebApp.HelloWorld

    添加以下包:

    dotnet add package Elsa
    dotnet add package Elsa.Activities.Http

    工作流程

    创建一个名为 HelloWorld.cs 的新文件并添加以下代码:

    using System.Net;
    using Elsa.Activities.Http;
    using Elsa.Builders;
    
    namespace ElsaQuickstarts.WebApp.HelloWorld
    {
        /// <summary>
        /// A workflow that is triggered when HTTP requests are made to /hello-world and writes a response.
        /// </summary>
        public class HelloWorld : IWorkflow
        {
            public void Build(IWorkflowBuilder builder)
            {
                builder
                    .HttpEndpoint("/hello-world")
                    .WriteHttpResponse(HttpStatusCode.OK, "<h1>Hello World!</h1>", "text/html");
            }
        }
    }

    上述工作流有两个活动。第一个活动 HttpEndpoint 表示一个 HTTP 端点,可以使用 HTTP 客户端(包括 Web 浏览器)调用该端点。第一个活动连接到第二个活动 WriteHttpResponse,后者将响应写入 HTTP 客户端。

    当活动如本例所示链接时,第二个活动连接到第一个活动的“Done”结果。您还可以明确连接到“Done”结果,如下所示:

    builder
      .HttpEndpoint("/hello-world")
      .When(OutcomeNames.Done)
      .WriteHttpResponse(HttpStatusCode.OK, "<h1>Hello World!</h1>", "text/html");

    任何时候您想连接到“Done”以外的结果时,都需要明确连接到活动的结果


    Startup

    接下来,打开 Startup.cs 并将其内容替换为以下内容:

    using Microsoft.AspNetCore.Builder;
    using Microsoft.Extensions.DependencyInjection;
    
    namespace ElsaQuickstarts.WebApp.HelloWorld
    {
        public class Startup
        {
            public void ConfigureServices(IServiceCollection services)
            {
                services
                    .AddElsa(options => options
                        .AddHttpActivities()
                        .AddWorkflow<HelloWorld>());
            }
    
            public void Configure(IApplicationBuilder app)
            {
                app.UseHttpActivities();
            }
        }
    }

    运行

    运行程序并等待,直到看到以下输出:

    Now listening on: http://localhost:5000

    Now listening on: https://localhost:5001

    Application started. Press Ctrl+C to shut down.

    打开 Web 浏览器并导航到 https://localhost:5001/hello-world。

    结果应如下所示:

     

     

    如果觉得不错,可以推荐收藏一下,让我也更有动力。
  • 相关阅读:
    [Agc029D]Grid game_贪心
    [Agc029C]Lexicographic constraints_进制_二分答案_贪心
    [Agc029B]Powers of two_贪心_树形dp
    [Agc029A]Irreversible operation_逆序对
    [LuoguP1074]靶形数独_搜索
    umi react处理接口请求慢的问题
    typescript-类型
    bizcharts画图遇到的几个问题
    webpack 热更新原理
    webpack配置
  • 原文地址:https://www.cnblogs.com/jingboweilan/p/15150484.html
Copyright © 2011-2022 走看看