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. GnuPG 1.4.15 发布,邮件加密工具

    GnuPG 1.4.15 改进包括: * Fixed possible infinite recursion in the compressed packet parser. [CVE-2013-44 ...

  2. 微信公共平台开发-(.net实现)2--ACCESSTOKEN值获得

    成功的走出第一步后,我们紧接着趁热打铁开始下一步: 成为了开发者之后微信平台会给您AppId和AppSecret,在订阅号中是没有的,所以因该申请一下服务号, 若没有请注意上一篇http://www. ...

  3. 创建widget

    1. 定义方法 def predictAll(tickers, startdt='36', enddt = 'today', predictdays = 1): if enddt == 'today' ...

  4. 虚拟化平台cloudstack(7)——新版本的调试

    调试环境 ubuntu 12.04 JDK1.7 apache-maven-3.10 eclipse 4.2 Juno mysql 5 源码下载及调试 上面的几个软件在上一篇中已经介绍了. 在新的版本 ...

  5. AngularJS入门教程1--配置环境

    首先需要下载AngualrJS,下载地址 https://angularjs.org/ 官方网站提供2种下载使用AngularJS方法: 1. 去GitHub下载 ,点击按钮会跳转到GitHub页面, ...

  6. 说说设计模式~建造者模式(Builder)

    返回目录 建造者模式是我的"设计模式"里创建型模式里的最后一篇,这种模式在实现中,很多架构都用到了,如MVC,MVP,MVVM,它们都是有建造者模式的精髓的,即,创建与表现分享,我 ...

  7. 大叔也说Xamarin~Android篇~原生登陆与WebView的网站如何共享Session

    回到目录 事情是这样的,我们最近开了一个APP,主要使用xamarin做了一个登陆,它与服务器API进行数据通讯,当用户名密码正确去,跳转到新的activity,并在webview控件中打开服务端的H ...

  8. Atiti  attilax主要成果与解决方案与案例rsm版 v4

    Atiti  attilax主要成果与解决方案与案例rsm版 v4 版本历史记录1 1. ##----------主要成果与解决方案与 参与项目1 ###开发流程与培训系列1 #-----组织运营与文 ...

  9. Atitit 泛型原理与理解attilax总结

    Atitit 泛型原理与理解attilax总结 1. 泛型历史11.1.1. 由来11.2. 为什么需要泛型,类型安全21.3. 7.泛型的好处22. 泛型的机制编辑22.1.1. 机制32.1.2. ...

  10. Atiti  qq空间破解(3)------------gui图形化通用cli执行器atiuse

    Atiti  qq空间破解(3)------------gui图形化通用cli执行器atiuse 结构:::命令行+以及反馈log框1 cli_guiUI/index.htm1 /AtiPlatf_c ...