揉杂在一起的问题


近期遇到的问题。简要记之,谨作备忘。


关键词:Delphi7、Eclipse/MyEclipse、AXIS2、Web Service、ocx、XML、Base64、多页Tiff、ImageEn等

一、Web服务器配置AXIS2服务

http://ws.apache.org/axis2/ 下载 axis2-1.4.1-war.zip。

或在http://apache.justdn.org/ws/axis2/下载。

解压后可以得到axis2.war。

把axis2.war以Web应用方式部署到Web服务器,访问http://127.0.0.1:8888/axis2,如出现AXIS的欢迎页面,则说明配置成功。

当然axis2.war可以重新命名为其他的xxxx.war。


二、AXIS2在Eclipse IDE中的配置

需要下载Axis Eclipse plug-in,分别是AXIS2的代码生成工具和打包工具:

axis2-eclipse-codegen-wizard.zip

axis2-eclipse-service-archiver-wizard.zip


下载地址:http://apache.justdn.org/ws/axis2/tools/1_4_1/

把下载的AXIS2的两个plug-in解压缩后放到Eclipse安装目录下的plug-in子目录。


Eclipse启动后便可在“File->New->Other”中看到这些Wizards工具。


AXIS2在Eclipse中开发Web Service的过程如下:

1. 新建Project

2. 新建Web Service的WSDL文件。

3. 使用Axis2 Code Generator向导,分两次从WSDL建立Web Service的Server端和Client端。

4. 使用Axis2 Services Archive向导,把Web Service服务端打包成aar。

5. 发布aar,把aar文件Copy到Axis2应用的/WEB-INF/services/目录下面。

访问对应的web应用可以得到该Web Service的WSDL文档。


三、AXIS2在MyEclipse6.5报错的问题

Axis2 Code Generator向导生成代码后,在Finish 时会产生Exception:

An error ocurred while completing process
-java.lang.reflect.InvocationTargetException

问题在于 Code Generator plugin 内缺少了两个包:

backport-util-concurrent-3.1.jar 包
geronimo-stax-api_1.0_spec-1.0.1.jar 包

解决方法:

1. 关闭 Eclipse

2. copy %AXIS2_HOME%\lib\下的backport-util-concurrent-3.1.jar 和 backport-util-concurrent-3.1.jar

粘贴到 MyEclipse 6.5\eclipse\plugins\Axis2_Codegen_Wizard_1.3.0\lib 文件夹下。

3. 注册此jar 包:

编辑MyEclipse 6.5\eclipse\plugins\Axis2_Codegen_Wizard_1.3.0\plugin.xml文件。

在 <runtime>內加入如下内容:

<library name="lib/geronimo-stax-api_1.0_spec-1.0.1.jar">
<export name="*"/>
</library>
<library name="lib/backport-util-concurrent-3.1.jar">
<export name="*"/>
</library>

4. 保存plugin.xml文件,重新启动Eclipse即可。

四、Delphi7客户端调用AXIS2服务的问题

因为Delphi7发布的时候,AXIS2还没有出生,Delphi7不兼容AXIS2的WSDL文档。

在默认情况下,D7导入AXIS2的WSDL后,生成的pas文件中没有对应的Web Service接口方法。

所以默认情况下无法使用D7编写的客户端调用AXIS2的Web Service服务。

为此,花费不少时间研究,几经磨难才搞定。 ^_^


五、Delphi7+AXIS2 Web Service服务传送文件

这个问题不大。主要还是BASE64的应用。其核心跟D7调用JBuilder9/10带的AXIS一样。

只是多了request和response这样请求和返回的参数,更具BS程序特性。


六、多页tif文件的处理

多页tif的拆分和合成,其处理速度是最头疼事情。

JAVA处理多页tif:JAI组件。可以把多页tif拆分成jpeg,然后再合并成多页tif,这样处理速度会稍好一些。

Delphi7处理多页tif:ImageEn控件,功能强大。


七、使用JDOM生成格式化XML文件

用dom4j生成的XML文件不易做换行缩进等美化格式的操作。

