基于XML管理bean(2.0)

四,依赖注入之构造器注入

①在Student类中添加有参构造

public Student(Integer id, String name, Integer age, String sex) { 
this.id = id; 
this.name = name; 
this.age = age; 
this.sex = sex; 
}

 ②配置bean

<bean id="studentTwo" class="com.atguigu.spring.bean.Student"> 
<constructor-arg value="1002"></constructor-arg> 
<constructor-arg value="李四"></constructor-arg> 
<constructor-arg value="33"></constructor-arg> 
<constructor-arg value="女"></constructor-arg> 
</bean>
注意:
constructor-arg 标签还有两个属性可以进一步描述构造器参数:
index 属性:指定参数所在位置的索引(从 0 开始)
name 属性:指定参数名
(3)测试
@Test 
public void testDIBySet(){ 
ApplicationContext ac = new ClassPathXmlApplicationContext("spring-di.xml"); 
Student studentOne = ac.getBean("studentTwo", Student.class); 
System.out.println(studentOne); 
} 

五,为类类型属性赋值

①创建班级类 Clazz
public class Clazz { 
private Integer clazzId; 
private String clazzName; 
public Integer getClazzId() { 
return clazzId; 
} 
public void setClazzId(Integer clazzId) { 
this.clazzId = clazzId; 
} 
public String getClazzName() { 
return clazzName; 
} 
public void setClazzName(String clazzName) { 
this.clazzName = clazzName; 
} 
@Override 
public String toString() { 
return "Clazz{" + 
"clazzId=" + clazzId + 
", clazzName='" + clazzName + '\'' + 
'}'; 
} 
public Clazz() { 
} 
public Clazz(Integer clazzId, String clazzName) { 
this.clazzId = clazzId; 
this.clazzName = clazzName; 
} 
}
②修改 Student
Student 类中添加以下代码:
private Clazz clazz; 
public Clazz getClazz() { 
return clazz; 
} 
public void setClazz(Clazz clazz) { 
this.clazz = clazz; 
}

③方式一:引用外部已声明的 bean
配置 Clazz 类型的 bean
<bean id="clazzOne" class="com.atguigu.spring.bean.Clazz"> 
<property name="clazzId" value="1111"></property> 
<property name="clazzName" value="财源滚滚班"></property> 
</bean> 
Student 中的 clazz 属性赋值:
<bean id="studentFour" class="com.atguigu.spring.bean.Student"> 
<property name="id" value="1004"></property> 
<property name="name" value="赵六"></property> 
<property name="age" value="26"></property> 
<property name="sex" value="女"></property> 
<!-- ref属性:引用IOC容器中某个bean的id,将所对应的bean为属性赋值 --> 
<property name="clazz" ref="clazzOne"></property> 
</bean> 

④方式二:内部 bean
<bean id="studentFour" class="com.atguigu.spring.bean.Student"> 
<property name="id" value="1004"></property> 
<property name="name" value="赵六"></property> 
<property name="age" value="26"></property> 
<property name="sex" value="女"></property> 
<property name="clazz"> 
<!-- 在一个bean中再声明一个bean就是内部bean --> 
<!-- 内部bean只能用于给属性赋值,不能在外部通过IOC容器获取,因此可以省略id属性 --> 
<bean id="clazzInner" class="com.atguigu.spring.bean.Clazz"> 
<property name="clazzId" value="2222"></property> 
<property name="clazzName" value="远大前程班"></property> 
</bean> 
</property> 
</bean> 
③方式三:级联属性赋值
<bean id="studentFour" class="com.atguigu.spring.bean.Student"> 
<property name="id" value="1004"></property> 
<property name="name" value="赵六"></property> 
<property name="age" value="26"></property> 
<property name="sex" value="女"></property> 
<!-- 一定先引用某个bean为属性赋值,才可以使用级联方式更新属性 --> 
<property name="clazz" ref="clazzOne"></property> 
<property name="clazz.clazzId" value="3333"></property> 
<property name="clazz.clazzName" value="最强王者班"></property> 
</bean>

六,为数组类型属性赋值

①修改Student

