1 public class THttpListener
     {
         HttpListener listerner;
         /// <summary>
         ///
         /// </summary>
         /// <param name="prefixes">格式 http://*/test/ </param>
         /// <param name="authent"></param>
         public THttpListener(string[] prefixes, AuthenticationSchemes authent = AuthenticationSchemes.Anonymous)
         {
             listerner = new HttpListener();
             listerner.AuthenticationSchemes = authent;//指定身份验证 Anonymous匿名访问
             foreach (var item in prefixes)
             {
                 listerner.Prefixes.Add(item);
                 Console.WriteLine(DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss") + " : HttpListener:" + item);
             }
         }

         public delegate void ResponseEventArges(HttpListenerContext ctx);
         public event ResponseEventArges ResponseEvent;
         AsyncCallback ac = null;

         public void Start()
         {
             if (!listerner.IsListening)
             {
                 listerner.Start();
                 ac = new AsyncCallback(GetContextAsyncCallback);
                 listerner.BeginGetContext(ac, null);
                 Console.WriteLine(DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss") + " : Start");
             }
         }

         /// <summary>
         /// 停止监听服务
         /// </summary>
         public void Stop()
         {
             listerner.Stop();
         }

         /// <summary>
         /// 收到监听请求回调
         /// </summary>
         /// <param name="ia"></param>
         public void GetContextAsyncCallback(IAsyncResult ia)
         {
             if (ia.IsCompleted)
             {
                 var ctx = listerner.EndGetContext(ia);
                 ctx.Response.StatusCode = ;
                 if (ResponseEvent != null)
                 {
                     ResponseEvent.BeginInvoke(ctx, null, null);
                 }
                 else
                 {
                     System.IO.BinaryWriter br = new System.IO.BinaryWriter(ctx.Response.OutputStream, new UTF8Encoding());
                     br.Write("error: 服务器未处理");
                     ctx.Response.Close();
                     br.Close();
                     br.Dispose();
                 }
             }
             listerner.BeginGetContext(ac, null);
         }

         public Dictionary<string, string> getData(System.Net.HttpListenerContext ctx)
         {
             var request = ctx.Request;
             if (request.HttpMethod == "GET")
             {
                 return getData(ctx, DataType.Get);
             }
             else
             {
                 return getData(ctx, DataType.Post);
             }
         }

         public Dictionary<string, string> getData(System.Net.HttpListenerContext ctx, DataType type)
         {
             var rets = new Dictionary<string, string>();
             var request = ctx.Request;
             switch (type)
             {
                 case DataType.Post:
                     if (request.HttpMethod == "POST")
                     {
                         string rawData;
                         using (var reader = new StreamReader(request.InputStream, request.ContentEncoding))
                         {
                             rawData = reader.ReadToEnd();
                         }
                         string[] rawParams = rawData.Split('&');
                         foreach (string param in rawParams)
                         {
                             string[] kvPair = param.Split('=');
                             ];
                             ]);
                             rets[key] = value;
                         }
                     }
                     break;
                 case DataType.Get:
                     if (request.HttpMethod == "GET")
                     {
                         string[] keys = request.QueryString.AllKeys;
                         foreach (string key in keys)
                         {
                             rets[key] = request.QueryString[key];
                         }
                     }
                     break;
             }
             return rets;
         }

         /// <summary>
         /// 数据提交方式
         /// </summary>
         public enum DataType
         {
             Post,
             Get,
         }

     }

测试调用类

 public class TestHttp
     {
         THttpListener _HttpListener;
         public TestHttp()
         {
             string[] strUrl = new string[] { "http://*/Test/" };
             _HttpListener = new THttpListener(strUrl);
             _HttpListener.ResponseEvent += _HttpListener_ResponseEvent;
             _HttpListener.Start();
         }

         void _HttpListener_ResponseEvent(System.Net.HttpListenerContext ctx)
         {
             //直接获取数据
             Dictionary<string, string> rets = _HttpListener.getData(ctx);
             //获取get数据
             Dictionary<string, string> retGets = _HttpListener.getData(ctx, THttpListener.DataType.Get);
             //获取post数据
             Dictionary<string, string> retPosts = _HttpListener.getData(ctx, THttpListener.DataType.Post);
             ResponseWrite(ctx.Request.AcceptTypes[], "Ret", ctx.Response);
         }

         static void ResponseWrite(string type, string msg, System.Net.HttpListenerResponse response)
         {
             //使用Writer输出http响应代码
             using (System.IO.StreamWriter writer = new System.IO.StreamWriter(response.OutputStream, new UTF8Encoding()))
             {
                 response.ContentType = type + ";charset=utf-8";
                 writer.WriteLine(msg);
                 writer.Close();
                 response.Close();
             }
         }
     }

当我们在服务程序或者后台程序需要开启对http的监听,来获取提交数据,但是又不能web服务器来挂在的程序,

