简介

什么是2BizBox API

2BizBox是免费的ERP软件,也是一个开放的ERP平台。2BizBox面向开发者提供了完整的API二次开发接口,用于对2BizBox进行集成和二次开发。2BizBox API涵盖了2BizBox的全部功能。掌握了2BizBox API,可以帮助开发者、系统集成商、实施服务商等深入了解2BizBox的功能和机制,并与其他软件系统进行无缝集成,满足企业客户的各种实际需求。例如,和OA、CRM、PDF、其他厂商ERP系统等的系统集成和数据交换,都是典型的应用场景。

举一个简单的例子:一家企业已经成功实施了**厂商的CRM系统和2BizBox ERP系统。一般来说,CRM中并没有产品的实时成本信息和BOM信息。在报价时候,企业希望能够在CRM中直接从2BizBox中获取报价商品的当前库存、成本、以及BOM信息,方便报价。此外,达成销售协议后,企业还希望通过鼠标点击,直接在2BizBox生成销售单。该如何进行呢?此时,如果您掌握了2BizBox API的开发技巧,这一切都将变得易如反掌。

2BizBox API的位置

2BizBox API是2BizBox整个系统的后台功能定义和数据结构定义,用于各种外部程序的调用。这些外部程序包括2BizBox系统本身的GUI桌面终端、基于Web的各种模块终端、PDA掌上终端、手机终端等等。同样,如果您掌握了2BizBox API的开发方法,也可以自己创建基于2BizBox的各种终端应用,或与2BizBox进行系统集成和数据联动。

下图展示了2BizBox API在整个2BizBox系统中的位置和作用。

2BizBox API可以做什么

2BizBox API包含了2BizBox系统本身的全部功能和数据结构。所以,理论上来说,通过2BizBox API,您可以操控系统,让它做任何它可以做的事。例如,创建单据、查询数据、修改订单等等。您甚至可以通过2BizBox API开发一个全新的客户端GUI程序,当然这一工作量将巨大无比。更多时候,我们是通过2BizBox API对一部分特定功能进行调用,以完成系统集成、数据查询、二次开发等工作。

2BizBox API目前提供的是Java版本。也就是说,您可以通过Java语言来使用2BizBox API,并集成在您的Java系统中。2BizBox可以应用在桌面Java程序中(例如Swing、SWT等),也可以应用在基于Web的Java环境中(例如Servlet、JSP等)。

为什么是API而不是源代码

2BizBox是免费软件,但并不是开源软件。2BizBox软件的源代码并不对公众开放。所以,提供完整的API就是对2BizBox进行二次开发和系统集成的最佳方式。此外,相比源代码,API有更多的优势。2BizBox有超过2百万行源代码,任何个人甚至企业要想消化理解这些源代码,都并非易事,而对其进行修改和定制,就更加的困难。此外,直接修改源代码,也会带来各种各样的Bug和安全风险,导致整个2BizBox系统的不稳定。当更多的开发者对源代码进行各种各样的修改的时候,系统的集成和发展将变得更加困难,甚至会产生分裂的危险,对最终用户和2BizBox的长远发展都将是不利的。而通过统一、一致、简单、开放的API接口,开发者就不用担心2BizBox的内部运作机制,也不必去理解浩如烟海的源代码。只要API接口一致且保持兼容,2BizBox就会携广大开发者不断的向前发展,齐心协力让2BizBox系统变得更加强大。

所以,我们认为API优于源代码。2BizBox会不断丰富和开放高质量的API,聚集广大开发者一起参与到2BizBox的发展中来。

目标读者

本教程面向2BizBox API开发者、2BizBox开发合作伙伴、2BizBox系统集成商。如果您是软件厂商,如果您提供各种BI、CAD、PLM、PDM、CRM、MES、OA、SCM、Call Center、财务系统、库房系统等等,都可以通过本文掌握2BizBox API的开发方法,和2BizBox进行集成,共同建立一个企业应用的生态圈。

对于2BizBox最终用户而言,无需了解2BizBox API和2BizBox二次开发相关知识。

