2BizBox API开发教程

2BizBox API开发教程

目录

[隐藏]
  • 1 简介
    • 1.1 什么是2BizBox API
    • 1.2 2BizBox API的位置
    • 1.3 2BizBox API可以做什么
    • 1.4 为什么是API而不是源代码
    • 1.5 目标读者
  • 2 开发实战
    • 2.1 前期准备
    • 2.2 搭建2BizBox运行环境
    • 2.3 搭建开发环境
    • 2.4 创建工程
  • 3 高级开发
    • 3.1 Swing程序集成示例
    • 3.2 Web程序集成示例
  • 4 了解更多

简介

什么是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类中敲入如下代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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键,执行该文件。在作者所在的及其环境下,输出结果如下:

?
1
2
3
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地址、公司、用户名、密码,以及要查询零件的关键字。窗口中间,放一个大的文本框,用于显示返回结果。

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
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);

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
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,登录语言默认是英文。

?
1
2
3
4
5
6
7
8
9
10
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条;
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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对象包含了零件对象的简要信息。对返回结果集进行遍历,将零件号和零件描述输出到文本框中进行显示。

完整程序如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
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工程的信息。我们在其中放入最简单的一个配置文件即可,内容如下:

?
1
2
3
4
5
6
7
8
<? 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文件。在其中,输入下面代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<%@ 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的开发者来说,几分钟就可以完成本教程。怎么样,您是否有兴趣亲自试一试呢?

  • 您可以到2BizBox API JavaDoc v3.3.0页面,在线查看详细的2BizBox API JavaDoc文档;
  • 您可以到2BizBox API下载页面下载最新版本的2BizBox API运行包;

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


你可能感兴趣的:(java,swing,api,String,服务器,Netbeans)