使用jdom可以轻松搞定一个换行缩进格式美化且易读且良构的XML文件。

主要语句参考:

Element root = new Element("aRoot");
Document document = new Document(root);
......
try{
Format format = Format.getCompactFormat();
format.setEncoding("UTF-8"); //设置文件编码格式UTF-8
format.setIndent(" "); //设置缩进
XMLOutputter XMLOut = new XMLOutputter(format);
XMLOut.output(document, new FileOutputStream(saveFilePath));
} catch (Exception e) {
e.printStackTrace();
}


八、Delphi7生成发布ocx的问题

D7中新建Active Form,在Type Library中对接口新增一个Property属性,生成对应的set和get方法。

html页面嵌入ActiveX后可以向ocx传递参数。

主要在ActiveForm的set方法中得到传入的参数。

ocx对象实例化时,其参数的执行顺序和建立顺序一致。使用前记得先注册ocx。

另外,发布ocx时,Project--Web Deploy等按钮可能是灰色。可能D7是D版或Bug。

针对这个问题,具体的做法是再New一个Active Form,然后关掉这个新的Active Form,这时候就可以使用Web Deploy了。


九、D7中ImageEn控件版本冲突问题

如下4个bpl可能会与其他控件的bpl冲突:

PKIECtrl7.bpl、PKIEDB7.bpl、DPKIECTRL7.bpl、DPKIEDB7.bpl

可把这些bpl放置到\WINDOWS\system32\目录下。

十、在IE7中刷新验证码图片

点击验证码图片域时,把其中的验证码图片刷新一下。在IE6下没有问题。

因图片指向引用地址未变,IE7浏览器未能自动刷新图片。

如下,在地址中增加一个Math取得随机数的方法,即可解决IE7中刷新验证码图片的问题。

<script>
function reflush()
{
document.getElementById('ValidateImg').src="/servlet/ValidateNum?"+Math.random();
}
</script>


十一、Ext.Panel.load()的回调callback()方法

aPanel.load({url: 'test.jsp',
scripts: true,
nocache: true,
discardUrl: false,
timeout: 600000, //10min
callback:function(el, success, response) {
if (!success ) {
var obj = Ext.util.JSON.decode(response.responseText);
alert(obj.msg);
}
}
});

当response返回FAILED时,回调触发执行:

response.setStatus(HttpServletResponse.SC_EXPECTATION_FAILED);//设置失败


十二、动态设置Ext.form.TextField的emptyText属性

aField.setRawValue('请输入查询条件');
aField.emptyText = '请输入查询条件';
aField.applyEmptyText();

十三、mms协议的端口

使用Windows Media Service发布点播服务,对外映射外网IP时,需开放防火墙的554、1755端口和对应的路由器的映射端口。


十四、Web应用绝对路径

//如果Web应用的绝对路径中包含中文或空格,则需要处理一下
String realPath = (Thread.currentThread().getContextClassLoader().getResource("")).getPath();
try {
realPath = URLDecoder.decode(realPath,"UTF-8");
} catch (UnsupportedEncodingException e) {
System.out.println(this.getClass().getName()+" throw Exception: "+e.toString());
}
realPath = realPath.substring(1,realPath.length());


十五、连接SQLServer2005的问题

一直用的SQLServer2000,更换到SQLServer2005时,后台报错:

------------

[Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确。

------------

上网搜到原因,连接SQLServer2005需替换微软新的数据库驱动程序。

于是下载了sqljdbc.jar。一试果然好使,同时也支持SQLServer2000。

以后可以不用那3个jar驱动了。


数据库驱动名称和数据库链接写法举例:

SQLServer 2000数据库驱动的写法:

driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"
url="jdbc:microsoft:sqlserver://192.168.100.100:1433;dataBaseName=testdb"


SQLServer 2005数据库驱动的写法:

driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://192.168.100.100:1433;DatabaseName=testdb"

注意两者的差异。

By JRQ
2009/06/12 于南昌

你可能感兴趣的:(eclipse,应用服务器,Web,MyEclipse,ext)