此外,目前2BizBox API仅提供Java版本,所以您需要掌握基本的Java开发技术。

开发实战

前期准备

2BizBox API基于Java开发。所以您需要准备以下内容:

JDK 6或以上版本;

IDE,如Eclipse或NetBeans等均可。本教程以NetBeans为例;

安装2BizBox ERP,并保证其能够运行和登录。创建一些样例数据,以便于开发测试之用;

当然,您需要有Java编程的基本知识。例如,写一个class,添加一个main函数,编译并运行,debug调试等等。好了,有了这些,我们就可以开始了。

搭建2BizBox运行环境

首先从2BizBox官方网站或各大下载网站下载2BizBox免费ERP软件(注意要下载All-in-One版本,它包括了软件的客户端和服务器程序)。双击安装文件后,按照提示进行安装。安装结束后,可以自动运行2BizBox ERP服务器和客户端。注意服务器启动要大约半分钟到一分钟所有。结束后,可以点击客户端的“登录”按钮,登录到系统的“测试”公司中。

在系统中,可以首先创建几个零件。可以观看在线视频学习如何添加一个零件。添加的零件,可以用于下面API程序的测试。这个截图是作者所在系统的零件数据:

搭建开发环境

要使用2BizBox API,需要以下jar包:

第三方包:

commons-lang-2.4.jar,Apache的Commons Lang包,一个标准的Java增强工具包;

2BizBox运行包:

common.jar,2BizBox的数据结构定义包,包含2BizBox所有涉及到的业务数据的POJO定义;

server.jar,2BizBox后台业务模块API函数封装包,封装了全部2BizBox业务API;

以上所有运行包,都可以在本站下载页面下载。

创建工程

本教程使用NetBeans作为IDE进行开发介绍。对于熟悉Eclipse工具的读者,操作方法类似,应当没有太大困难。

第一步:创建工程 在NetBeans中创建一个全新的Java工程,如下图。

给新工程命名BBApiTest,并设定工程目录。

这样,我们就创建了一个全新的、空的Java工程。

第二步:添加Jar包 如上所述,工程需要用到3个jar包。右键点击工程的Libraries目录,添加准备好的3个jar文件包。

添加后,jar包列表如下图:

至此,工程以及工程环境就搭建好了。接下来,我们可以写代码了!

第三步:创建Java类 点击菜单,生成一个普通的Java类。

给这个Java类命名ApiTest,并设置package为test。

第四步:敲入代码

在新建的Java类中敲入如下代码:

package test;import com.serva.bb2.common.BizBoxServer;
import com.serva.bb2.gui.server.EngServerActionManager;
import com.serva.bb2.gui.server.ServerActionUtil;public class ApiTest {public static void main(String[] args) throws Exception {BizBoxServer server = new BizBoxServer("localhost", "80", "test", "username", "password", "zh");ServerActionUtil.setTargetServer(server);EngServerActionManager eng = EngServerActionManager.getInstance();int count = eng.getAllPartsCount();System.out.println("2BizBox ERP系统中物料总计:" + count + "个");}
}

这是一段极其简单的Java代码。一个普通的Java类,一个main函数。在函数中,创建了一个2BizBox服务器目标,并设置ip地址、端口、公司、用户名、密码、连接语言。随后,获得工程模块的API管理器,调用函数getAllPartsCount获得连接2BizBox系统中所有物料总数。

第五步:执行工程 按F6键,执行该文件。在作者所在的及其环境下,输出结果如下:

run:
2BizBox ERP系统中物料总计:87042个
BUILD SUCCESSFUL (total time: 1 second)

恭喜!您已经成功创建了第一个2BizBox API程序。

高级开发

上面的例子简单的演示了如何通过2BizBox API来连接2BizBox后台服务器并获取数据。本章节继续用复杂一点的例子来演示如何在一个桌面程序或Web程序中通过2BizBox API与已有2BizBox系统进行集成。

Swing程序集成示例

我们假设您已经有了一个基于Java Swing的复杂的桌面应用系统,需要和2BizBox进行数据交换。或者,您已经有了一套基于桌面的OA系统,可以处理各种单据的审批,并在审批结束后,自动到2BizBox ERP中进行单据创建(例如采购单)。此时,2BizBox API就可以大有所为。