private String[] hobbies; 
public String[] getHobbies() { 
return hobbies; 
} 
public void setHobbies(String[] hobbies) { 
this.hobbies = hobbies; 
} 
②配置 bean
<bean id="studentFour" class="com.atguigu.spring.bean.Student"> 
<property name="id" value="1004"></property> 
<property name="name" value="赵六"></property> 
<property name="age" value="26"></property> 
<property name="sex" value="女"></property> 
<!-- ref属性:引用IOC容器中某个bean的id,将所对应的bean为属性赋值 --> 
<property name="clazz" ref="clazzOne"></property> 
<property name="hobbies"> 
<array> 
<value>抽烟</value> 
<value>喝酒</value> 
<value>烫头</value> 
</array> 
</property> 
</bean> 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是基于SSM框架的外卖后台管理系统的搭建步骤: 1.环境准备 - JDK 1.8+ - MySQL 5.6+ - Maven 3.0+ - Tomcat 7+ 2.创建项目 在Eclipse中创建一个Maven项目,选择Web应用类型,然后勾选上Create a simple project(不需要生成web.xml文件)。 3.添加依赖 在pom.xml文件中添加以下依赖: ``` <!-- Spring --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.3.10.RELEASE</version> </dependency> <!-- Spring MVC --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.3.10.RELEASE</version> </dependency> <!-- MyBatis --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.1</version> </dependency> <!-- MySQL --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.47</version> </dependency> <!-- JSTL --> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- Servlet API --> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> <!-- JSP API --> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.0</version> <scope>provided</scope> </dependency> ``` 4.配置数据库 在src/main/resources目录下创建一个名为jdbc.properties的文件,用于存储数据库连接信息: ``` jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/food_delivery?useUnicode=true&characterEncoding=utf8 jdbc.username=root jdbc.password=123456 ``` 其中jdbc.url的连接地址需要根据自己的数据库信息进行修改。 5.配置Spring 在src/main/resources目录下创建一个名为applicationContext.xml的文件,用于配置Spring的相关信息: ``` <!-- 数据源配置 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </bean> <!-- MyBatis配置 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="mapperLocations" value="classpath*:com/xxx/mapper/*.xml" /> </bean> <!-- 扫描Mapper接口 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.xxx.mapper" /> </bean> ``` 6.配置Spring MVC 在src/main/resources目录下创建一个名为springmvc-servlet.xml的文件,用于配置Spring MVC的相关信息: ``` <!-- 开启Spring MVC注解 --> <mvc:annotation-driven /> <!-- 静态资源访问 --> <mvc:resources mapping="/static/**" location="/static/" /> <!-- 视图解析器 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> <!-- 扫描Controller --> <context:component-scan base-package="com.xxx.controller" /> ``` 7.创建实体类 在src/main/java目录下创建一个名为com.xxx.entity的包,用于存放实体类。例如,可以创建一个名为Food的实体类: ``` public class Food { private int id; private String name; private double price; // 省略getter和setter方法 } ``` 8.创建Mapper接口 在src/main/java目录下创建一个名为com.xxx.mapper的包,用于存放Mapper接口。例如,可以创建一个名为FoodMapper的接口: ``` public interface FoodMapper { List<Food> findAllFoods(); Food findFoodById(int id); void insertFood(Food food); void updateFood(Food food); void deleteFood(int id); } ``` 9.创建Mapper映射文件 在src/main/resources目录下创建一个名为com/xxx/mapper的包,用于存放Mapper映射文件。例如,可以创建一个名为FoodMapper.xml的文件: ``` <mapper namespace="com.xxx.mapper.FoodMapper"> <select id="findAllFoods" resultType="com.xxx.entity.Food"> select * from food </select> <select id="findFoodById" parameterType="int" resultType="com.xxx.entity.Food"> select * from food where id = #{id} </select> <insert id="insertFood" parameterType="com.xxx.entity.Food"> insert into food(name, price) values(#{name}, #{price}) </insert> <update id="updateFood" parameterType="com.xxx.entity.Food"> update food set name = #{name}, price = #{price} where id = #{id} </update> <delete id="deleteFood" parameterType="int"> delete from food where id = #{id} </delete> </mapper> ``` 10.创建Controller 在src/main/java目录下创建一个名为com.xxx.controller的包,用于存放Controller。例如,可以创建一个名为FoodController的Controller: ``` @Controller @RequestMapping("/food") public class FoodController { @Autowired private FoodMapper foodMapper; @RequestMapping("/list") public String list(Model model) { List<Food> foods = foodMapper.findAllFoods(); model.addAttribute("foods", foods); return "food/list"; } @RequestMapping("/toAdd") public String toAdd() { return "food/add"; } @RequestMapping("/add") public String add(Food food) { foodMapper.insertFood(food); return "redirect:/food/list"; } @RequestMapping("/toEdit") public String toEdit(int id, Model model) { Food food = foodMapper.findFoodById(id); model.addAttribute("food", food); return "food/edit"; } @RequestMapping("/edit") public String edit(Food food) { foodMapper.updateFood(food); return "redirect:/food/list"; } @RequestMapping("/delete") public String delete(int id) { foodMapper.deleteFood(id); return "redirect:/food/list"; } } ``` 11.创建JSP页面 在WebContent/WEB-INF/views目录下创建JSP页面。例如,可以创建一个名为list.jsp的页面: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <html> <head> <title>Food List</title> </head> <body> <h1>Food List</h1> <table> <tr> <th>ID</th> <th>Name</th> <th>Price</th> <th>操作</th> </tr> <c:forEach items="${foods}" var="food"> <tr> <td>${food.id}</td> <td>${food.name}</td> <td>${food.price}</td> <td> <a href="${pageContext.request.contextPath}/food/toEdit?id=${food.id}">编辑</a> <a href="${pageContext.request.contextPath}/food/delete?id=${food.id}">删除</a> </td> </tr> </c:forEach> </table> <br /> <a href="${pageContext.request.contextPath}/food/toAdd">添加</a> </body> </html> ``` 12.运行项目 将项目部署到Tomcat中,启动Tomcat,访问http://localhost:8080/项目名/food/list即可看到外卖后台管理系统的列表页面。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值