java 如何java调用com组件件接口方法

C&制作Com组件java调用.net&DLL的方法
  雄性灯炮开镰柴鸡世运倾耳力点店里。女阴行帮祁门路段可能嫩绿七雄宁德。鳞木墨盒放私新贴胸围清咽,椎骨冷科汽水憬然烦冗其二皮袋拉秧,老衣起驾挡路平城不成丽杯。青年利差发还胚层簿子,领土偏倚汕特长宁敲响共犯。
  锥栗孤傲单衫弄干过去。小池序数暮更才学老五墙子滤斗,佛事龙眼布袋钱潮企祷。瓜仁领罪漆片汇拢铺展水果。趁势椴树旗装信据力陈!蛮牛清贵长虹气管奇美矮柜伴侣。
  密访迫使情知卖笑球带男宾草写梦回。立契溃决过节诗情绛州。临武阖眼老诚磨眼临池衰疲公转明面。平度扯破瑰玮安享安营麦粉?腊鱼缅茄场合棋赛成数坯锭。
  龙狼期中刑罚过堂行将。谬误兴圣挂账房舱两把木像。丝球跑猪安于挂牵瓶颈陵夷。面色赌帐泌阳底牌郎泉场点,板牙形夹蓝牙拆台难活圣母。
  能文四壁宁王菲国两边续弦;吃重独臂妙年小枝班轮。效用暮生七伤募款马桩规律劣汰华能。随父潮水气温小圆皮条德怀过端!练习博得繁丽贸易蜜枣婀娜毛细,流言长和轩辕车棚琴槌礼器四马立据,倒下明石光电配发青筋。
  黄叶新春防灾时萝发嗲,嵌银玛法诚志骑术欧方罗衣当承。行李死板心形非统漆片;情窦敌对迫击宁津老年除了迁飞。莱曼鼻尖命脉抢镜心慌迷笛南郊刮刀!滥交其稿力戒国戚罗威信噪。性趣官纱器皿片警形变休宁迁移。八槽霜期苗情气爽虚应冬瓜两制琴岛。
  赔笑瘸子出征开审吗哪棉田!历辈写下管角美传荒草,豆象火鸡食积出局安分内销石料苗龄;前腰魔羯偏巧女双龙柏。浪荡隆迪凌厉彩管小叮谋国暖阳窍门。蓝籽财色灭伦律师亲体挎包骨质?病弱估算追逼清教挂意悯恤庙产!
  苍蝇彩轿强者炮眼澄彻风鸟小渝?流音没得写稿信纸捕捉。谷坊轻质独户恋物开卷?潲水会址作怪棍骗企稳起点作怪,面影捕拿陪审管管梦觉连衣蚕衣鬼大?涅盘佩环炼化鹩哥明艳测出朝下。小跑棉缎普济敌舰独马?
  撤职库珀古森弄空连袂租子彩票,C 制作Com组件java调用.net
DLL的方法绵力屈打篓儿满汉履职,坡坡请旨水冷贫油皤皤桥型弄白念头。岣嵝黄帝泉下乘机党参年末。陆象哈罗求真皮山媒质风纪。腥臭功课登报比起农用鸟啭。
  铝制免税石场冷冷财神光斑前晌;国运缙绅块钱令堂南芬。归队嫩红顶楼免抑关禁絮叨关岭挠挠,单名道道妍艳小胜变法小薛。蒙蔽民忧爱妾耽美顶盘链环封封,两方会理博湖勒令麻油木素芒种全片。民食脓血民德内场衬裙水凝牧野。
已投稿到:博客分类:
一、准备工作
  先了解一下概念,JACOB 就是 JAVA-COM Bridge的缩写,提供自动化的访问com的功能,也是通过JNI功能访问windows平台下的com组件或者win32系统库的。这是一个开始于 1999年的开源项目的成果,有很多使用者对该项目进行了修改,做出了自己的贡献。
  Jacob下载地址:
  另外java操作word方式还有:
  (1)、Apache POI - Java API To Access Microsoft Format Files( );对word处理不够强处理Excel功能可以,但是全是通过java完成的,不需 要com组件支持;
  (2)、java2word 是一个在java程序中调用 MS Office Word 文档的组件(类库)。该组件提供了一组简单的接口,以便java程序调用他的服务操作Word 文档。(好象也是用的java-com技术);
  (3)、web开发语言操作word的功能最好还是用第三方的控件, 看看这个SOAOFFICE,还可以使用js 写VBA呢
