【自用】SSM,这就是你想要的条条框框!

SSM整合实例

注意! 这篇文章的整合没有涉及到maven

1、导jar包

2,、表和实体类
实体类:com.bao.entity【Student】

private int stuNo;
private String stuName;
private int stuAge;
//getting and setting

表:【student】

stuNo int;
stuName varchar;
stuAge int;

3、建spring的配置文件【applicationContex.xml】
4、建mybatis映射文件【studentmapper.xml】

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.bao.mapper.StudentMapper.xml">
 	<select id="queryStudentBystuNo" resultType="Student">
 		select * from student where stuNo = #{stuNo}
 	</select>
</mapper>

5、在【web.xml】中配置,将spring纳入web项目(可通过直接提示contextloaderlistener)

<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<listener>	<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

6、回到【applicationContex.xml】配置数据源(数据库信息)和mapper

<!-- 数据源 -->
	<!-- 引入properties便于下面的数据源配置 -->
	<bean id="config" class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
		<property name="locations">
			<array>
				<value>classpath:db.properties</value>
			</array>
		</property>
	</bean>
	<!-- 配置数据库信息(代替了mybaties的配置文件conf.xml)-->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
		<property name="driverClassName" value="${driver}"></property>
		<property name="url" value="${url}"></property>
		<property name="username" value="${username}"></property>
		<property name="password" value="${password}"></property>
	</bean>
	
	<!-- 配置mybatis需要的核心类:sqlsessionfactory -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource"></property>
		<!-- 加载mapper.xml路径 -->
		<property name="mapperLocations" value="com/bao/mapper/*.xml"></property>
	</bean>
	
	<!-- spring整合mybatis:将mybatis的sqlsessionfactory交给spring -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
	<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
	<!-- 将这个包里面的接口产生对应的动态代理对象,对象名就是首字母小写的接口名 -->
	<!-- 相当于StudentMapper studentMapper=session.getMapper(StudentMapper.class) -->
		<property name="basePackage" value="com.bao.mapper"></property>
	</bean>

逻辑:
用spring的方法生成mybatis的核心类sqlsessionfactory
引入上面的数据源,加载mapper.xml
最后将mybatis的sqlsessionfactory交给spring

sm整合完毕(别忘了在mapper.xml中写sql语句和在mapper.java创建接口)

7、在【web.xml】配置springmvc(可通过直接提示dispatherservlet)

<servlet>
		<servlet-name>springDispatcherServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath:applicationContex-controller.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>

	<servlet-mapping>
		<servlet-name>springDispatcherServlet</servlet-name>
		<url-pattern>/</url-pattern><!-- 拦截一切请求 -->
	</servlet-mapping>

并创建【applicationContex-controller.xml】(这是springmvc配置文件)

8、编写applicationContex-controller.xml

<!-- 配置视图解析器 -->
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/views/"></property>
		<property name="suffix" value=".jsp"></property>
	</bean>
	
	<!-- springmvc基础配置 -->
	<mvc:annotation-driven></mvc:annotation-driven>

建com.bao.service【IStudentService】(接口)
建com.bao.impl【StudentServiceImpl】(实现类实现上面的接口)

建com.bao.controller【StudentController】(mvc控制器,所以要加@Controller注解)

在applicationContex-controller.xml添加扫描器扫描所有的控制器

<context:component-scan base-package="com.bao.controller"></context:component-scan>

编写控制器StudentController

@Controller
@RequestMapping("controller")
public class StudentController {
	@RequestMapping("queryStudentByNo")
	public String queryStudentByNo() {
	}
}

创建并写一个前台jsp

<a href="controller/queryStudentByNo/1">查询1号学生</a>

通过ant风格传过来一个"1"的数据
控制器StudentController这样来接收

public class StudentController {
	@RequestMapping("queryStudentByNo{stuno}")
	public String queryStudentByNo(@PathVariable("stuno")int stuNo) {
	}
}

Dao层写sql语句(StudentMapper.xml写语句、StudentMapper.java写接口)

Service调Dao
【IStudentService】

Student quetyStudentBuNo(int stuNo);

并在实现类【StudentServiceImpl】实现(或许不用写接口),引入Dao层的接口

StudentMapper studentmapper;
	@Override
	public Student quetyStudentBuNo(int stuNo) {
		return null;
	}

去springIOC容器为【StudentServiceImpl】注入StudentMapper类
(这是set注入,所以studentmapper要有setting,studentMapper处是com.bao.mapper【StudentMapper.java】的动态代理对象–类名首字母小写)

<bean id="studentService" class="com.bao.impl.StudentServiceImpl">
		<property name="studentmapper" ref="studentMapper"></property>
</bean>

所以【StudentServiceImpl】的studentmapper可以调用Dao的方法了
return studentmapper.queryStudentBystuNo(stuNo);

控制器依赖service(同样在springIOC容器注入,此步骤略)

IStudentService studentService;

现在控制器可以调用下层的方法并用Student接收,student放进map中,map会将这个对象放到request域中,最后跳转到"result"页面

@RequestMapping("queryStudentByNo{stuno}")
	public String queryStudentByNo(@PathVariable("stuno")int stuNo,Map<String,Object> map) {
		Student student=studentService.quetyStudentBuNo(stuNo);
		map.put("student", student);
		return "result";
	}

【result.jsp】

${reqyestScope.student.stuNo}-${reqyestScope.student.stuName}-${reqyestScope.student.stuAge}

测试

错误:com/bao/mapper不存在
Could not resolve resource location pattern [com/bao/mapper/*.xml]: ServletContext resource [/com/bao/mapper/] cannot be resolved to URL because it does not exist
原因springmvc的影响
解决方法:classpath:com/bao/mapper

错误:不能从字符串转到studentmapper类型
Cannot convert value of type ‘java.lang.String’ to required type
‘com.bao.mapper.StudentMapper’ for property ‘studentmapper’: no matching editors or conversion strategy found

原因;
解决方法:依赖注入Dao哪里
value改成ref

成功启动:点击超链接会报500空指针错误
原因:控制器通过注解加入到IOC容器里,又用过配置加入到IOC容器里,矛盾报错
解决:注释掉IOC容器里关于控制器的注入,并在控制器里类里加自动装配@Autowired

@Qualifier(“studentService”)根据名字装配

运行无误

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值