minihttp是基于c#实现的轻量级的动态WEB服务组件,通过minihttp可以轻松地构一个动态的WEB服务并嵌入到.NET程序中运行部署.由于minihttp完全基于托管代码实现,所以可以轻松运行在windows .net和 linux mono之间而不需要调整任何代码.为了方便处理动态功能minihttp还提供基础的MVC开发模式,并支持Razor视图模板从而让实现动态功能更简单.

功能描述

  • 支持 .net和mono平台下运行
  • 暂只支持GET和POST功能
  • 支持MVC和Razor

构建WEB服务

minihttp构建一个web服务非常简单,只需要通过调用HttpHost.CreateHttpServer创建IHttpServer,并调用相关Open方法即可开启服务功能.

    IHttpServer server = HttpHost.CreateHttpServer();
server.Prefixes.Add("http://*:80/");
//server.ServerPath += "Web" + System.IO.Path.DirectorySeparatorChar;
server.Open();

以上代码就是在所有IP的80端口开启服务,如果在不指定ServerPath的前提下,目录指向当前程序域运行的目录.

使用MVC功能

minihttp构建的出发点就是用于提供一个服务程序方便实现WEB管理功能而存在,所以minihttp支持动态处理是最基础的功能需求.为了让开发人员更好地编写动态数据处理,minihttp集成了基础的mvc功能和Razor视图模板支持.

Hello World

以下是制定一个简单的Hello Word页面,主要功能是用户提交自己的名字然后显示出来.

  • Action

           public ActionResult HelloWorld(string name)
    {
    return View("/views/helloworld", name);
    }
  • View
    <h2>Hello World</h2>
    <form method="post" action="/helloworld">
    <div class="input-group">
    <span class="input-group-addon">输入名字:</span>
    <input type="text" class="form-control" name="name" placeholder="Username"> </div>
    <br />
    <div class="input-group">
    <button type="submit" class="btn btn-default" style="float:right;">提交</button>
    </div>
    </form>
    <br />
    <div class="input-group">
    <span class="input-group-addon">hello:</span>
    <span class="form-control">@Model</span>
    </div>

在使用上基本兼容asp.net mvc模式,定义相应的方法并返回指定的view和model.

参数绑定

提供Action参数定功能,支持值类型和类模型,也提供自定义绑定描述扩展.minihttp是通过提交数据的名称来进行数据绑定映射,并提供大量的默认绑定器来满足大部分情况的需要.下面简单介绍一下如何绑定一个类模型

  • Model

        public class Register
    {
    public string Name { get; set; }
    public string EMail { get; set; }
    public string Password { get; set; }
    }
  • Action
      public ActionResult Register(Models.Register register)
    {
    return View("/views/register", register);
    }
  • View
    @{
    minihttp.quickstart.Web.Models.Register reg = (minihttp.quickstart.Web.Models.Register)Model;
    }
    <h2>数据绑定</h2>
    <form method="post" action="/register">
    <div class="input-group">
    <span class="input-group-addon InputLabel">用户名:</span>
    <input type="text" class="form-control" name="name" placeholder="Username"> </div>
    <br />
    <div class="input-group">
    <span class="input-group-addon InputLabel">邮件:</span>
    <input type="text" class="form-control" name="email" placeholder="Username"> </div>
    <br />
    <div class="input-group">
    <span class="input-group-addon InputLabel">密码:</span>
    <input type="text" class="form-control" name="password" placeholder="Username"> </div>
    <br />
    <div class="input-group">
    <button type="submit" class="btn btn-default" style="float:right;">提交</button>
    </div>
    </form>
    <h3>提交数据</h3>
    <div class="input-group">
    <span class="input-group-addon InputLabel">用户名:</span>
    <span class="form-control">@reg.Name</span>
    </div>
    <br />
    <div class="input-group">
    <span class="input-group-addon InputLabel">邮件:</span>
    <span class="form-control">@reg.EMail</span>
    </div>
    <br />
    <div class="input-group">
    <span class="input-group-addon InputLabel">密码:</span>
    <span class="form-control">@reg.Password</span>
    </div>

常用需求都可以通过自动化绑来简化提交数据的获取,这样可以大大节省这方面的工作量.

子模板

子模板可以便于共享视图,这样就可以有利于视图的复用,对些minihttp也提供了对它的支持.

  • View

    <h2>子模板</h2>
    @{
    var data = new {User= new minihttp.quickstart.Web.Models.User(){ Name="sdf",EMail="sdfsd",Address="sdfsdf",Phone="12345"}};
    }
    @RenderPage("/views/controls/userinfo",data)
  • ChileView
    <div class="input-group">
    <span class="input-group-addon InputLabel">用户名:</span>
    <span class="form-control">@ViewData.User.Name</span>
    </div>
    <br />
    <div class="input-group">
    <span class="input-group-addon InputLabel">邮件:</span>
    <span class="form-control">@ViewData.User.EMail</span>
    </div>
    <br />
    <div class="input-group">
    <span class="input-group-addon InputLabel">地址:</span>
    <span class="form-control">@ViewData.User.Address</span>
    </div>
    <br />
    <div class="input-group">
    <span class="input-group-addon InputLabel">地址:</span>
    <span class="form-control">@ViewData.User.Phone</span>
    </div>
    <br />

MasterPage

该功能也是minihttp所支持的功能,主要是方便统一处理页面布局,其使用方式和asp.net mvc一致.可以通过以下方式统一设置所有页面的masterpage布局.

server.MasterPage = "/views/layer/master";

master页面通过 @RenderBody()来指定页面输出的方式.

