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

目录
相关文章
|
1月前
|
存储 数据可视化 Java
基于MicrometerTracing门面和Zipkin实现集成springcloud2023的服务追踪
Sleuth将会停止维护,Sleuth最新版本也只支持springboot2。作为替代可以使用MicrometerTracing在微服务中作为服务追踪的工具。
103 1
|
20天前
|
安全 测试技术 数据安全/隐私保护
原生鸿蒙应用市场开发者服务的技术解析:从集成到应用发布的完整体验
原生鸿蒙应用市场开发者服务的技术解析:从集成到应用发布的完整体验
|
28天前
|
安全 Java 网络安全
Android远程连接和登录FTPS服务代码(commons.net库)
Android远程连接和登录FTPS服务代码(commons.net库)
23 1
|
1月前
|
存储 开发框架 .NET
.NET 8 实现无实体库表 API 部署服务
【10月更文挑战第12天】在.NET 8中,可通过以下步骤实现无实体库表的API部署:首先安装.NET 8 SDK及开发工具,并选用轻量级Web API框架如ASP.NET Core;接着创建新项目并设计API,利用内存数据结构模拟数据存储;最后配置项目设置并进行测试与部署。此方法适用于小型项目或临时解决方案,但对于大规模应用仍需考虑持久化存储以确保数据可靠性与可扩展性。
|
1月前
|
存储 开发框架 .NET
Windows IIS中asp的global.asa全局配置文件使用说明
Windows IIS中asp的global.asa全局配置文件使用说明
37 1
|
1月前
|
安全 Java 测试技术
ToB项目身份认证AD集成(二):快速搞定window server 2003部署AD域服务并支持ssl
本文详细介绍了如何搭建本地AD域控测试环境,包括安装AD域服务、测试LDAP接口及配置LDAPS的过程。通过运行自签名证书生成脚本和手动部署证书,实现安全的SSL连接,适用于ToB项目的身份认证集成。文中还提供了相关系列文章链接,便于读者深入了解AD和LDAP的基础知识。
|
1月前
|
监控 安全 API
Docker + .NET API:简化部署和扩展
Docker + .NET API:简化部署和扩展
39 0
|
1月前
|
监控 安全 API
最完美的扩展Docker + .NET API:简化部署和扩展
最完美的扩展Docker + .NET API:简化部署和扩展
72 0
|
Android开发 开发者
“.NET研究”如何发布你的Android应用程序
  本文是从 Some Things To Know About Publishing Android Apps 这篇文章翻译而来。     到目前为止,在Android交易市场(Android Market)里,已经有我的2个应用程序了,所以,我想写出一点关于Android应用程序发布过程的东西,用来告诉那些想发布自己的应用程序的朋友们,在发布过程中会遇到哪些的事情。
1070 0
|
2月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
41 7