spring入门

spring 的介绍

什么是spring,它能够做什么?

Spring是一个开源框架,它由Rod Johnson创建。它是为了解决企业应用开发的复杂性而创建的。
Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。

目的:解决企业应用开发的复杂性
功能:使用基本的JavaBean代替EJB,并提供了更多的企业应用功能
范围:任何Java应用
简单来说,Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。

什么是控制反转(或依赖注入)?

控制反转(IoC=Inversion of Control)IoC,用白话来讲,就是由容器控制程序之间的(依赖)关系,而非传统实现中,由程序代码直接操控。这也就是所谓“控制反转”的概念所在:(依赖)控制权由应用中转到了外部容器,控制权的转移,是所谓反转。IoC还有一个另外的名字:“依赖注(DI=Dependency Injection)” ,即由容器动态的将某种依赖关系注入到组件之中.

spring管理Bean的方式

首先我们做一下准备工作,导入spring依赖 。这里的spring版本是

<!-- 2、导入spring依赖 -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-context</artifactId>
			<version>${spring.version}</version>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-aspects</artifactId>
			<version>${spring.version}</version>
		</dependency>

spring管理上下文,里面的东西是写好的-------spring_context_xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xmlns:context="http://www.springframework.org/schema/context"
	default-autowire="byName"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd">
	<bean id="userBiz" class="com.hu.ioc.biz.impl.UserBizImpl2"></bean>
	<bean id="userBiz1" class="com.hu.ioc.biz.impl.UserBizImpl1"></bean>
	<bean id="userAction" class="com.hu.ioc.web.UserAction">
		<!-- <property name="uid" value="22"></property>-->
		<!--<property name="uname" value="zs"></property> -->
		<!-- <property name="userBiz" ref="userBiz"></property> -->
		<constructor-arg name="uid" value="32"></constructor-arg>
		<constructor-arg name="uname" value="zs"></constructor-arg>
		<property name="hobby">
			<list>
				<value>篮球</value>
				<value>PRP</value>
				<value>TKD</value>
			</list>
		</property>
	
	</bean>

</beans>

UserSerlvet

package com.hu.ioc.web;

import java.util.ArrayList;
import java.util.List;

import com.hu.ioc.biz.UserBiz;
import com.hu.ioc.biz.impl.UserBizImpl1;

/**
 * 弊端:
 * 	当需求变化非常快的时候,不便于维护,因为维护的权利是属于程序员的
 * 
 * 	spring 的IOC就是解决这一问题的
 * 	将维护代码的权利由程序员转交给spring容器来完成
 * 
 * 1.spring管理Bean的方式
 * 	set注入
 * 		基本数据类型
 * 		引用数据类型
 * 	构造注入
 * 	自动装配
 * @author huguiyun
 *
 */
public class UserAction {
	private UserBiz userBiz ;//自动匹配用
	private int uid;
	private String uname;
	private List<String> hobby = new ArrayList<>();
		
	public UserBiz getUserBiz() {
		return userBiz;
	}

	public void setUserBiz(UserBiz userBiz) {
		this.userBiz = userBiz;
	}

	public UserAction() {
		super();
	}

	public UserAction(int uid, String uname) {
		super();
		this.uid = uid;
		this.uname = uname;
		
	}

	public int getUid() {
		return uid;
	}

	public void setUid(int uid) {
		this.uid = uid;
	}

	public String getUname() {
		return uname;
	}

	public void setUname(String uname) {
		this.uname = uname;
	}

	public List<String> getHobby() {
		return hobby;
	}

	public void setHobby(List<String> hobby) {
		this.hobby = hobby;
	}

	/**
	 * set注入
	 */
	public void test1() {
		System.out.println("uid:"+this.uid);
		System.out.println("uname:"+this.uname);
		System.out.println("hobby:"+this.hobby);
	}
	
	/**
	 * 构造注入
	 */
	public void test2() {
		
	}
	
	/**
	 * 引用数据类型
	 */
	public void test3() {
		userBiz.read();		
	}
}

两个测试方法,他们两个都实现了User Biz接口

public class UserBizImpl1 implements UserBiz {
	@Override
	public void read() {
		System.out.println("金刚!大猩猩!!!");
	}
}
public class UserBizImpl2 implements UserBiz {
	@Override
	public void read() {
		System.out.println("太白!李太白!!!");
	}
}

UserBiz接口

public interface UserBiz {
	public void read();

}

set注入