<div id="main">
<div id="start-menu">
<div class="panel panel-default">
<div class="panel-heading">Start</div>
<div class="panel-body">
<ul>
<li><a href="/helloworld">Hello World</a></li>
<li><a href="/Register">数据绑定</a></li>
<li><a href="/Control">子模板</a></li>
<li><a href="/datalist">数据列表</a></li>
</ul>
</div>
</div>
</div>
<div id="center">
@RenderBody() </div>
<div style="clear: both;" />
</div>

下载

Lib

quick start

demo

(组件许可任何个人或企业免费使用)

可嵌入式的动态http服务minihttp组件的更多相关文章

  1. 基于 OSGi 的面向服务的组件编程,helloworld

    基于 OSGi 的面向服务的组件编程 OSGi(Open Services Gateway Initiative,开放服务网关协议)提供了一个面向服务组件的编程模型,基于 OSGi 编程,具有模块化, ...

  2. 基于 OSGi 的面向服务的组件编程

    作者:曹 羽中 (caoyuz@cn.ibm.com), 软件工程师, IBM中国开发中心 出处:http://www.ibm.com/developerworks/cn/opensource/os- ...

  3. 如何从零开始实现一个soa远程调用服务基础组件

    说起soa远程调用基础组件,最著名的莫过于淘宝的dubbo了,目前很多的大型互联网公司都有一套自己的远程服务调用分布式框架,或者是使用开源的(例如dubbo),或者是自己基于某种协议(例如hessia ...

  4. Zookeeper分布式服务协调组件

    1.简介 Zookeeper是一个分布式服务协调组件,是Hadoop.Hbase.Kafka的重要组件,它是一个为分布式应用提供一致性服务的组件.   Zookeeper的目标就是封装好复杂易出错的服 ...

  5. datasnap——动态注册服务类

    datasnap——动态注册服务类 在DataSnap的应用程序时,我们首先需要注册的服务器类,以提供访问客户端应用程序的服务器方法.通常的做法是使用DSServerClass组件,但有些时候,我们要 ...

  6. 基于 IOCP 的通用异步 Windows Socket TCP 高性能服务端组件的设计与实现

    设计概述 服务端通信组件的设计是一项非常严谨的工作,其中性能.伸缩性和稳定性是必须考虑的硬性质量指标,若要把组件设计为通用组件提供给多种已知或未知的上层应用使用,则设计的难度更会大大增加,通用性.可用 ...

  7. [Asp.net core 3.1] 通过一个小组件熟悉Blazor服务端组件开发

    通过一个小组件,熟悉 Blazor 服务端组件开发.github 一.环境搭建 vs2019 16.4, asp.net core 3.1 新建 Blazor 应用,选择 asp.net core 3 ...

  8. SpringCloud学习笔记:服务支撑组件

    SpringCloud学习笔记:服务支撑组件 服务支撑组件 在微服务的演进过程中,为了最大化利用微服务的优势,保障系统的高可用性,需要通过一些服务支撑组件来协助服务间有效的协作.各个服务支撑组件的原理 ...

  9. 服务发现组件之 — Eureka

    前言 现在流行的微服务体系结构正在改变我们构建应用程序的方式,从单一的单体服务转变为越来越小的可单独部署的服务(称为微服务),共同构成了我们的应用程序.当进行一个业务时不可避免就会存在多个服务之间调用 ...

随机推荐

  1. Spring 4 官方文档学习 Spring与Java EE技术的集成

    本部分覆盖了以下内容: Chapter 28, Remoting and web services using Spring -- 使用Spring进行远程和web服务 Chapter 29, Ent ...

  2. Linux启动与登陆环境

    linux启动流程 参考:http://www.ruanyifeng.com/blog/2013/08/linux_boot_process.html 加载内核,首先读入/boot 目录下的内核文件. ...

  3. sql月份销售统计

    1.SELECT   MONTH(SellTime) as selltime,SUM(TotalPrice) as total FROM  Sell WHERE  YEAR(SellTime)=CON ...

  4. linux TLS 线程本地变量

    最近在写底层hook的时候, 涉及到线程安全问题, 最开始我设计的时候使用的互斥量, 但是考虑到都是底层函数,加锁会导致性能问题, 一直在思考优化方案, 后来偶然想到,java里面有线程本地变量的AP ...

  5. Qt 4.x调试器问题,缺失调试助手。

    之前项目开发需要用到4.x环境,固定多少版本避免团队开发不协调,然后拿了同事的开发包安装[注:我本子上原来就有4.x版本跟5.x版本,只是对应的4.x跟需求的不一样] creator是2.4.1的,同 ...

  6. ARC模式下的内存泄露问题

    ARC模式下的内存泄露问题 iOS提供的ARC 功能很大程度上简化了编程,让内存管理变得越来越简单,但是ARC并不是说不会发生内存泄露,使用不当照样会发生. 以下列举两种内存泄露情况: 死循环造成的内 ...

  7. 查询时,如何保存获取相关路径url

    作为新人,总是会有许多小问题不懂,不知道如何解决的. 这不,这次,遇到了路径获取问题. 在Jsp页面中,获取当前路径,在<script></script>中添加  var ur ...

  8. nodejs前端跨域访问

    XMLHttpRequest cannot load http://localhost:3000/. No 'Access-Control-Allow-Origin' header is presen ...

  9. member template

    1.当且仅当类模板的参数相同时,你才能对类实体对象相互赋值,即将一个实体对象整体赋值给另外一个实体对象.不能将一种类型的实体对象赋值给另外一种实体对象.如: Stack<int> intS ...

  10. <Oracle Database>物理结构

    物理结构 Oracle物理结构包含了数据文件.日志文件和控制文件 数据文件 每一个Oracle数据库有一个或多个物理的数据文件.一个数据库的数据文件包含全部数据库数据.数据文件有下列特征: 一个数据文 ...