使用RpcLite构建SOA/Web服务(Full .Net Framework)

使用RpcLite构建SOA/Web服务(Full .Net Framework)

SOA框架系列

1. 使用RpcLite构建SOA/Web服务

2. 使用RpcLite构建SOA/Web服务(Full .Net Framework)

继前一篇文章《使用RpcLite构建SOA/Web服务》已过去好几个月。在这几个月里对RpcLite作了很多修改如:.Net Core的支持、Fluent API方式配置、Monitor、Filter等功能。

前一篇文章介绍了使用RpcLite的基本用法,在文章中介绍的配置方式为配置文件使用起来比较麻烦。本文配置使用Fluent API方式,在.Net Core中可以完全不使用配置文件,在Asp.Net中仅需要添加一个HttpModule。

创建服务端

Full .Net Framework中现只支持Host到ASP.NET中。

创建服务包括以下步骤:

  • 创建Web Application工程
  • 添加RpcLite引用
  • Web.config添加RpcHttpModule
  • 创建服务契约接口
  • 通过实现服务契约接口创建服务类
  • 在Global.asax中初始化RpcLite

创建Web Application工程

  • 打开Visual Studio 2015
  • 打开菜单File ? New ? Project...
  • 在左边的菜单中选择 Templates ? Visual C# ? Web
  • 在项目类型中选择 ASP.NET Web Application (.Net Framework)
  • 确保目标Framework版本为 .NET Framework 4.0 或更高
  • 填写项目名称HelloRpcLiteService点Ok

添加RpcLite引用

添加引用有两种方式:直接下载dll然后引用、通过NuGet添加,其中通过NuGet添加简单方便,本文以此方式为例。 通过NuGet添加也有两种方式:图形界面或命令行

命令行

  • 打开菜单Tools ? NuGet Package Manager ? Package Manager Console
  • 运行 Install-Package RpcLite

图形界面

  • 在Solution Explorer中右击HelloRpcLite,选择Manage NuGet Packages...
  • 在NuGet页面中选择Browse Tab页,然后搜索RpcLite
  • 在搜索结果中安装RpcLite

Web.config添加RpcHttpModule

默认情况下添加RpcLite包依赖后Web.Config会自动添加,若已自动添加请忽略本小节的操作

在集成管道模式和经典管道模式中添加HttpModule方式不同,本文以现在用得最多的集成管道模式说明

在configuration/system.webServer节点下添加 <add name=”RpcLite” type=”RpcLite.Service.RpcHttpModule, RpcLite.NetFx” />

完整配置如下:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <system.webServer>
            <modules>
                    <add name="RpcLite" type="RpcLite.Service.RpcHttpModule, RpcLite.NetFx" />
            </modules>
    </system.webServer>
</configuration>

创建服务契约接口

  • 新建类文件IProductService.cs
  • 输入以下内容
namespace HelloRpcLiteService
{
        public interface IProductService
        {
                string GetDateTimeString();
        }
}

通过实现服务契约接口创建服务类

  • 新建类文件ProductService.cs
  • 输入以下内容
 
using System;

namespace HelloRpcLiteService
{
        public class ProductService : IProductService
        {
                public string GetDateTimeString()
                {
                        return DateTime.Now.ToString();
                }
        }
}

在Global.asax中初始化RpcLite

  • 向工程中添加Global.asax
  • 在Application_Start函数中添加初始化代码
using System;
using RpcLite.Config;

namespace HelloRpcLiteService
{
        public class Global : System.Web.HttpApplication
        {
                protected void Application_Start(object sender, EventArgs e)
                {
                        RpcInitializer.Initialize(builder => builder
                                .UseService<ProductService>("ProductService", "api/service/")
                                .UseServicePaths("api/")
                                );
                }
        }
}

说明

  • UseService<ProductService>(“ProductService”, “api/service/”)是添加一个服务 泛型参数ProductService为服务提供类, 第一个参数”ProductService”为服务名 “api/service/”为服务相对于当前WebApplication根的地址,例如WebApplication地址为http://localhost:8080则服务地址为http://localhost:8080/api/service/。若服务部署到虚拟目录下如http://localhost:8080/app1则服务地址为http://localhost:8080/app1/api/service/
  • UseServicePaths(“api/”)指定服务地址的前缀,以此地址开始的所有Url都会被认为是RpcLite服务,UseService中使用的路必需在ServicePaths中。若没有配置此选项则不能正常访问服务。

运行

到此一个RpcLite服务已经创建完成,可运行查看结果。

  • F5运行WebApplication,在浏览器中查看地址,假设是http://localhost:11651
  • 在浏览器访问http://localhost:11651/api/service/GetDateTimeString,可看到返回的内容是当前日期
  • 在浏览器访问http://localhost:11651/api/service/可以看到当前服务的信息,服务名及所有接口名
Service Name: ProductService
Actions:
String GetDateTimeString();

通过RpcLite客户端、JavaScript就可以访问这个服务了。