我们这里创建并模拟了一个非常简单的基于Java Swing的桌面应用程序,并通过2BizBox API与2BizBox服务器获取数据。这里我们以“模糊查询零件名字并列出”为例子,介绍如何在一个Java Swing程序中对后台的2BizBox服务器进行操作和通讯。

本例子假设您对Java和Swing技术熟悉。

重新创建一个新的Java类,命名ApiTestSearchPartUI,并从JFrame继承。在这个窗口中,上部放置几个输入框,分别用于输入要连接的服务器的IP地址、公司、用户名、密码,以及要查询零件的关键字。窗口中间,放一个大的文本框,用于显示返回结果。

下面几行代码用于对窗口初始化。包括大小、关闭动作、标题等:

this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setTitle("2BizBox API测试");
this.setSize(750, 500);
this.setLocation(300, 300);

接下来,把创建好的Swing组件放在一个Panel中,并放置在窗口顶端:

JPanel settingPane = new JPanel(new FlowLayout(FlowLayout.LEADING, 5, 0));
settingPane.setBorder(BorderFactory.createEmptyBorder(10, 10, 10, 10));
settingPane.add(new JLabel("Server:"));
settingPane.add(this.txtServer);
settingPane.add(new JLabel("Company:"));
settingPane.add(this.txtCompany);
settingPane.add(new JLabel("User:"));
settingPane.add(this.txtUser);
settingPane.add(new JLabel("Password:"));
settingPane.add(this.txtPassword);
settingPane.add(new JLabel("Search:"));
settingPane.add(this.txtSearch);
settingPane.add(btnConnect);

在后面,放置一个按钮。当点击按钮时,我们根据用户输入的信息,对服务器进行连接,并根据搜索条件,从后台搜索符合条件的零件:

this.btnConnect.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {try {initServer();findPartsByDescriptionInside();} catch (Exception ex) {ExceptionWorker worker = new ExceptionWorker(ex);String message = worker.getMessage();JOptionPane.showMessageDialog(ApiTestSearchPartUI.this, message);}}
});

代码中,后台调用可能发生异常。所以,在catch异常后,我们要进行处理。这里,使用2BizBox API中提供的ExceptionWorker对异常进行分析和处理,并将结果翻译、解析,通过getMessage()函数返回。我们直接把异常的详细描述通过文本框显示出来即可。

在调用后台时,先通过如下代码初始化服务器。其中,端口默认是80,登录语言默认是英文。

private void initServer() {String server = this.txtServer.getText().trim();String port = "80";String company = this.txtCompany.getText().trim();String user = this.txtUser.getText().trim();String password = new String(this.txtPassword.getPassword());String language = "en";BizBoxServer targetServer = new BizBoxServer(server, port, company, user, password, language);ServerActionUtil.setTargetServer(targetServer);
}

接下来是真正的调用代码。首先获得工程模块的接口EngineeringBox,然后调用其中的findPartsByDescriptionInside函数,来模糊搜索符合条件的零件。其中几个参数解释如下:

第一个参数:零件号。如果不限定零件号,直接输入空字符串""即可;

第二个参数:零件类型。如果不限定零件类型,直接输入空字符串""即可;

第三个参数:零件描述。这是我们要使用的零件描述过滤条件,传入用户在界面上的录入;

第四个参数:返回集合的开始游标。也就是从符合条件的结果集的第几个记录开始;

第五个参数:返回集合的长度。也就是最多返回多少个符合条件的记录,注意不要太大,导致服务器附在过重。这里设置100条;

private void findPartsByDescriptionInside() throws Exception {EngineeringBox eng = EngServerActionManager.getInstance();String search = this.txtSearch.getText().trim();Collection<PartBasicInfo> parts = eng.findPartsByDescriptionInside("", "", search, 0, 100);String result = "";if (parts != null) {Iterator<PartBasicInfo> it = parts.iterator();while (it.hasNext()) {PartBasicInfo part = it.next();result += part.getPartPk().getPartNumber();result += "\t";result += part.getDescription();result += "\n";}}this.txtResult.setText(result);
}

