NC65 REST接口开发及调试

本文详细介绍了如何在NC65中通过REST协议实现Webservice接口,包括接口注册的XML配置、服务代码编写以继承AbstractUAPRestResource,以及部署和测试Postman的方法。重点在于restlet框架的应用和实际操作步骤。
NC65中除了支持SOAP协议的webservice接口外,还支持REST协议的接口,NC65的REST服务封装的是restlet,找了很多资料终于弄清楚了,这里总结归纳一下,供朋友们参考:

1、接口注册方法
在模块的META-INF文件夹下,增加.rest扩展名的接口文件,内容为xml格式,参考脚本如下:

<?xml version="1.0" encoding='gb2312'?>
<module>
    <rest>
        <resource classname="nc.pubitf.dm.api.rest.DMResource"  exinfo=""/>
 
       <!--  <resource classname="第二个接口"  exinfo=""/> -->
    </rest>
</module>

2、服务代码编写
注册文件中的nc.pubitf.dm.api.rest.DMResource需要放在开发环境的public源码目录下,继承uap.ws.rest.resource.AbstractUAPRestResource,参考脚本如下

package nc.pubitf.dm.api.rest;
 
import javax.ws.rs.Consumes;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
 
import org.json.JSONString;
import nc.vo.scmpub.api.rest.utils.RestUtils;
import nc.vo.scmpub.res.Module;
import uap.ws.rest.resource.AbstractUAPRestResource;
 
@Path("service") 
/*指定路径 
 默认service:http://ip:port/uapws/rest/service/hello
 也可以:@Path("crm2so") 
 service:http://ip:port/uapws/rest/crm2so/hello
*/
public class DMResource extends AbstractUAPRestResource {
 
 
    @Override
    public String getModule() {
        // TODO Auto-generated method stub
        return Module.DM.getName();   //返回一个字符串,与接口定义文件所在的module对应即可
    }
    
    @POST
    @Path("hello")
    @Produces("application/json")
    @Consumes("application/json")
    public JSONString hello(){
        return RestUtils.toJSONString("Hello World!");
    }
}

3、部署和测试

将上面的代码部署到dm模块后,重启中间件,Postman测试时,测试URL设置为:http://ip:port/uapws/rest/service/hello,其中service/hello为代码中的类声明中的Path和方法中的Path,uapws/rest/为固定的NC65中的REST服务访问路径。Postman中设置请求方式为“POST”,请求HEAD参数Content-Type为application/json即可。效果如下:

在这里插入图片描述

### 创建与测试 NC65 REST API NC65 平台提供了开发 RESTful 接口的能力,允许开发者通过标准化的方式暴露业务逻辑和数据。以下是基于 NC65 开发 REST 接口的完整指南,涵盖接口创建、配置、实现以及测试等关键步骤。 #### 1. 接口类的创建与继承 在 NC65开发 REST 接口,首先需要创建一个继承自 `AbstractUAPRestResource` 的类。在某些项目中,也可能继承 `AbstractNCCRestResource` 或 `MTFRestResource`,具体取决于项目的架构设计和底层依赖。此类需要重写 `getModule` 方法,用于返回当前接口所属模块的名称。 ```java package nc.pubitf.dm.api.rest; import javax.ws.rs.*; import javax.ws.rs.core.MediaType; import org.json.JSONString; import nc.vo.scmpub.api.rest.utils.RestUtils; import nc.vo.scmpub.res.Module; import uap.ws.rest.resource.AbstractUAPRestResource; @Path("service") public class DMResource extends AbstractUAPRestResource { @Override public String getModule() { return Module.DM.getName(); } @POST @Path("hello") @Produces(MediaType.APPLICATION_JSON) @Consumes(MediaType.APPLICATION_JSON) public JSONString hello() { return RestUtils.toJSONString("Hello World!"); } } ``` #### 2. 配置 REST 接口文件 在接口开发完成后,需要在模块的 `META-INF` 目录下创建一个 `.rest` 格式的配置文件。该文件用于注册接口类,使其能够在运行时被识别并加载。配置文件格式如下: ```xml <?xml version="1.0" encoding='gb2312'?> <module> <rest> <!-- classname 为接口类的全限定名 --> <resource classname="nc.pubitf.dm.api.rest.DMResource" exinfo=""/> </rest> </module> ``` 此文件应放置在 NC65 系统中对应的模块目录下,通常位于 `Home` 路径中的模块配置目录中。 #### 3. 接口部署与访问路径 NC65REST 接口通过统一的 URL 前缀进行访问,通常为 `/service/restuapbd`,具体路径取决于接口类上 `@Path` 注解的定义。例如,若类定义为 `@Path("service")`,则接口路径为 `/service/restuapbd/service`。 每个方法上的 `@Path` 注解进一步定义了具体的接口路径。例如,`@Path("hello")` 对应的完整访问路径为 `/service/restuapbd/service/hello`。 #### 4. 接口测试 接口测试可以通过多种方式进行,包括使用 Postman、curl 命令或编写单元测试代码。以下是一个使用 curl 命令测试 POST 接口的示例: ```bash curl -X POST http://localhost:8080/service/restuapbd/service/hello -H "Content-Type: application/json" -d '{}' ``` 预期返回结果为: ```json "Hello World!" ``` 也可以使用 Postman 构造 POST 请求,设置请求头 `Content-Type: application/json`,并发送空对象 `{}`。 #### 5. 日志与调试接口开发过程中,建议开启 NC65 的日志输出功能,以便跟踪请求处理流程。可以通过配置日志级别为 `DEBUG` 来查看更详细的运行时信息。此外,使用 IDE 的调试功能可以更直观地分析接口执行路径和数据流转。 #### 6. 常见问题与注意事项 - **类路径问题**:确保接口类位于 `public` 或 `client` 源码目录下,并正确配置 `.rest` 文件。 - **模块名一致性**:`getModule` 方法返回的模块名应与接口定义文件中的模块名一致。 - **URL 映射冲突**:避免多个接口类使用相同的 `@Path` 路径,防止 URL 冲突。 - **依赖管理**:确保项目中引入了正确的 UAP 和 NC65 依赖库,避免类加载失败。 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值