tomcat迁移websphere注意项目

win7 tomcat6

linux websphere8

 

jeewx项目部署到WebSphere注意事项

 

一、spring

1、spring配置文件

Xml代码   收藏代码
  1. <context-param>  
  2.     <param-name>contextConfigLocation</param-name>  
  3.     <param-value>classpath:spring-*.xml</param-value>  
  4. </context-param>  

 

这种配置websphere不支持,

报错:

org.springframework.beans.factory.NoSuchBeanDefinitionException: No matching bean of type [org.jeecgframework.web.system.service.SystemService] found for dependency

扫描二维码关注公众号,回复: 285434 查看本文章

 

改为

Xml代码   收藏代码
  1. <context-param>  
  2.     <param-name>contextConfigLocation</param-name>  
  3.     <param-value>  
  4.         classpath*:spring-minidao.xml,  
  5.         classpath*:spring-mvc-aop.xml,  
  6.         classpath*:spring-mvc-cgform.xml,  
  7.         classpath*:spring-mvc-context.xml,  
  8.         classpath*:spring-mvc-hibernate.xml,  
  9.         classpath*:spring-mvc-timeTask.xml,  
  10.         classpath*:spring-mvc.xml  
  11.     </param-value>  
  12. </context-param>  

(也可以再xml里import)

 

web.xml中classpath:和classpath*:  有什么区别? 
classpath:只会到你的class路径中查找找文件; 
classpath*:不仅包含class路径,还包括jar文件中(class路径)进行查找.

有时候会用模糊匹配的方式配置多配置文件。
但是如果配置文件是在jar包里,模糊匹配就找不到了。可以用逗号隔开的方式配置多个配置文件。

 

2、请求映射

如果Controller的方法配置的请求映射是这样

@RequestMapping(params = "checkuser")

前台请求是这样

loginController.do?checkuser

报错:

[org.jeecgframework.core.common.exception.MyExceptionHandler]org.springframework.web.servlet.mvc.multiaction.NoSuchRequestHandlingMethodException: No matching handler method found for servlet request: path '/loginController.do', method 'POST', parameters map['randCode' -> array<String>['9n88'], 'password' -> array<String>['123456'], 'userName' -> array<String>['admin'], 'userKey' -> array<String>['D1B5CC2FE46C4CC983C073BCA897935608D926CD32992B5900']]

这种websphere是不支持的,websphere所实现的request支持key-value的形式,估计这种只有key没有value的请求参数,websphere给扔了

可改为这种

@RequestMapping(params = "method=checkuser")

loginController.do?method=checkuser

如果是jeewx(jeecg)项目修改

Ctrl+H

.do\?

替换为

.do?method=

 