返回结果集是PartBasicInfo对象的集合。PartBasicInfo对象包含了零件对象的简要信息。对返回结果集进行遍历,将零件号和零件描述输出到文本框中进行显示。

完整程序如下:

package test;import com.serva.bb2.common.BizBoxServer;
import com.serva.bb2.common.PartBasicInfo;
import com.serva.bb2.common.box.EngineeringBox;
import com.serva.bb2.gui.server.EngServerActionManager;
import com.serva.bb2.gui.server.ServerActionUtil;
import com.serva.bb2.gui.swing.ExceptionWorker;
import java.awt.BorderLayout;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Collection;
import java.util.Iterator;
import javax.swing.BorderFactory;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JPasswordField;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;public class ApiTestSearchPartUI extends JFrame {private JTextField txtServer = new JTextField("192.168.1.121", 8);private JTextField txtCompany = new JTextField("test", 4);private JTextField txtUser = new JTextField("admin", 4);private JPasswordField txtPassword = new JPasswordField("password", 4);private JTextField txtSearch = new JTextField(8);private JTextArea txtResult = new JTextArea();private JButton btnConnect = new JButton("Connect");public ApiTestSearchPartUI() {this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);this.setTitle("2BizBox API测试");this.setSize(750, 500);this.setLocation(300, 300);JPanel settingPane = new JPanel(new FlowLayout(FlowLayout.LEADING, 5, 0));settingPane.setBorder(BorderFactory.createEmptyBorder(10, 10, 10, 10));settingPane.add(new JLabel("Server:"));settingPane.add(this.txtServer);settingPane.add(new JLabel("Company:"));settingPane.add(this.txtCompany);settingPane.add(new JLabel("User:"));settingPane.add(this.txtUser);settingPane.add(new JLabel("Password:"));settingPane.add(this.txtPassword);settingPane.add(new JLabel("Search:"));settingPane.add(this.txtSearch);settingPane.add(btnConnect);this.add(settingPane, BorderLayout.NORTH);JPanel resultPane = new JPanel(new BorderLayout());resultPane.setBorder(BorderFactory.createEmptyBorder(0, 10, 10, 10));resultPane.add(new JScrollPane(txtResult), BorderLayout.CENTER);this.add(resultPane, BorderLayout.CENTER);this.btnConnect.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {try {initServer();findPartsByDescriptionInside();} catch (Exception ex) {ExceptionWorker worker = new ExceptionWorker(ex);String message = worker.getMessage();JOptionPane.showMessageDialog(ApiTestSearchPartUI.this, message);}}});}private void initServer() {String server = this.txtServer.getText().trim();String port = "80";String company = this.txtCompany.getText().trim();String user = this.txtUser.getText().trim();String password = new String(this.txtPassword.getPassword());String language = "en";BizBoxServer targetServer = new BizBoxServer(server, port, company, user, password, language);ServerActionUtil.setTargetServer(targetServer);}private void findPartsByDescriptionInside() throws Exception {EngineeringBox eng = EngServerActionManager.getInstance();String search = this.txtSearch.getText().trim();Collection<PartBasicInfo> parts = eng.findPartsByDescriptionInside("", "", search, 0, 100);String result = "";if (parts != null) {Iterator<PartBasicInfo> it = parts.iterator();while (it.hasNext()) {PartBasicInfo part = it.next();result += part.getPartPk().getPartNumber();result += "\t";result += part.getDescription();result += "\n";}}this.txtResult.setText(result);}public static void main(String[] args) throws Exception {ApiTestSearchPartUI ui = new ApiTestSearchPartUI();ui.setVisible(true);}
}

运行效果如下图:

在这个例子中,我们输入了正确的登录信息,并收入汉字“机”作为零件描述的关键字,在要连接的2BizBox服务器上进行数据查询,搜索出了大量符合条件的记录,并显示在了下面的文本框中。读者可以自行修改查询条件,在您的2BizBox系统中自由查询,体现“自由操控2BizBox”的乐趣!

