NC65 REST接口开发及调试

本文详细介绍了如何在NC65中通过REST协议实现Webservice接口,包括接口注册的XML配置、服务代码编写以继承AbstractUAPRestResource,以及部署和测试Postman的方法。重点在于restlet框架的应用和实际操作步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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前台代码的方法 在进行用友NC65开发调试过程中,前台代码通常涉及用户界面(UI)交互逻辑、事件绑定以及数据展示等内容。为了确保前台代码能够正常运行并满足业务需求,可以采用以下几种方法进行调试: #### 1. 使用浏览器开发者工具 对于基于Web技术实现的前台页面(如JSP、HTML5、JavaScript等),可以通过浏览器内置的开发者工具进行调试。例如: - **Chrome DevTools**:通过F12键打开开发者工具,切换到“Sources”选项卡,在对应的JS文件中设置断点,逐步执行代码。 - **Firefox Developer Edition**:提供类似的调试功能,并支持更详细的性能分析。 通过这些工具可以查看网络请求、响应数据、DOM结构变化以及JavaScript异常信息,从而定位问题所在。 #### 2. 日志输出与控制台打印 在关键的前台逻辑中添加`console.log()`或`alert()`语句,将变量值、函数调用路径等信息输出到控制台或弹窗中,以便实时观察程序执行状态。例如: ```javascript console.log("当前查询条件为:", condition); ``` 这种方式适用于快速验证某个函数是否被正确调用或参数传递是否正确。 #### 3. NC65平台提供的调试机制 根据引用内容,NC65中的增删改查操作通常由向导生成并在Private包中实现[^1]。虽然这部分主要涉及后台逻辑,但前台与后台之间的数据交互也可以通过设置断点的方式进行调试。具体步骤如下: - 在IDE(如Eclipse)中配置好NC65开发环境; - 找到前台页面所对应的控制器类或服务类; - 在相关方法上设置断点,启动中间件并访问前台页面触发对应操作; - 查看SQL语句或其他日志输出,确认数据是否按照预期处理。 #### 4. REST接口调试工具 如果前台是通过RESTful API与后端通信,则可以使用Postman等工具模拟请求,检查返回结果是否符合预期。例如,测试URL格式为`http://ip:port/uapws/rest/service/hello`,需要设置请求方式为POST,并指定Content-Type为application/json[^2]。此外,某些接口可能需要携带token认证信息,如`uap_token`字段[^3]。 #### 5. 前端框架专用调试工具 如果项目中使用了特定的前端框架(如React、Vue.js等),还可以借助框架自带的调试插件或社区推荐的调试工具进一步提升效率。例如: - **Vue Devtools**:用于调试Vue应用的状态管理、组件树结构及事件流; - **React Developer Tools**:支持React组件层级查看、props和state检查等功能。 这些工具可以帮助开发者更直观地理解应用的运行时行为,加快问题排查速度。 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值