@RequestMapping(params = "
@RequestMapping(params="

替换为
@RequestMapping(params = "method=

就可以了。

 

修改一个类可以解决这个问题

ParamsRequestCondition.java,附件提供

 

Spring3系列13-Controller和@RequestMapping
http://www.cnblogs.com/leiOOlei/p/3658076.html

V3.4.2版本打包部署到webSphere7.0服务器发布不成功
http://www.jeecg.org/forum.php?mod=viewthread&tid=1407

 

二、hibernate

hibernate-jpa-2.0-api-1.0.1.Final.jar和
/opt/IBM/WebSphere/AppServer/plugins/javax.j2ee.persistence.jar包冲突

报错:

java.lang.NoSuchMethodError: javax/persistence/OneToMany.orphanRemoval()Z

 

解决

把hibernate-jpa-2.0-api-1.0.1.Final.jar复制到/opt/IBM/WebSphere/AppServer/lib/ext不管用

不得以

把hibernate-jpa-2.0-api-1.0.1.Final.jar复制到/opt/IBM/WebSphere/AppServer/java/jre/lib/ext下

记得把权限调成755

 

在jsp中显示某个类是引用的哪个jar包

Java代码   收藏代码
  1. out.println(javax.persistence.OneToMany.class.getProtectionDomain().getCodeSource().getLocation().getFile());  

  

 

=========================其他高手提供=====================

由于客户们使用的web应用服务器采用的软件不一,Tomcat5、Tomcat6、Websphere5.1、Websphere6.1、Weblogic8等等,而这些软件所采用的标准又不一致,IBM的WAS的JDK采用的自己的,痛苦的是开发人员。

  Tomcat下开发一般很少遇到什么问题,而且真正上线时,客户很少采用tomcat,一般都是WAS,这就需要把程序部署到WAS下。当然,很多不做实事的项目负责人会说这很简单(因为你没做过也不是你去做),而把这个工作放到开发完之后去转,但实际上,还是有很多地方要注意的,最好在开发前弄清楚,部署的时候会减少很多麻烦。

  下面把我的经验列一下:

  1、include的文件要注意: 复制内容到剪贴板

 

以下是引用片段:
<%@ page contentType="text/html; charset=UTF-8"%>

 

  这个在WAS5下不能被多次设置,include文件中如果有要去掉,不过WAS6.0以上就可以了。

  2、web.xml中的serlvet标准

  was5.1只支持2.3标准,was6.0以上才可以支持2.4,如果程序需要跨不同版本的应用服务器,最好采用2.3标准。

  2.3的开头设置如下: 复制内容到剪贴板

 

以下是引用片段:
<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">

 

  <web-app>2.4的如下: 复制内容到剪贴板

 

以下是引用片段:
<?xml version="1.0" encoding="UTF-8"?> 
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4" 
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee   http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

 

  如果你有用spring,那么你肯定比较喜欢如下的配置: 复制内容到剪贴板

 

以下是引用片段:
<listener> 
  <listener-class> 
   org.springframework.web.context.ContextLoaderListener 
  </listener-class> 
</listener> 
<context-param> 
  <param-name>contextConfigLocation</param-name> 
  <param-value> 
   /WEB-INF/classes/applicationContext*.xml 
  </param-value> 
</context-param>

 

  但是很遗憾的说,在2.3的标准下是不能用的,这个实在让我很郁闷,还好spring还提供一个servlet供初始化 复制内容到剪贴板

 

以下是引用片段:
<servlet> 
  <servlet-name>SpringContextServlet</servlet-name> 
  <servlet-class> 
   org.springframework.web.context.ContextLoaderServlet 
  </servlet-class> 
  <load-on-startup>1</load-on-startup>

 

    </servlet>但是这样就不能设置contextConfigLocation参数了(或许有,是我还没找到),这样,如果配置文件有多个,比如:applicationContext-struts.xml,applicationContext-hibernate.xml等等,那么我就需要把他们合成一个文件,放到web-inf\applicationContext.xml,注意,不是web-inf\classes中。

    3.ajax调用的编码问题:

  如果你有用ajax去传一些中文,那么在从服务器端发往客户端时,你可能会用response.setCharacterEncoding("GBK"),来解决乱码问题,但是再次很遗憾的说,这个方法是不被支持的,你可以用:response.setContentType("text/xml;charset=GBK");来替代,我也推荐这种方式。另外,request.setCharacterEncoding方法还是可以用的。

  4.根据我的尝试,最好还是把servlet-api.jar包放进去,此包可以从tomcat里面找到

  5.绝对要使用jdk1.4标准去编译,不是要你使用1.4的jdk,只是把构建的标准改为1.4就可以了。

  如果编译不过去,那你就去老老实实改程序吧,不要去浪费时间想什么外门邪道,比如去更改was的jdk等等疯狂举动。

  所以,jdk5.0及以后版本中新增的一些新玩意,如果你不能确定客户使用的服务器软件支持的话,最好还是不要使用。

  6.不要写文件到服务器,否则在群集部署的时候就会有问题了。

 http://ju.outofmemory.cn/entry/110728

猜你喜欢

转载自hui8080.iteye.com/blog/2376033