一、配置部分
1、applicationContext.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd ">
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName"
value="com.mysql.jdbc.Driver" />
<property name="url"
value="jdbc:mysql://localhost:3306/springapp" />
<property name="username" value="root" />
<property name="password" value="root" />
</bean>
<bean id = "transactionManager"
class = "org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name = "dataSource" ref="dataSource"/>
</bean>
<bean id = "jdbcTemplate"
class = "org.springframework.jdbc.core.JdbcTemplate">
<property name = "dataSource" ref="dataSource"/>
</bean>
<bean id="transactionInterceptor"
class="org.springframework.transaction.interceptor.TransactionInterceptor">
<property name="transactionManager">
<ref bean="transactionManager" />
</property>
<property name="transactionAttributes">
<props>
<prop key="delete*">PROPAGATION_REQUIRED,-Exception</prop>
<prop key="update*">PROPAGATION_REQUIRED,-Exception</prop>
<prop key="save*">PROPAGATION_REQUIRED,-Exception</prop>
<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
<bean id="txProxy"
class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
<property name="beanNames">
<list>
<value>*Dao*</value>
<value>*Service*</value>
</list>
</property>
<property name="interceptorNames">
<list>
<value>transactionInterceptor</value>
</list>
</property>
</bean>
<bean id = "userService"
class = "com.logcd.service.impl.UserService">
<property name="jdbcTemplate" ref="jdbcTemplate"/>
</bean>
</beans>
2、faces-config.xml文件
<?xml version='1.0' encoding='UTF-8'?>
<faces-config xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-facesconfig_2_0.xsd"
version="2.0">
<application>
<variable-resolver>
org.springframework.web.jsf.DelegatingVariableResolver
</variable-resolver>
<locale-config>
<default-locale>zh_CN</default-locale>
<supported-locale>en</supported-locale>
<supported-locale>zh_CN</supported-locale>
</locale-config>
</application>
</faces-config>
3、web.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_5.xsd">
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<context-param>
<param-name>javax.faces.CONFIG_FILES</param-name>
<param-value>/WEB-INF/faces-config.xml</param-value>
</context-param>
<context-param>
<param-name>javax.faces.STATE_SAVING_METHOD</param-name>
<param-value>server</param-value>
</context-param>
<context-param>
<param-name>javax.faces.PROJECT_STAGE</param-name>
<param-value>Development</param-value>
</context-param>
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>/faces/*</url-pattern>
<url-pattern>*.xhtml</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>views/hello.xhtml</welcome-file>
</welcome-file-list>
</web-app>
二、服务与Bean调用
1、服务接口与实现
package com.logcd.service;
import com.logcd.model.User;
public interface IUserService {
public User findByUserId(int userId);
}
package com.logcd.service.impl;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowCallbackHandler;
import com.logcd.model.User;
import com.logcd.service.IUserService;
public class UserService implements IUserService {
private JdbcTemplate jdbcTemplate;
public JdbcTemplate getJdbcTemplate() {
return jdbcTemplate;
}
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
public User findByUserId(int userId) {
final User user = new User();
jdbcTemplate.query("SELECT * FROM t_user WHERE id = ?",
new Object[] {new Integer(userId)},
new RowCallbackHandler() {
public void processRow(ResultSet rs) throws SQLException {
user.setId(rs.getInt("id"));
user.setUserName(rs.getString("username"));
user.setPassword(rs.getString("password"));
}
});
return user;
}
}
2、在Bean中调用服务层
package com.logcd.jsfsun;
import java.io.Serializable;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ManagedProperty;
import javax.faces.bean.SessionScoped;
import com.logcd.model.User;
import com.logcd.service.IUserService;
@ManagedBean(name = "hello")
@SessionScoped
public class HelloWorld implements Serializable{
private static final long serialVersionUID = 1L;
private String name = "World";
@ManagedProperty(name="userService", value="#{userService}")
private IUserService userService;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public IUserService getUserService() {
return userService;
}
public void setUserService(IUserService userService) {
this.userService = userService;
}
/**
* 测试调用服务
* @return
*/
public String getLoginName() {
User user = userService.findByUserId(10001);
return user.getUserName();
}
}
3、xhtml页面调用测试
<div style="margin: 5px; color: green;font-weight: bold;">
欢迎您,<h:outputText value="#{ hello.loginName }"/>
</div>
分享到:
相关推荐
### JSF与Spring集成知识点详解 #### 一、概述 **JSF (JavaServer Faces)** 和 **Spring** 都是目前广泛使用的Java Web开发框架。JSF 是一个用于构建基于 Java 的 Web 应用程序的标准组件框架,而 Spring 框架则是...
### JSF2与Spring集成应用详解 #### 一、引言 在当今的企业级应用开发领域,JavaServer Faces (JSF) 和 Spring 框架是两个非常重要的技术栈。JSF 是一种用于构建用户界面的Java标准组件框架,而Spring则是一个提供...
整合教程通常会涵盖这些步骤,指导开发者如何设置环境、配置Spring和JSF、创建并集成Managed Beans,以及处理页面事件和业务逻辑。通过学习这些教程,开发者可以有效地结合两者的优点,构建出高效、灵活且易于维护的...
【JSF2与Spring整合详解】 JavaServer Faces 2(简称JSF2)是Java平台上的一个企业级的用户界面框架,它为构建基于Web的应用程序提供了组件化、事件驱动的模型。而Spring框架则是Java后端开发的核心框架,以其依赖...
在这个"jsf+hibernate+spring集成案例"中,我们将看到: 1. **配置集成**:首先,我们需要在Spring配置文件中定义数据源、SessionFactory(Hibernate的核心组件)以及JSF所需的Managed Beans。这通常涉及到XML配置...
2. **配置JSF**:为了使JSF能够与Spring协作,需要在JSF的配置文件(如`faces-config.xml`)中添加Spring的JSF监听器`org.springframework.web.jsf.FacesContextListener`,这样JSF就能识别到Spring的Bean。...
总之,JSF 2 与 Spring 3 的集成使得开发者能够在视图层享受 JSF 的便利,同时利用 Spring 提供的强大后端功能。这种集成方案在大型企业级项目中非常常见,能够有效提升开发效率和应用质量。通过深入理解这些知识点...
项目中的"jsm"可能代表了与JSF、Spring和Mybatis集成相关的配置文件、源代码或资源文件。这些文件可能包括: 1. `faces-config.xml` - JSF的配置文件,定义了视图、导航规则和 Managed Beans。 2. `web.xml` - Web...
SWF为JSF提供了更强大的流程控制能力,而SpringFaces则是Spring社区为了更好地集成JSF而创建的项目。 **4. 整合步骤** - 配置Spring:在Web应用的`web.xml`中配置Spring的DispatcherServlet,并添加Spring的上下文...
在JSF和Spring的环境中,Hibernate常用于管理数据库交互,Spring可以通过其JPA(Java Persistence API)支持轻松地集成Hibernate。 在这个整合项目中,开发者可能已经配置了以下关键组件: 1. **JSF配置**:JSF的...
jsf与spring的集成的几种方式,以及jsf的一些技术
【JSF集成Spring Framework和Hibernate开发应用实例】的详述 JavaServer Faces (JSF) 是一种基于MVC(Model-View-Controller)模式的Java EE应用程序用户界面框架,适用于构建复杂的Web应用。JSF提供了丰富的组件库...
在标签"jsf spring"中,我们看到这两个关键词,进一步确认了这个资源的主题是关于JSF与Spring的集成。 压缩包中的文件名"jsf-spring-4.0.3"可能包含以下内容: 1. **配置文件**:如`spring-context.xml`,用于定义...
3. **JSF与Spring Boot集成**:JSF可以与Spring Boot结合使用,通过Spring Faces模块实现。Spring Faces允许在JSF环境中利用Spring的功能,如依赖注入和AOP(面向切面编程)。集成后,开发者可以利用Spring Boot的...
在JSF和Spring集成时,Spring可以作为JSF的后台服务层,处理业务逻辑和数据访问。通过Spring的JSF集成模块,如`spring-jsf.jar`(虽然这个文件不在当前列表中,但在实际集成中可能需要),可以使JSF和Spring之间的...
在与JSF集成时,Spring常用于提供业务逻辑和服务层支持。例如,通过Spring的`@ManagedBean`和`@RequestScoped`注解可以创建JSF可访问的bean,同时利用Spring的IoC容器管理这些bean的生命周期和依赖关系。 **...
2. **JSF与Spring的整合**:为了使JSF能够使用Spring的Bean,我们需要添加`spring-jsf`库,并配置JSF的` faces-config.xml`,将Spring作为JSF的Managed Bean提供者。这样,JSF可以通过Spring的ApplicationContext...
在本项目中,MySQL作为数据存储的平台,与Spring Data JPA 集成,实现了对数据的持久化管理。`credit-manager`可能包含了数据库模型的设计,如实体类(Entity),以及与这些实体对应的数据库表结构。 **最小化配置*...