C# 控制台或者winform程序开启http的监听状态的更多相关文章

  1. 监听程序未启动或数据库服务未注册到该监听程序。启动该监听程序并注册数据库服务 然后重新运行 em configuration assistant。

    在WIN 7/64Bit上安装ORACLE 11gR2后,管理网页Database Control(如:https://localhost:1158/em)始终登录不进去,总是说密码错误,使用配置工具 ...

  2. 利用 netsh 给 mysql 开启多端口监听

    利用 netsh 给 mysql 开启多端口监听 标题党,实际并不是真的多端口监听,只是端口转发而已. 由于某种特殊原因需要 mysql 服务器多个端口监听. mysql 服务器本身是不支持的,但可以 ...

  3. nc临时开启端口并监听

    port="6379 3306 27017 4505 4506 24007 24008 49152" #while true #do for i in $port do isexi ...

  4. 微信小程序实现watch属性监听数据变化

    Vue 提供了一种通用的方式来观察和响应 Vue 实例上的数据变动:监听属性 watch. 虽然watch的滥用会导致性能不佳,但在一些情况下我们还是需要watch,使得代码更加简洁.逻辑更加清晰(其 ...

  5. Windows 8 应用程序前后台切换事件监听

    在一些情况下,我们需要监听应用程序切换到后台或者从后台切换至前台的事件,从而进行相关处理操作.支付宝应用锁屏(IOS,Android平台)的处理中就需要监听此事件,在用户将应用切换至后台一段时间后再切 ...

  6. 控制台或Winform程序中如何编码或解码Server.URLEncode

    原文发布时间为:2010-07-10 -- 来源于本人的百度文章 [由搬家工具导入] 在Asp.net中可以使用Server.HTMLEncode和Server.URLEncode 将文本或URL的特 ...

  7. 小程序组件中有bindinput监听报异常

    真机上有问题,ide上是没问题的,   组件有处理函数,结果异常说页面没有处理函数,加上处理函数后就不报异常了.

  8. docker开启远程tcp监听端口

    linux 测试成功 cat > /etc/systemd/system/docker.service.d/tcp.conf <<EOF [Service] ExecStart= E ...

  9. 解决windows7无法连接CentOS7系统中oracle问题:ORA-12514 TNS 监听程序当前无法识别

    linux开启后终端按下面输入(容易忘记,记录下): [oracle@localhost ~]$ lsnrctl stop                #先关闭监听服务 [oracle@localh ...

随机推荐

  1. Linux之源码包安装软件

    安装准备      安装c语言编辑器 gcc      压缩包  node-v6.2.0-linux-x64.tar.gz   源码包保存位置  /usr/local/src/ 源码包安装位置 /us ...

  2. Python文件读取编码错误问题解决之(PyCharm开发工具默认设置的坑。。。)

    刚接触Python学习,正准备做个爬虫的例子,谁知道代码一开始就遇到了一个大坑,狂汗啊. 问题是这样的:我通过代码爬取了博客园首页的HTML代码并存入到blog.txt文件当中,然后准备读取出来之后进 ...

  3. Visual Studio Xamarin编译Android项目出错的解决办法

    安装完Xamarin后,编译Android项目时,你会发现好长时间进度都不动,当你取消编译后,会发现其实是出错了,就是因在Android项目在第一次编译时要去google网站上下一个andorid s ...

  4. WindowsPhone技术和XNA技术

    介于公司目前还没有涉及WP(WindowsPhone)项目的开发,而我本身是学习WP开发的,因此在这里稍微入门的介绍一点WP的知识. 一.简介 Windows Phone具有桌面定制.图标拖拽.滑动控 ...

  5. Linux 网络编程(epoll)

    服务器端代码 #include<stdio.h> #include<stdlib.h> #include<string.h> #include<sys/soc ...

  6. 详解c#迭代器

    迭代器模式是设计模式中行为模式(behavioral pattern)的一个例子,他是一种简化对象间通讯的模式,也是一种非常容易理解和使用的模式.简单来说,迭代器模式使得你能够获取到序列中的所有元素 ...

  7. Linux及文件系统基本介绍

    Linux及文件系统基本介绍 1   互联网行业现状 在服务器端市场: 超级计算机 2014年11月的数据显示前500系统中的485个系统都在运行着 Linux 的发布系统,而仅仅只有一台运行着 Wi ...

  8. 解析ASP.NET Mvc开发之EF延迟加载

    目录: 1)从明源动力到创新工场这一路走来 2)解析ASP.NET WebForm和Mvc开发的区别 3)解析ASP.NET Mvc开发之查询数据实例 ------------------------ ...

  9. 【T-SQL基础】03.子查询

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化. 本系列[T-SQL基础]主要是针对T-SQL基础的总结. [T-SQL基础]01.单表查询-几道sql查询题 ...

  10. FusionCharts简单教程(三)-----FusionCharts的基本属性

          通过前面两章的讲解我们可以制作出简单的图像,但是有时候我们需要对图像进行一个精确的规划,比如设置背景颜色.设置提示信息.设置间隔颜色等等,这时就需要我们对FusionCharts的细节有比 ...