Windows Forms应用程序中集成一个ASP.NET API服务

简介: Windows Forms应用程序中集成一个ASP.NET API服务

在Windows Forms应用程序中集成一个ASP.NET API服务可以是一种有效的方式来为桌面应用程序提供网络服务能力。这种方式特别适用于需要在桌面环境中运行的小型服务。我们可以利用HttpListener类来实现这种功能,因为它不依赖于IIS或Kestrel来运行。下面是一个实现此目的的示例。

环境准备

Visual Studio: 创建一个Windows Forms应用程序。

.NET Framework/CORE: 确保你的项目使用的环境支持HttpListener。

创建Windows Forms项目

首先,使用Visual Studio创建一个新的Windows Forms应用项目。

集成ASP.NET API服务

这里,我们将在Windows Forms应用程序中创建一个简单的API服务。

在WinForms中配置HttpListener

打开主窗体代码文件,例如Form1.cs,然后添加以下代码:

using System.Net;
using System.Text;
namespace AppWeb
{
    public partial class Form1 : Form
    {
        private HttpListener _httpListener;
        private Thread _listenerThread;
        public Form1()
        {
            InitializeComponent();
        }
        private void StartHttpServer()
        {
            _httpListener = new HttpListener();
            _httpListener.Prefixes.Add("http://localhost:5000/");
            _httpListener.Start();
            _listenerThread = new Thread(new ThreadStart(ListenForRequests));
            _listenerThread.IsBackground = true;
            _listenerThread.Start();
            Console.WriteLine("HTTP Server started on http://localhost:5000/");
        }
        private void ListenForRequests()
        {
            while (_httpListener.IsListening)
            {
                try
                {
                    var context = _httpListener.GetContext();
                    ProcessRequest(context);
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"Error: {ex.Message}");
                }
            }
        }
        private void ProcessRequest(HttpListenerContext context)
        {
            var request = context.Request;
            var response = context.Response;
            Console.WriteLine($"Received request: {request.HttpMethod} {request.Url}");
            // 固定响应,实际应用中根据URL路径处理不同请求
            string responseString = "{\"message\": \"Hello from WinForms API!\"}";
            byte[] buffer = Encoding.UTF8.GetBytes(responseString);
            response.ContentLength64 = buffer.Length;
            response.ContentType = "application/json";
            response.OutputStream.Write(buffer, 0, buffer.Length);
            response.OutputStream.Close();
        }
        private void btnStart_Click(object sender, EventArgs e)
        {
            StartHttpServer();
        }
        private void btnStop_Click(object sender, EventArgs e)
        {
            if (_httpListener != null)
            {
                _httpListener.Stop();
                _httpListener.Close();
            }
        }
    }
}

关键点

HttpListener: 此类用于创建一个简易的HTTP服务器,它可以侦听HTTP请求。

ListenForRequests: 在后台线程中运行,监听进入的HTTP请求,并处理这些请求。

ProcessRequest: 处理传入的请求并生成响应。在这里,你可以实现复杂的路由和处理逻辑。

应用程序关闭时处理: 在FormClosing事件中停止HTTP监听器以释放资源。

运行和测试

启动Windows Forms应用程序,确保显示的信息表明服务器已启动。然后,你可以使用curl、Postman或浏览器访问http://localhost:5000/来测试API服务。

curl http://localhost:5000/

修改ProcessRequest方法以支持多个路由

private void ProcessRequest(HttpListenerContext context)
{
    var request = context.Request;
    var response = context.Response;
    Console.WriteLine($"Received request: {request.HttpMethod} {request.Url}");
    string responseString = string.Empty;
    switch (request.Url.AbsolutePath)
    {
        case "/":
            responseString = "{\"message\": \"Hello from WinForms API!\"}";
            break;
        case "/time":
            responseString = $"{{\"time\": \"{DateTime.Now.ToString("o")}\"}}";
            break;
        case "/greet":
            string name = request.QueryString["name"] ?? "Guest";
            responseString = $"{{\"greeting\": \"Hello, {name}!\"}}";
            break;
        default:
            response.StatusCode = (int)HttpStatusCode.NotFound;
            responseString = "{\"error\": \"Not Found\"}";
            break;
    }
    byte[] buffer = Encoding.UTF8.GetBytes(responseString);
    response.ContentLength64 = buffer.Length;
    response.ContentType = "application/json";
    response.OutputStream.Write(buffer, 0, buffer.Length);
    response.OutputStream.Close();
}

image.png

目录
相关文章
|
6天前
|
开发框架 安全 .NET
Microsoft .NET Framework 3.5、4.5.2、4.8.1,适用于 Windows 版本的 .NET,Microsoft C Runtime等下载
.NET Framework是Windows平台的开发框架,包含CLR和FCL,支持多种语言开发桌面、Web应用。常用版本有3.5、4.5.2、4.8.1,系统可同时安装多个版本,确保软件兼容运行。
247 0
Microsoft .NET Framework 3.5、4.5.2、4.8.1,适用于 Windows 版本的 .NET,Microsoft C Runtime等下载
|
5月前
|
安全 测试技术 Linux
Flawnter 5.9.1 (macOS, Linux, Windows) - 应用程序安全测试软件
Flawnter 5.9.1 (macOS, Linux, Windows) - 应用程序安全测试软件
159 2
Flawnter 5.9.1 (macOS, Linux, Windows) - 应用程序安全测试软件
|
7月前
|
存储 监控 安全
如何排查常见的 Windows 应用程序错误和崩溃
本文介绍了如何通过事件日志分析来诊断Windows应用程序错误和崩溃的根本原因。文章首先解释了应用错误的表现形式及常见事件ID(如1000、1001等),并分析了导致崩溃的原因,包括硬件问题(如存储不足、外部因素)和软件问题(如编码错误、数据损坏、.NET Framework兼容性)。接着,提供了几种故障排除方法,例如运行系统文件检查器(SFC)、执行干净启动、检查更新以及重新安装.NET Framework。最后,探讨了使用日志管理工具(如EventLog Analyzer)集中分析崩溃事件的功能,包括预置报表、时间轴分析、实时警报和自动化响应,帮助管理员高效解决应用问题。
710 1
|
10月前
|
区块链 C# Windows
PasteEx:一款.NET开源的Windows快捷粘贴神器
PasteEx:一款.NET开源的Windows快捷粘贴神器
135 17
|
10月前
|
Web App开发 C# Windows
一款.NET开源的Windows资源管理器标签页工具
一款.NET开源的Windows资源管理器标签页工具
133 5
|
10月前
|
弹性计算 开发框架 安全
基于云效 Windows 构建环境和 Nuget 制品仓库进行 .Net 应用开发
本文将基于云效 Flow 流水线 Windows 构建环境和云效 Packages Nuget 制品仓库手把手教你如何开发并部署一个 .NET 应用,从环境搭建到实战应用发布的详细教程,帮助你掌握 .NET 开发的核心技能。
|
11月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
11月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)
本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。
|
12月前
|
Windows
.NET 隐藏/自定义windows系统光标
【10月更文挑战第20天】在.NET中,可以使用`Cursor`类来控制光标。要隐藏光标,可将光标设置为`Cursors.None`。此外,还可以通过从文件或资源加载自定义光标来更改光标的样式。例如,在表单加载时设置`this.Cursor = Cursors.None`隐藏光标,或使用`Cursor.FromFile`方法加载自定义光标文件,也可以将光标文件添加到项目资源中并通过资源管理器加载。这些方法适用于整个表单或特定控件。
156 0
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
394 0

热门文章

最新文章