让axis1.4与spring集成,去掉累赘层~

对于axis1.4来说,我们常用wsdd的方式来发布服务。下面先看下我们是如何使用的。

  1. 定义一个服务类

    package com.sunsharing.axistest;
    
    public class HelloWordService {
        public String sayHello(String person){
            return "hello ," + person;
        }
    }
  2. 使用wsdd暴露服务以及方法
    <deployment xmlns="http://xml.apache.org/axis/wsdd/"
    	xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">
    	<handler name="URLMapper"
    		type="java:org.apache.axis.handlers.http.URLMapper" />	
    
    	<service name="helloWordService " provider="java:RPC">
    		<parameter name="className"
    			value="com.sunsharing.axistest.HelloWordService " />
    	</service>
    	<transport name="http">
    		<requestFlow>
    			<handler type="URLMapper" />
    		</requestFlow>
    	</transport>
    </deployment>

这已经把服务暴露出来了。

接下来,妹子可能会问你,能不能从我传入的person找到它存储在数据库的详细信息,多输出点信息呢?于是乎,你又定义了一个spring的service,就简单的jdbcTemplate来查询想满足妹子吧。

@Service
public class SpringHelloWordService {

    @Autowired
    JdbcTemplate jdbcTemplate;

    public String sayHello(String person){
        //这个打印为了看是不是spring托管的service,是的话,jdbcTemplate应该不为空,有注入
        System.out.println(jdbcTemplate);
        return "hello,"+person;
    }
}

继续之前的做法,往wsdd再配置个service

<service name="springHelloWordService" provider="java:RPC">
		<parameter name="className"
			value="com.sunsharing.axistest.SpringHelloWordService" />
	</service>

呵呵,这样做的话,你的jdbcTemplate肯定是空指针!!!,这个className是axis自己new出来的。你还是再想想办法吧。

这时候,你一想,那我就写在之前定义好的HelloWordService,进行调用spring的服务不就好了。修改下HelloWordService。

public class HelloWordService {
    public String sayHello(String person){
        //ServiceLocator是我们系统初始自定义的获取spring bean的辅助类
        SpringHelloWordService service = (SpringHelloWordService)ServiceLocator.getBean("springHelloWordService");
        return service.sayHello(person);
    }
}

好像一切都做完了,妹子的要求也满足了。不过对于喜欢偷懒的程序猿来说,总觉得好累,为什么不直接把spring的service直接暴露出来就好了,还多这么一层,真是累啊~~~

稍微看了下源码,wsdd的方式部署中,有个provider。再看看,就从它入手,定义一个SpringProvider(网上copy的,修改了下getServiceClass)

package com.sunsharing.axistest;

import org.apache.axis.AxisFault;
import org.apache.axis.Handler;
import org.apache.axis.MessageContext;
import org.apache.axis.components.logger.LogFactory;
import org.apache.axis.handlers.soap.SOAPService;
import org.apache.axis.providers.java.RPCProvider;
import org.apache.axis.transport.http.HTTPConstants;
import org.apache.commons.logging.Log;
import org.springframework.beans.factory.config.ConfigurableListableBeanFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.XmlWebApplicationContext;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpServlet;

public class SpringProvider extends RPCProvider {
    protected static Log log =
            LogFactory.getLog(SpringProvider.class.getName());
    public static final String OPTION_BEANNAME = "beanName";

    protected Object makeNewServiceObject(MessageContext msgContext, String clsName) throws Exception {
        String beanName = getStrOption(OPTION_BEANNAME, msgContext.getService());
        return getService(beanName, msgContext);
    }

    protected String getServiceClassNameOptionName() {
        return OPTION_BEANNAME;
    }

    protected Object getService(String beanName, MessageContext context) throws AxisFault {
        ApplicationContext appContext = getAppContext(context);
        if (appContext == null) {
            log.fatal("Spring ApplicationContext is NULL.");
            throw new AxisFault("get Spring ApplicationContext error.");
        }

        Object bean = appContext.getBean(beanName);
        if (bean == null) {
            log.error("bean named:" + beanName + " is NULL");
            throw new AxisFault("bean named:" + beanName + " is NULL");
        }
        return bean;
    }

    protected String getStrOption(String optionName, Handler service) {
        String value = null;
        if (service != null)
            value = (String) service.getOption(optionName);
        if (value == null)
            value = (String) getOption(optionName);
        return value;
    }

    protected Class getServiceClass(String beanName, SOAPService service, MessageContext msgContext) throws AxisFault {
//        ConfigurableListableBeanFactory beanFactory = getBeanFactory(msgContext);
//        if (beanFactory == null) {
//            log.error("BeanFactory is NULL");
//            throw new AxisFault("BeanFactory is NULL");
//        }
//        Object bean = beanFactory.getBeanDefinition(beanName);
//        return bean.getClass();
        Object bean = getService(beanName,msgContext);
        return bean.getClass();
    }

    protected XmlWebApplicationContext getAppContext(MessageContext msgContext) {
        HttpServlet servlet = (HttpServlet) msgContext.getProperty(HTTPConstants.MC_HTTP_SERVLET);
        ServletContext servletContext = servlet.getServletContext();
        XmlWebApplicationContext appContext = (XmlWebApplicationContext) servletContext
                .getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE);
        return appContext;
    }

    private final ConfigurableListableBeanFactory getBeanFactory(MessageContext msgContext) {
        XmlWebApplicationContext appContext = getAppContext(msgContext);
        return appContext.getBeanFactory();
    }
}

再定义一个wsdd的provider,WSDDJavaSpringProvider

public class WSDDJavaSpringProvider extends WSDDProvider {