本文代码地址 https://github.com/aolyn/rpclite.docs/tree/master/samples/HelloRpcLite/src/HelloRpcLiteService

QQ群:364617712 

欢迎加入

联系方式

时间: 2024-08-24 23:49:14

使用RpcLite构建SOA/Web服务(Full .Net Framework)的相关文章

使用RpcLite构建SOA/Web服务

使用RpcLite构建SOA/Web服务 SOA框架系列 1. 使用RpcLite构建SOA/Web服务 提到Web服务最先想到的就是WebService此外常用的还有WCF.ServiceStack.WebApi等. RpcLite是一个开源的轻量级SOA服务框架,除了基本的提供Web服务还包括SOA治理系统(本文暂不展开在后继的文章会详细说明).RpcLite与WCF比较像,下面介绍使用方法. 1.   创建一个Web项目,Framework选择>=4.0 2.   从NuGet中添加Rpc

Yii2快速构建RESTful Web服务功能简介

Yii2相比Yii1而言,一个重大的改进是内置了功能完备的RESTful支持. 其内置RESTful支持提供了如下功能: 使用ActiveRecord的通用接口来快速构建原型: 应答格式协商(缺省支持 JSON 和 XML): 可定制的对象序列化,支持选择输出哪些列: 请求数据的格式化以及验证错误: 通过HTTP 动词映射实现高效路由: 支持 OPTIONS 和 HEAD 动词: 认证 和 鉴权: 支持 HATEOAS(RESTful的架构约束,超媒体即应用程序状态): 结果缓存,可使用 yii

基于IIS构建Pyathon Web服务

本文简单叙述了在Windows下,如何利用IIS构建Python Web服务. 其主要步骤如下: 1.在IIS下构建一个站点,如图: 2.配置Python文件的处理程序,如图: 3.最后,在对应站点根目录下放置Python文件,如图: 是不是感觉好简单.我们在浏览器看看结果,如图:

使用 Jersey 和 Apache Tomcat 构建 RESTful Web 服务

RESTful Web 服务简单介绍 REST 在 2000 年由 Roy Fielding 在博士论文中提出,他是 HTTP 规范 1.0 和 1.1 版的首席作者之中的一个. REST 中最重要的概念是资源(resources),使用全球 ID(通常使用 URI)标识. client应用程序使用 HTTP 方法(GET/ POST/ PUT/ DELETE)操作资源或资源集.RESTful Web 服务是使用 HTTP 和 REST 原理实现的 Web 服务.通常,RESTful Web 服

.net/java调用NuSOAP构建的Web服务

此文主要解决php下的web服务接受和返回复杂类型(自定义类型)该如何构建以及其他程序客户端如何来调用. 第一步:用NuSOAP组件来构建基于php的webservice 下载NuSOAP组件,在创建基于php的webservice时需要引用,代码如下,很简单直观,有注释就不多解释了: <?php require_once ('lib/nusoap.php'); // 返回的是一个数组 function adduser ($userName, $userAge, $birthday, $high

基于jersey和Apache Tomcat构建Restful Web服务(一)

基于jersey和Apache Tomcat构建Restful Web服务(一) 现如今,RESTful架构已然成为了最流行的一种互联网软件架构,它结构清晰.符合标准.易于理解.扩展方便,所以得到越来越多网站的采用.那么问题来了,它是什么呢? 起源 REST(Representational state transfer)在 2000 年由 Roy Fielding 在博士论文中提出,他是 HTTP 规范 1.0 和 1.1 版的首席作者之一. REST 中最重要的概念是资源(resources

基于jersey和Apache Tomcat构建Restful Web服务(二)

基于jersey和Apache Tomcat构建Restful Web服务(二) 上篇博客介绍了REST以及Jersey并使用其搭建了一个简单的“Hello World”,那么本次呢,再来点有趣的东西,当然也是很简单了,仅仅是在路径中包含参数而已了.接下来开始动手实践吧. 在路径中包含参数 接下来就在上次的基础上进行改动即可,或者是再添加一个方法,随意了,这个方法主要就是在路径中加入输入的参数,并且根据参数的不同,它的返回值也不同,返回值为“Hello”+你输入的参数.这里用到了“PathPar

SpringBoot实战(十)之使用Spring Boot Actuator构建RESTful Web服务

一.导入依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.

Yii2高速构建RESTful Web服务功能简单介绍

Yii2相比Yii1而言,一个重大的改进是内置了功能完备的RESTful支持. 其内置RESTful支持提供了例如以下功能: 使用ActiveRecord的通用接口来高速构建原型: 应答格式协商(缺省支持 JSON 和 XML). 可定制的对象序列化,支持选择输出哪些列. 请求数据的格式化以及验证错误: 通过HTTP 动词映射实现高效路由: 支持 OPTIONS 和 HEAD 动词: 认证 和 鉴权: 支持 HATEOAS(RESTful的架构约束,超媒体即应用程序状态): 结果缓存.可使用 y