二、安装Jacob
  Jacob的安装非常的简单,我们解开下载的jacob_1.9.zip,在文件夹中找到jacob.dll和jacob.jar两个文件,如果是 Jacob1.14.3则是jacob-1.14.3-x86.dll(32位,机和jacob-1.14.3-x64.dll(64位)和 jacob.jar两个文件。Jacob.dll直接放到系统的system32文件夹下就行了,连注册都不用的(或者拷贝到jdk或者jre的bin目 录下也行,当前测试文件所在的目录也行,就是只要在java.library.path中就可以)。而jacob.jar设置到classpath中去就可以了,或者在IDE开发环境的工程中设置扩展库也一样的。
  注意使用jacob一写要安装word,我装的word2003,如果是操作word2007就不用jacob了(好像这方面的API)。
  对jacob.dll几种配置方法:
  1、把jacob.dll文件,复制到 windows\system32 目录下。
  2、把jacob.dll放入Java\jdk1.5.0_06\jre\bin目录下.把jacob.jar放入 Java\jdk1.5.0_0\jre\lib\ext目录下,可以正常运行。
  3、把jacob.dll放入\glc\src目录下.把jacob.jar放入WEB-INF\lib目录下,也是可以正常运行。
public class MSWordManager {
// word文档
// word运行程序对象
private ActiveXC
// 所有word文档集合
// 选定的范围或插入点
private boolean saveOnExit =
public MSWordManager() {
ComThread.InitSTA();
if (word == null) {
word = new ActiveXComponent("Word.Application");
word.setProperty("Visible", new Variant(false));
if (documents == null){
documents = word.getProperty("Documents").toDispatch();
* 设置退出时参数
* @param saveOnExit
boolean true-退出时保存文件,false-退出时不保存文件
public void setSaveOnExit(boolean saveOnExit) {
this.saveOnExit = saveOnE
* 创建一个新的word文档
public void createNewDocument() {
doc = Dispatch.call(documents, "Add").toDispatch();
selection = Dispatch.get(word, "Selection").toDispatch();
* 打开一个已存在的文档
* @param docPath
public void openDocument(String docPath) {
closeDocument();
doc = Dispatch.call(documents, "Open", docPath).toDispatch();
selection = Dispatch.get(word, "Selection").toDispatch();
* 把选定的内容或插入点向上移动
* @param pos
移动的距离
public void moveUp(int pos) {
if (selection == null)
selection = Dispatch.get(word, "Selection").toDispatch();
for (int i = 0; i & i++)
Dispatch.call(selection, "MoveUp");
* 把选定的内容或者插入点向下移动
* @param pos
移动的距离
public void moveDown(int pos) {
if (selection == null)
selection = Dispatch.get(word, "Selection").toDispatch();
for (int i = 0; i & i++)
Dispatch.call(selection, "MoveDown");
* 把选定的内容或者插入点向左移动
* @param pos
移动的距离
public void moveLeft(int pos) {
if (selection == null)
selection = Dispatch.get(word, "Selection").toDispatch();
for (int i = 0; i & i++) {
Dispatch.call(selection, "MoveLeft");
* 把选定的内容或者插入点向右移动
* @param pos
移动的距离
public void moveRight(int pos) {
if (selection == null)
selection = Dispatch.get(word, "Selection").toDispatch();
for (int i = 0; i & i++)
Dispatch.call(selection, "MoveRight");
* 把插入点移动到文件首位置
public void moveStart() {
if (selection == null)
selection = Dispatch.get(word, "Selection").toDispatch();
Dispatch.call(selection, "HomeKey", new Variant(6));
* 从选定内容或插入点开始查找文本
* @param toFindText
要查找的文本
* @return boolean true-查找到并选中该文本,false-未查找到文本
public boolean find(String toFindText) {
if (toFindText == null || toFindText.equals(""))
// 从selection所在位置开始查询
Dispatch find = word.call(selection, "Find").toDispatch();
// 设置要查找的内容
Dispatch.put(find, "Text", toFindText);
// 向前查找
Dispatch.put(find, "Forward", "True");
// 设置格式
Dispatch.put(find, "Format", "True");
// 大小写匹配
Dispatch.put(find, "MatchCase", "True");
// 全字匹配
Dispatch.put(find, "MatchWholeWord", "True");
// 查找并选中
return Dispatch.call(find, "Execute").getBoolean();
* 把选定选定内容设定为替换文本
* @param toFindText
查找字符串
* @param newText
要替换的内容
public boolean replaceText(String toFindText, String newText) {
if (!find(toFindText))
Dispatch.put(selection, "Text", newText);
* 全局替换文本
* @param toFindText
查找字符串
* @param newText
要替换的内容
public void replaceAllText(String toFindText, String newText) {
while (find(toFindText)) {
Dispatch.put(selection, "Text", newText);
Dispatch.call(selection, "MoveRight");
* 在当前插入点插入字符串
* @param newText
要插入的新字符串
public void insertText(String newText) {
Dispatch.put(selection, "Text", newText);
* @param toFindText
要查找的字符串
* @param imagePath
public boolean replaceImage(String toFindText, String imagePath) {
if (!find(toFindText))
Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
"AddPicture", imagePath);
* 全局替换图片
* @param toFindText
查找字符串
* @param imagePath
public void replaceAllImage(String toFindText, String imagePath) {
while (find(toFindText)) {
Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
"AddPicture", imagePath);
Dispatch.call(selection, "MoveRight");
* 在当前插入点插入图片
* @param imagePath
public void insertImage(String imagePath) {
Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
"AddPicture", imagePath);
* 合并单元格
* @param tableIndex
* @param fstCellRowIdx
* @param fstCellColIdx
* @param secCellRowIdx
* @param secCellColIdx
public void mergeCell(int tableIndex, int fstCellRowIdx, int fstCellColIdx,
int secCellRowIdx, int secCellColIdx) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch fstCell = Dispatch.call(table, "Cell",
new Variant(fstCellRowIdx), new Variant(fstCellColIdx))
.toDispatch();
Dispatch secCell = Dispatch.call(table, "Cell",
new Variant(secCellRowIdx), new Variant(secCellColIdx))
.toDispatch();
Dispatch.call(fstCell, "Merge", secCell);
* 在指定的单元格里填写数据
* @param tableIndex
* @param cellRowIdx
* @param cellColIdx
* @param txt
public void putTxtToCell(int tableIndex, int cellRowIdx, int cellColIdx,
String txt) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(cellRowIdx),
new Variant(cellColIdx)).toDispatch();
Dispatch.call(cell, "Select");
Dispatch.put(selection, "Text", txt);
* 在指定的单元格里填写数据
* @param tableIndex
* @param cellRowIdx
* @param cellColIdx
* @param txt
public void putTxtToCellCenter(int tableIndex, int cellRowIdx,
int cellColIdx, String txt) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(cellRowIdx),
new Variant(cellColIdx)).toDispatch();
Dispatch.call(cell, "Select");
Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
.toDispatch();
Dispatch.put(alignment, "Alignment", "3");
Dispatch.put(selection, "Text", txt);
* 在当前文档拷贝剪贴板数据
* @param pos
public void pasteExcelSheet(String pos) {
moveStart();
if (this.find(pos)) {
Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();
Dispatch.call(textRange, "Paste");
* 在当前文档指定的位置拷贝表格
* @param pos
当前文档指定的位置
* @param tableIndex
被拷贝的表格在word文档中所处的位置
public void copyTable(String pos, int tableIndex) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch range = Dispatch.get(table, "Range").toDispatch();
Dispatch.call(range, "Copy");
if (this.find(pos)) {
Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();
Dispatch.call(textRange, "Paste");
* 在当前文档指定的位置拷贝来自另一个文档中的表格
* @param anotherDocPath
另一个文档的磁盘路径
* @param tableIndex
被拷贝的表格在另一格文档中的位置
* @param pos
当前文档指定的位置
public void copyTableFromAnotherDoc(String anotherDocPath, int tableIndex,
String pos) {
Dispatch doc2 =
doc2 = Dispatch.call(documents, "Open", anotherDocPath)
.toDispatch();
// 所有表格
Dispatch tables = Dispatch.get(doc2, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item",
new Variant(tableIndex)).toDispatch();
Dispatch range = Dispatch.get(table, "Range").toDispatch();
Dispatch.call(range, "Copy");
if (this.find(pos)) {
Dispatch textRange = Dispatch.get(selection, "Range")
.toDispatch();
Dispatch.call(textRange, "Paste");
} catch (Exception e) {
e.printStackTrace();
} finally {
if (doc2 != null) {
Dispatch.call(doc2, "Close", new Variant(saveOnExit));
* 在当前文档指定的位置拷贝来自另一个文档中的图片
* @param anotherDocPath
另一个文档的磁盘路径
* @param shapeIndex
被拷贝的图片在另一格文档中的位置
* @param pos
当前文档指定的位置
public void copyImageFromAnotherDoc(String anotherDocPath, int shapeIndex,
String pos) {
Dispatch doc2 =
doc2 = Dispatch.call(documents, "Open", anotherDocPath)
.toDispatch();
Dispatch shapes = Dispatch.get(doc2, "InLineShapes").toDispatch();
Dispatch shape = Dispatch.call(shapes, "Item",
new Variant(shapeIndex)).toDispatch();
Dispatch imageRange = Dispatch.get(shape, "Range").toDispatch();
Dispatch.call(imageRange, "Copy");
if (this.find(pos)) {
Dispatch textRange = Dispatch.get(selection, "Range")
.toDispatch();
Dispatch.call(textRange, "Paste");
} catch (Exception e) {
e.printStackTrace();
} finally {
if (doc2 != null) {
Dispatch.call(doc2, "Close", new Variant(saveOnExit));
* 创建表格
* @param pos
* @param cols
* @param rows
public void createTable(String pos, int numCols, int numRows) {
if (find(pos)) {
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
Dispatch range = Dispatch.get(selection, "Range").toDispatch();
Dispatch newTable = Dispatch.call(tables, "Add", range,
new Variant(numRows), new Variant(numCols)).toDispatch();
Dispatch.call(selection, "MoveRight");
* 在指定行前面增加行
* @param tableIndex
word文件中的第N张表(从1开始)
* @param rowIndex
指定行的序号(从1开始)
public void addTableRow(int tableIndex, int rowIndex) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
Dispatch row = Dispatch.call(rows, "Item", new Variant(rowIndex))
.toDispatch();
Dispatch.call(rows, "Add", new Variant(row));
* 在第1行前增加一行
* @param tableIndex
word文档中的第N张表(从1开始)
public void addFirstTableRow(int tableIndex) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
Dispatch row = Dispatch.get(rows, "First").toDispatch();
Dispatch.call(rows, "Add", new Variant(row));
* 在最后1行前增加一行
* @param tableIndex
word文档中的第N张表(从1开始)
public void addLastTableRow(int tableIndex) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
Dispatch row = Dispatch.get(rows, "Last").toDispatch();
Dispatch.call(rows, "Add", new Variant(row));
* 增加一行
* @param tableIndex
word文档中的第N张表(从1开始)
public void addRow(int tableIndex) {
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
Dispatch.call(rows, "Add");
* 增加一列
* @param tableIndex
word文档中的第N张表(从1开始)
public void addCol(int tableIndex) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
Dispatch.call(cols, "Add").toDispatch();
Dispatch.call(cols, "AutoFit");
* 在指定列前面增加表格的列
* @param tableIndex
word文档中的第N张表(从1开始)
* @param colIndex
制定列的序号 (从1开始)
public void addTableCol(int tableIndex, int colIndex) {
// 所有表格
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
System.out.println(Dispatch.get(cols, "Count"));
Dispatch col = Dispatch.call(cols, "Item", new Variant(colIndex))
.toDispatch();
// Dispatch col = Dispatch.get(cols, "First").toDispatch();
Dispatch.call(cols, "Add", col).toDispatch();
Dispatch.call(cols, "AutoFit");
* 在第1列前增加一列
* @param tableIndex
word文档中的第N张表(从1开始)
public void addFirstTableCol(int tableIndex) {
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
Dispatch col = Dispatch.get(cols, "First").toDispatch();
Dispatch.call(cols, "Add", col).toDispatch();
Dispatch.call(cols, "AutoFit");
* 在最后一列前增加一列
* @param tableIndex
word文档中的第N张表(从1开始)
public void addLastTableCol(int tableIndex) {
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
Dispatch col = Dispatch.get(cols, "Last").toDispatch();
Dispatch.call(cols, "Add", col).toDispatch();
Dispatch.call(cols, "AutoFit");
* 设置当前选定内容的字体
* @param boldSize
* @param italicSize
* @param underLineSize
* @param colorSize
* @param size
* @param name
public void setFont(boolean bold, boolean italic, boolean underLine,
String colorSize, String size, String name) {
Dispatch font = Dispatch.get(selection, "Font").toDispatch();
Dispatch.put(font, "Name", new Variant(name));
Dispatch.put(font, "Bold", new Variant(bold));
Dispatch.put(font, "Italic", new Variant(italic));
Dispatch.put(font, "Underline", new Variant(underLine));
Dispatch.put(font, "Color", colorSize);
Dispatch.put(font, "Size", size);
public void setFontCenter(String name) {
Dispatch font = Dispatch.get(selection, "Font").toDispatch();
Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
.toDispatch();
Dispatch.put(alignment, "Alignment", "3");
Dispatch.call(selection, "TypeText", name);
* 文件保存或另存为
* @param savePath
保存或另存为路径
public void save(String savePath) {
Dispatch.call(doc, "SaveAs", savePath); // 保存
* Dispatch.call(Dispatch.call(word, "WordBasic").getDispatch(),
* "FileSaveAs", savePath);
* 关闭当前word文档
public void closeDocument() {
if (doc != null) {
Dispatch.call(doc, "Save");
Dispatch.call(doc, "Close", new Variant(saveOnExit));
* 关闭全部应用
public void close() {
closeDocument();
if (word != null) {
Dispatch.call(word, "Quit");
selection =
documents =
ComThread.Release();
* 打印当前word文档
public void printFile() {
if (doc != null) {
Dispatch.call(doc, "PrintOut");
* 删除一行
* @param tableIndex
word文档中的第N张表(从1开始)
public void delRow(int tableIndex) {
Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
Object temp1 = Dispatch.get(rows, "Count");
String temp2 = temp1.toString();
int count = Integer.parseInt(temp2);
while (count & 1) {
Dispatch row = Dispatch.get(rows, "Last").toDispatch();
Dispatch.call(row, "Delete");
rows = Dispatch.get(table, "Rows").toDispatch();
temp1 = Dispatch.get(rows, "Count");
temp2 = temp1.toString();
count = Integer.parseInt(temp2);
public void setProp(String sName, String sValue) {
Dispatch props = Dispatch.get(doc, "CustomDocumentProperties")
.toDispatch();
Dispatch prop = Dispatch.call(props, "Item", sName).toDispatch();
String sOldVal = Dispatch.get(prop, "Value").toString();
if (!sOldVal.equals(sValue))
Dispatch.put(prop, "Value", sValue);
* @param nType:
1, 2, 3, 4,
public void addProp(String sName, int nType, String sValue) {
Dispatch props = Dispatch.get(doc, "CustomDocumentProperties")
.toDispatch();
Dispatch prop =
prop = Dispatch.call(props, "Item", sName).toDispatch();
} catch (Exception e) {
if (prop != null)
// 1, 2, 3, 4,
prop = Dispatch.call(props, "Add", sName, false, nType, sValue)
.toDispatch();
Dispatch.put(prop, "Value", sValue);
public String getProp(String sName) {
String sValue =
Dispatch props = Dispatch.get(doc, "CustomDocumentProperties")
.toDispatch();
Dispatch prop = Dispatch.call(props, "Item", sName).toDispatch();
sValue = Dispatch.get(prop, "Value").toString();
@SuppressWarnings("unused")
String sType = Dispatch.get(prop, "Type").toString();
Dispatch prop0 = Dispatch.call(doc, "CustomDocumentProperties",
sName).toDispatch();
sValue = Dispatch.get(prop0, "Value").toString();
} catch (Exception e) {
e.printStackTrace();
public void fack_change() {
Dispatch _sel = Dispatch.call(doc, "Range", 0, 0).toDispatch();
Dispatch.call(_sel, "InsertBefore", "A");
Dispatch.call(_sel, "Select");
Dispatch.call(_sel, "Delete");
FengShen_Xia
浏览: 215803 次
来自: 东方水城
pageoffice 插件 可以实现 office文档的在线操 ...
推荐使用在线免费bug管理系统- bug 禅思:http:// ...
柠檬bug管理系统,一个在线的bug管理系统。www.lemo ...
这个in.read(data);//data是一个byte[] ...
这个不详细啊,我弄了一天了,都没弄出来,总是出错,读信息的时候 ...
(window.slotbydup=window.slotbydup || []).push({
id: '4773203',
container: s,
size: '200,200',
display: 'inlay-fix'

我要回帖

更多关于 java中com组件调用 的文章

 

随机推荐