在UserAction中写入,提供set/get方法。。

	private int uid;
	private String uname;
	private List<String> hobby = new ArrayList<>();
	
	public int getUid() {
		return uid;
	}

	public void setUid(int uid) {
		this.uid = uid;
	}

	public String getUname() {
		return uname;
	}

	public void setUname(String uname) {
		this.uname = uname;
	}

	public List<String> getHobby() {
		return hobby;
	}

	public void setHobby(List<String> hobby) {
		this.hobby = hobby;
	}
	

在spring_context_xml写入。给user赋值

 <property name="uid" value="22"></property>
<property name="uname" value="zs"></property>
<property name="hobby">
	<list>
		<value>篮球</value>
		<value>PRP</value>
		<value>TKD</value>
	</list>
</property>

构造注入

需要在Userserlvet里面提供构造器
然后在spring_context_xml里写入下面代码。给user赋值

<constructor-arg name="uid" value="32"></constructor-arg>
<constructor-arg name="uname" value="zs"></constructor-arg>

自动匹配

在spring_context_xml里加入default-autowire=“byName”,
在这里插入图片描述
userBiz 这个是要与user里的 private UserBiz userBiz ;保持一致。class里放的是方法实现方法的全路径名

<bean id="userBiz" class="com.hu.ioc.biz.impl.UserBizImpl2"></bean>
<bean id="userBiz1" class="com.hu.ioc.biz.impl.UserBizImpl1"></bean>

如何将spring的上下文交给tomcat上下文进行管理

首先spring上下文为什么交给tomcat?

分析:目前工程中的所有JavaBean都交给了spring进行管理,那么游览器发送请求,请求是tomcat,
由tomcat来处理请求,tomcat处理请求一般来说都要访问数据库,数据库是由Dao层访问的,dao层的实体类又是交给了spring的上下文,那么就意味着,tomcat要处理请求,必须拿到spring的上下文,才能够拿到 Dao层的JavaBean

代码实现

SpingLoadListener 主体类,

package com.hu.ioc.test;

import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.annotation.WebListener;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

/**
 * 2.如何将spring的上下文交给tomcat上下文进行管理
 * 	首先spring上下文为什么交给tomcat?
 * 	分析:目前工程中的所有JavaBean都交给了spring进行管理,那么游览器发送请求,请求是tomcat,
 * 	由tomcat来处理请求,tomcat处理请求一般来说都要访问数据库,数据库是由Dao层访问的,dao层的实体类
 * 	又是交给了spring的上下文,那么就意味着,tomcat要处理请求,必须拿到spring的上下文,才能够拿到
 * 	Dao层的JavaBean
 * @author huguiyun
 *
 */
@WebListener
public class SpingLoadListener implements ServletContextListener {
	
	private String springXmlLocation="";
	
	@Override
	public void contextInitialized(ServletContextEvent sce) {
		System.out.println("监听了tomcat的启动!!!");
		
		//获取tomcat上下文
		ServletContext servletContext = sce.getServletContext();
		//获取spring-other.xml
		springXmlLocation = servletContext.getInitParameter("springXmlLocation");
		//如果是null的,就设置默认的
		if(null== springXmlLocation || "".equals(springXmlLocation)) {
			springXmlLocation = "/spring-other.xml";
		}
		System.out.println("springXmlLocation:"+springXmlLocation);
		//spring的上下文
		ApplicationContext context = new ClassPathXmlApplicationContext(springXmlLocation);
		//将spring上下文 转为 tomcat的上下文
		servletContext.setAttribute("SPRING-CONTEXT_KEY", context);
		
	}
}

web.xml 加入

<context-param>
		<param-name>springXmlLocation</param-name>
		<param-value>/spring-other.xml</param-value>
</context-param>

测试代码

package com.hu.ioc.test;

import java.io.IOException;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.context.ApplicationContext;

import com.hu.ioc.web.UserAction;

@WebServlet("/user")
public class UserSerlvet extends HttpServlet {

	private static final long serialVersionUID = 8506874277797661149L;
	
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		doPost(req, resp);
	}
	
	
	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		//获取上下文
		ServletContext servletContext = req.getServletContext();
		//拿到里面的值
		ApplicationContext context = (ApplicationContext)servletContext.getAttribute("SPRING-CONTEXT_KEY");
		UserAction bean = (UserAction)context.getBean("userAction");
		//调用方法
		bean.test3();
	}
}

如果测试成功就说明成功了
在这里插入图片描述

小编刚刚出道,有什么写的不对的地方就指出来,大家一起进步。有喜欢的就点亮一下旁边的小红心吧,给小编的一个支持。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值