以上例子是一个非常简单、典型的Swing程序,但它已经可以成功的连接任意2BizBox服务器,只要您有正确的用户登录信息即可,并且可以查询和搜索零件信息。只要稍加改造,就可以把上面的代码嵌入在您自己的Swing程序中,和2BizBox ERP进行联动或数据集成了。

Web程序集成示例

在Web开发环境中集成2BizBox API也是非常简单的事情。本例子用一个非常简单的JSP来说明如何在JSP中通过2BizBox API来调用远程2BizBox服务器并获得数据、在浏览器中输出。在实际Web开发中,您可以通过这种方式来和2BizBox服务器进行通讯和数据交换,并与您现有的Web系统进行集成和整合。

首先准备tomcat。可以到tomcat官方网站下载免安装版本的zip格式文件。下载后,解压zip文件。进入其中的bin目录,双击startup.bat文件,确保能够正常启动tomcat。如果不能启动,最可能的问题是没有安装Java环境,或没有正确设置JAVA_HOME环境变量。

接下来,我们手工创建一个非常简单的JSP。在webapps目录中,我们创建一个2bizbox目录,作为测试工程。在其中,创建WEB-INF子目录,并在WEB-INF中创建一个web.xml文件,用来定义这个Web工程的信息。我们在其中放入最简单的一个配置文件即可,内容如下:

<?xml version="1.0" encoding="ISO-8859-1"?><web-app xmlns="http://java.sun.com/xml/ns/j2ee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"version="2.4"></web-app>

然后,在WEB-INF中创建lib文件夹,将2BizBox API需要的几个运行jar包放进去,分别是common.jar、commons-lang-2.4.jar、server.jar几个包。好了,这样,一个空的Web环境就搭建成功了。

下面,我们创建JSP测试文件。在2bizbox目录中,用写字板创建一个test.jsp文件。在其中,输入下面代码:

<%@ page import="java.util.*, com.serva.bb2.common.*, com.serva.bb2.common.box.*, com.serva.bb2.gui.server.*, com.serva.bb2.gui.swing.*" %><%
BizBoxServer server = new BizBoxServer("localhost", "80", "test", "admin", "password", "en");
ServerActionUtil.setTargetServer(server);EngineeringBox eng = EngServerActionManager.getInstance();
String search = "TEST";
Collection<PartBasicInfo> parts = eng.findPartsByDescriptionInside("", "", search, 0, 100);
String result = "";
if (parts != null) {Iterator<PartBasicInfo> it = parts.iterator();while (it.hasNext()) {PartBasicInfo part = it.next();result += part.getPartPk().getPartNumber();result += "********";result += part.getDescription();result += "<br>";}
}
out.write(result);%>

这段代码很简单,首先创建2BizBox目标服务器的地址和登录信息,并进行连接。然后,从其中的工程模块调用findPartsByDescriptionInside方法查询最多100条描述中包含"TEST"字符串的零件。最后,把返回的结果集通过字符串把零件号和零件描述输出在网页中。

在作者的环境下,输出结果如下图:

如果进一步简单改造,可以在这个页面上增加表单,自由输入服务器地址、用户名、密码、查询条件等,并提交本页面进行动态查询,就可以实现真正的零件查询了。

了解更多

通过以上步骤可以看到,基于2BizBox API进行二次开发和系统集成是非常简单的事情。对于一个熟悉Java的开发者来说,几分钟就可以完成本教程。怎么样,您是否有兴趣亲自试一试呢?

您可以到在线JavaDoc页面,在线查看详细的2BizBox API JavaDoc文档;

您可以到2BizBox API下载页面下载最新版本的2BizBox API运行包;

希望您能够从中得到更多乐趣!