    public static final String PROVIDER_RPC = "SPRING";
    public static final QName QNAME = new QName(WSDDConstants.URI_WSDD_JAVA, PROVIDER_RPC);
    /**
     * @param service
     * @param registry XXX
     * @return XXX
     * @throws Exception XXX
     */
    @Override
    public Handler newProviderInstance(WSDDService service, EngineConfiguration registry) throws Exception {
        return new SpringProvider();
    }

    @Override
    public String getName() {
        return PROVIDER_RPC;
    }
}

wsdd再配置个service,请注意allowedMethods,可能你不想把spring service的所有方法暴露,那么可以在此配置声明要暴露出来的方法,用英文逗号隔开即可。

<service name="springHelloWordService" provider="java:SPRING">
		<parameter name="beanName"
			value="springHelloWordService" />
		<parameter name="allowedMethods" value="sayHello" />
	</service>

还缺少一个重要的事情,就是注册provider,好的,就这么干,在系统启动时候加上注册(注意注册的方法一定要在AxisServlet初始化之前执行,load-on-startup调大点,下面是web.xml对axisServlet的配置和注册的语句)

<servlet>
        <servlet-name>AxisServlet</servlet-name>
        <servlet-class>org.apache.axis.transport.http.AxisServlet</servlet-class>
        <load-on-startup>6</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>AxisServlet</servlet-name>
        <url-pattern>/services/*</url-pattern>
    </servlet-mapping>
WSDDProvider.registerProvider(WSDDJavaSpringProvider.QNAME,new WSDDJavaSpringProvider());

启动~~~访问看看吧~

让axis1.4与spring集成,去掉累赘层~,布布扣,bubuko.com

时间: 2024-11-05 06:27:38

让axis1.4与spring集成,去掉累赘层~的相关文章

RabbitMQ安装和使用(和Spring集成)

一.安装Rabbit MQ Rabbit MQ 是建立在强大的Erlang OTP平台上,因此安装Rabbit MQ的前提是安装Erlang.通过下面两个连接下载安装3.2.3 版本: 下载并安装 Eralng OTP For Windows (vR16B03) 运行安装 Rabbit MQ Server Windows Installer (v3.2.3) 具体操作步骤参考:在 Windows 上安装Rabbit MQ 指南 本人遇到的问题 当安装RabbitMQ后,使用rabbitmqctl

spring集成quartz

spring集成quartz 注意:出现异常"Caused by: java.lang.IncompatibleClassChangeError: class org.springframework.scheduling.quartz.CronTriggerBean has interface org.quartz.CronTrigger as super class" Spring3.0不支持Quartz2.0,因为org.quartz.CronTrigger在2.0从class变成

Hessian入门(包括与Spring集成)

A.纯Hessian接口开发步骤 Hessian-JAVA服务器端必须具备以下几点: * 1.包含Hessian的jar包(hessian-4.0.37.jar) * 2.设计一个接口,用来给客户端调用(IHessian.java) * 3.实现该接口的功能(IHessianImpl.java) * 4.配置web.xml,配好相应的Servlet(web.xml) * 5.对象必须实现Serializable接口(Foo.java) Hessian-JAVA服务端代码预览图: 1.包含Hess

Struts2+Spring集成合并

前边单独总结了Struts2,Spring和Ibaits框架了,那么怎么结合使用呢?这次先来看一下Sturts2和Spring的集成合并.其实挺简单的,就是导入各自的jar包以及连接彼此的jar包,分好彼此的工作就可以了. 好看一下Struts2+Spring的集成方案!  Struts2和Spring集成有两种方案,是根据action的创建来划分的!  方案一,Struts2负责流程,Spring负责对象的创建:Action由Struts2框架负责创建:Service由Spring框架负责创建

Java Persistence with MyBatis 3(中文版) 第五章 与Spring集成

MyBatis-Spring是MyBatis框架的子模块,用来提供与当前流行的依赖注入框架Spring的无缝集成. Spring框架是一个基于依赖注入(Dependency Injection)和面向切面编程(Aspect Oriented Programming,AOP)的Java框架,鼓励使用基于POJO的编程模型.另外,Spring提供了声明式和编程式的事务管理能力,可以很大程度上简化应用程序的数据访问层(data access layer)的实现.在本章中,我们将看到在基于Spring的

spring集成Log4j以及log4j配置简要说明

Spring集成: web.xml中配置log4j <context-param> <param-name>log4jConfigLocation</param-name> <param-value>WEB-INF/log4j.xml</param-value></context-param> <!-- 加载Spring框架中的log4j监听器Log4jConfigListener --><listener>

rabbitMQ第五篇:Spring集成RabbitMQ

前面几篇讲解了如何使用rabbitMq,这一篇主要讲解spring集成rabbitmq. 首先引入配置文件org.springframework.amqp,如下 <dependency> <groupId>org.springframework.amqp</groupId> <artifactId>spring-rabbit</artifactId> <version>1.6.0.RELEASE</version> <

Spring 集成 RMI

Maven <dependency> <groupId>org.springframework</groupId> <artifactId>spring-remoting</artifactId> </dependency> 服务端 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.spri

activiti搭建(二)与Spring集成

转载请注明源地址:http://www.cnblogs.com/lighten/p/5876773.html 本文主要讲解如何将Activiti和Spring框架集成,再过一段时间将会将一个基础的demo放在github上,地址将会在activiti系列导读文章中给出,如果未给出,则是因为没有构建完成(学习中,更新较慢).按照搭建篇章的顺序,也能搭建起来. 上一章将了数据库的初始化,继续那章建立的maven项目.Activiti与Spring集成需要相应的jar包,下面将补充其他maven依赖: