前提:
这个月的突然一天,有个项目对接需要使用axis2发布的接口,这下难倒我了,毕竟之前我是连webservice接口都不知怎么发布的。后来从HelloWorld开始发布了第一个接口--sayHi();到这一步的时候都是很顺利的,唯独和axis2整合的时候,出现问题了,spring的dao层在axis2发布后的接口里,一直为null,貌似是spring一直没有被初始化,这期间我测试过按照正常流程来执行一个请求,是正确的,唯独和axis2整合后就不行了,在这测试的时间内,很痛苦,很痛苦,所有能想到的方法都一一试过了,包括强制获取dao和单例模式,然而然并卵。于是只好退而求其次,先用spring+mybatis+cxf发布一个可以使用的接口作为代理,再用axis2框子单独发布一个调用代理的方法来达到项目对接。下面开始介绍spring+mybatis+cxf:
一,创建工程目录:

首先,我们建一个实体类Person.java
package com.srit.user.model;public class Person {private String id; private String name; private int age; private String birthday; private double hight; public String getId() { return id;
} public void setId(String id) { this.id = id;
} public String getName() { return name;
} public void setName(String name) { this.name = name;
} public int getAge() { return age;
} public void setAge(int age) { this.age = age;
} public String getBirthday() { return birthday;
} public void setBirthday(String birthday) { this.birthday = birthday;
} public double getHight() { return hight;
} public void setHight(double hight) { this.hight = hight;
}
}
接着我们先来写dao里的PersonDao.java,它是个接口interface ,主要是执行简单的增,删,改,查
package com.srit.user.dao;import java.util.List;import javax.jws.WebMethod;import javax.jws.WebService;import com.srit.user.model.Person;public interface PersonDao {public void insertPerson(Person person); public void updatePerson(Person person); public List<Person> findPerson(String name); public void deletePerson(String id);
}
下面是dao层的实现类PersonDaoImpl.java
1 package com.srit.user.dao.impl; 2 3 import java.util.List; 4 5 import javax.annotation.Resource; 6 7 import org.mybatis.spring.SqlSessionTemplate; 8 import org.mybatis.spring.support.SqlSessionDaoSupport; 9 10 import com.srit.user.dao.PersonDao;11 import com.srit.user.model.Person;12 13 public class PersonDaoImpl extends SqlSessionDaoSupport implements PersonDao {14 15 private SqlSessionTemplate sqlSessionTemplate;
16 17 public SqlSessionTemplate getSqlSessionTemplate() {
18 return sqlSessionTemplate;
19 }
20 21 @Resource(name="sqlSessionTemplate")
22 public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) {
23 this.sqlSessionTemplate = sqlSessionTemplate;
24 }
25 26 public void deletePerson(String id) {
27 getSqlSession().delete("com.srit.usr.dao.PersonDao.deletePerson", id);
28 }
29 30 public List<Person> findPerson(String name) {
31 return getSqlSession().selectList("com.srit.user.dao.PersonDao.findPerson", name);
32 }
33 34 public void insertPerson(Person person) {
35 getSqlSession().insert("com.srit.user.dao.PersonDao.insertPerson", person);
36 }
37 38 public void updatePerson(Person person) {
39 getSqlSession().update("com.srit.user.dao.PersonDao.updatePerson", person);
40 }
41 42 43 }
接着是service层PersonService.java
package com.srit.user.service;import java.util.List;import com.srit.user.model.Person;public interface PersonService {public void insertPerson(Person person); public void updatePerson(Person person); public List<Person> findPerson(String name); public void deletePerson(String id);
}
紧接着便是service层的实现类了PersonServiceImpl.java
package com.srit.user.service.impl;import java.util.List;import javax.annotation.Resource;import org.springframework.stereotype.Service;import org.springframework.transaction.annotation.Transactional;import org.springframework.web.context.ContextLoader;import org.springframework.web.context.WebApplicationContext;import com.srit.user.dao.PersonDao;import com.srit.user.model.Person;import com.srit.user.service.PersonService;
@Service
@Transactional
public class PersonServiceImpl implements PersonService {
@Resource private PersonDao personDao;
public PersonDao getPersonDao() { return personDao;
} public void setPersonDao(PersonDao personDao) { this.personDao = personDao;
// WebApplicationContext context=ContextLoader.getCurrentWebApplicationContext();// personDao =(PersonDao)context.getBean("personDao"); }
public void deletePerson(String id) {
personDao.deletePerson(id);
}
public List<Person> findPerson(String name) { return personDao.findPerson(name);
}
public void insertPerson(Person person) {
personDao.insertPerson(person);
}
public void updatePerson(Person person) {
personDao.updatePerson(person);
}
}
然后就是我们要发布的service接口了MyWebservice.java
1 package com.srit.user.webservice;2 3 import com.srit.user.model.Person;4 5 public interface MyWebservice {6 public String czDate(Person person);
7 }
当然必须有它的实现类MyWebserviceImpl.java
下班了 。。。下次接着写
编辑推荐:
- myeclipse上spring+mybatis+axis2发布webservice接口的问题02-28
- Host '127.0.0.1' is not allowed to connect to this MySQL server02-28
- MySQL常见的数据类型详细介绍02-28
- 深入了解安装和配置mysql 8.0.17的方法02-28
- pt-query-digest(percona toolkit)小解02-28
- MySQ中基本语法与语句的介绍02-28
- 关于pt-heartbeat(percona toolkit)的实例代码02-28
- CentOS6.5 yum安装mysql5.7.18的实例教程02-28
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- myeclipse上spring+mybatis+axis2发布webservice接口的问题
- MySQL常见的数据类型详细介绍
MySQL常见的数据类型详细介绍
26-02-28 - 深入了解安装和配置mysql 8.0.17的方法
深入了解安装和配置mysql 8.0.17的方法
26-02-28 - MySQ中基本语法与语句的介绍
MySQ中基本语法与语句的介绍
26-02-28 - MySQL基础内容
MySQL基础内容
26-02-28 - 常用的sql语句
常用的sql语句
26-02-28 - MySQL如何开启远程连接?
MySQL如何开启远程连接?
26-02-28 - mysqlslap的使用方法介绍
mysqlslap的使用方法介绍
26-02-28 - Mysql学习笔记
Mysql学习笔记
26-02-28 - MySQL中基于mysqldump和二进制日志log-bin进行逻辑备份以及基于时间点的还原