2BizBox免费ERP API初体验相关推荐

  1. ap接口 php_小白php API初体验 php api文档 php api接口开发 php web ap

    这里的php 写API其实就是指提供一个WebServiceWebSite : 1.以html格式响应返回 2.由用户通过浏览器来接入 WebService : 1.以json/Xml格式返回 2.由 ...

  2. 2BizBox 免费ERP v3.3.0 新版本剧透之二:自定义打印模板

    2BizBox ERP使的可以,但销售单等单据有时不能反应企业风格满足独特需要.对于企业来讲,很多单据特别重要.尤其是传递给往来业务单位的单据,由于其固有的业务格式和双方的特殊业务约定等因素的影响,需 ...

  3. Kong Api 初体验、Kong安装教程

    见:https://blog.csdn.net/forezp/article/details/79383631 Kong是一个可扩展的开源API层(也称为API网关或API中间件). Kong运行在任 ...

  4. Kong Api 初体验

    个人博客纯净版:https://www.fangzhipeng.com/%E6%9E%B6%E6%9E%84/2017/09/17/kong-api-gateway.html Kong是一个可扩展的开 ...

  5. Vue3 组合式API初体验

    目录 一.背景 二.什么是组合式API(Composition API ) 组合式API全景 为什么要引入组合式API `mixins` 的方式 域插槽的方式 组合式API的方式 结论 组合式API存 ...

  6. 在 npm 发布中文 API 初体验——中国历代纪元

    发布细节参考中文代码演示--创建 Node.js 模块过程,没什么意外. 数据来源是新华字典第 11 版附录"我国历代纪元简表",以后慢慢细化,先做个草稿. 现在只有一个接口: v ...

  7. Vue3通透教程【四】Vue3组合API初体验

    文章目录

  8. 免费ERP第四锤:免费?必须地!

    就不解释什么是ERP了.直接说说ERP这个行当吧. 混乱的ERP行业 ERP这个行当怪的很.其实ERP的行业的盘子不大.以制造业为例,根据计世资讯统计,2008年中国生产制造ERP市场规模仅有37.8 ...

  9. 免费WiFi初体验——个小白的WiFi旅程

    说来羞愧,真正接触到WiFi还是在毕业后,此前自己封闭在一个人的世界,再加上外在学校的包围,我还成了个"山里"的孩子. 去年毕业了,也算是个90后,可自觉得心态过于成熟.了解外界太 ...

最新文章

  1. vscode pylint 错误_VScode中报Unable to import #x27;xxx#x27; pylint的解决方案
  2. 每个网页设计师应该知道的10条CSS规则
  3. 常用10种PHP编辑器下载
  4. mysql5.6的my.cnf配置详解
  5. 微信小程序小模块界面,边框带阴影
  6. 对话Linus:Linux 25岁啦
  7. html td装满图片,HTML:桌子上的Td不满
  8. 10976 - Fractions Again?!
  9. IOS iframe宽高问题(来至stackoverflow)
  10. opencv中的图像拼接
  11. 没有什么能难倒程序员,教你如何下载付费歌曲
  12. 数码照巧转胶片效果 美图秀秀制作质感写真
  13. 胡适致迷茫大学生:成不在一时,功必不唐捐
  14. A fatal exception has occurred.Program will exit。可能是系统装有多个java编程程序。
  15. 最新AI产品经理求职动态:卡年龄、卡学历,这么卷,怎么办?
  16. iPad goodnotes 5 打开很慢“准备自己的资料库,获得更快体验”解决
  17. Hadoop-3.xx单机和集群安装教程
  18. 计算机用户被停用,Win10电脑中Administrator账户被停用如何解决
  19. 《设计模式的艺术》读书笔记
  20. 家电消费市场潜力爆发,智能制造成发展趋势

热门文章

  1. 前端压缩图片 -- vue项目使用localResizeIMG插件 -- 实例
  2. 电信管理系统的操作思路
  3. IPv6技术精要--第3章 对比IPv4和IPv6
  4. CMOS图像传感器设计重点
  5. Axure教程:一个通用的app注册/登录页
  6. 印度理工学院射频集成电路设计之电感负反馈低噪声放大器
  7. 【自动驾驶轨迹预测】一文熟悉自动驾驶轨迹预测发展现状!
  8. linux db2 权限管理,DB2权限与授权
  9. db2 LIKE 语句
  10. 微信小程序开发demo10