NC65接口开发

前言

WebService的两种方式为SOAP和REST。SOAP是一种具体的通讯协议,REST是一种规范。

SOAP

SOAP(Simple Object Access Protocol)简单对象访问协议,是基于HTTP的一种异构系统通信的协议,说白了就是XML格式的文档传输(WSDL)。
WSDL (Web Service Description Language) 也遵循XML格式,用来描述哪个服务器提供什么服务,怎样找到它,以及该服务使用怎样的接口规范。

WebService开发框架也有很多,比较热门的就cxf, axis, axis2等。

REST

REST (Representational State Transfer)表述性状态传递,REST只是一种架构风格,而不是协议或标准。



WebService接口开发

开发环境配置

配置IDE启动参数,服务端增加:

-Duap.hotwebs=uapws

如有其他则用逗号隔开。

如果环境是NC65,服务端增加:

-Dorg.owasp.esapi.resources=${FIELD_NC_HOME}/ierp/bin/esapi

不然可能会报错Failed to load ESAPI.properties as a classloader resource

如图

ima-202204131

注意:项目需要初次启动后才会出现上图的UAP应用配置


编写webservice代码

在public包下创建接口

在public包下创建接口

在private下创建接口实现类

ima-20220414083617127

在META-INF文件夹下建立一个空的upm文件

ima-20220414083838267

并在upm中添加如下内容

module name=“模块名”

<?xml version='1.0' encoding='UTF-8'?>
<module name="tsdp">
	<public>
	</public>
	<private>
	</private>
</module>

WS Tools发布

在接口文件上点击右键,选择“WS Tools”-> “Public Web Service”,如图:

WS Tools发布

选择事先创建好的upm文件

ima-20220414084226194

填写“组件名称”(其他信息不需填写),点击“查找”按钮选择相应的接口实现类,下一步

ima-20220414084251884

不需要修改,直接点下一步。

ima-20220414084321890

取消勾选,点击完成

image-20220414084338303

检查是否成功,upm文件会自动追加内容:

image-20220414084523741

并生成wsdl文件

image-20220414084600228

最后启动服务,使用soap工具测试,地址为ip:prot/uapws/service/upm文件中的compoment name,比如此示例的访问地址为127.0.0.1:8888/uapws/service/helloworld



REST方式接口开发

开发环境配置

与webservice配置一致

配置IDE启动参数,服务端增加:

-Duap.hotwebs=uapws

如有其他则用逗号隔开。

如果环境是NC65,服务端增加:

-Dorg.owasp.esapi.resources=${FIELD_NC_HOME}/ierp/bin/esapi

不然会报错Failed to load ESAPI.properties as a classloader resource

如图

REST方式接

uapYingyong


编写rest服务代码

在public下建包与java类,继承AbstractUAPRestResource

ima-20220413145757408

重写getModule()方法,return后跟nc项目模块名,并使用@Path("XXXX")在类上添加一级路径

重写moudle方法

编写接收方法,对数据进行业务处理,并在方法上标明注解:

注意:rest接口所调用代码如果在private下,需要写upm文件

@POST:http请求方式
@Path("xxxx"):二级路径
@Produces("application/json"):指定方法返回的消息格式

image-20220413145642669


代码示例一

将请求数据转为Object的示例

package nc.itf.rest.test;

import java.util.HashMap;
import java.util.Map;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import nc.vo.scmpub.api.rest.utils.RestUtils;
import com.alibaba.fastjson.JSONObject;
import uap.ws.rest.resource.AbstractUAPRestResource;

@Path("wlxd")//一级路径
public class restTest extends AbstractUAPRestResource{

	@Override
	public String getModule() {
		//当前项目模块名
		return "pu";
	}
	@POST //请求方式
	@Path("test")//二级路径
	@Produces("application/json")//返回消息格式
	public org.json.JSONString test(Object info){
		//处理接收到的电文
		JSONObject jo = new JSONObject();
		jo.parse(info.toString());
		Map<String,Object> mapRet = new HashMap<String,Object>();
		mapRet.put("status","ok");
		mapRet.put("msg","操作成功");
		JSONObject msg = new JSONObject(mapRet);
		return RestUtils.toJSONString(msg.toString());
	}
}

代码示例二

自动将请求数据转为JSONObject的示例

import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import nc.bs.framework.common.NCLocator;
import nc.bs.framework.server.ISecurityTokenCallback;
import nc.vo.scmpub.api.rest.utils.RestUtils;
import com.alibaba.fastjson.JSONObject;
import uap.ws.rest.resource.AbstractUAPRestResource;


@Path("receiveOA")
public class LeavergstRestForOA extends AbstractUAPRestResource{
	
	@Override
	public String getModule() {
		return "hrta";
	}
	
	@POST
	@Path("leavergst")
	@Produces("application/json") //请求头Content-Type需要设置为application/json;charset=utf-8
	public org.json.JSONString receiveLeavergst(JSONObject info){
				
		LeavergstForOA leavergst = NCLocator.getInstance().lookup(LeavergstForOA.class);
        
        //设置登录信息,避开权限,解决:user session expired,please re login!(0)--> token is null 的问题
		NCLocator.getInstance().lookup(ISecurityTokenCallback.class).token("NCSystem".getBytes(), "pfxx".getBytes());
        
		return RestUtils.toJSONString(leavergst.receiveOA(info));
		
	}

}

编写rest文件

编写rest文件,并放到项目的META-INF文件夹中:

module中的name值为模块名,resourceclassnamejava代码全路径,其他位置不用修改

<?xml version="1.0" encoding='gb2312'?>
<module name="pu">
    <rest>
        <resource classname="nc.itf.rest.test.restTest"  exinfo=""/>
    </rest>
</module>

ima-20220413145900047


启动项目并验证

项目启动完成后,在ip:port/uapws/restmanage查看是否有自己发布的类

image-20220413144544053

使用ip:port/uapws/rest/一级路径/二级路径,在postman中测试

ima-20220413141713077

### 创建与测试 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. 接口部署与访问路径 NC65 的 REST 接口通过统一的 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 依赖库,避免类加载失败。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值