不善于写博客,第一篇,介绍下spring强大的类名加方法名实现极度简洁的mvc。正文如下:
1:对web项目加入spring支持,不罗嗦哪些jar包依赖了,仅仅展示web.xml的spring支持配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app 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_4.xsd"
version="2.4">
<display-name>Web</display-name>
<!-- 设置会话超时 -->
<session-config>
<session-timeout>30</session-timeout>
</session-config>
<context-param>
<description>Spring配置文件位置</description>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<listener>
<description>Spring配置加载器</description>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
<!-这里是自己定义的监听器,可以忽略->
<listener>
<description>App监听器</description>
<listener-class>
com.gyx.web.listener.AppListener
</listener-class>
</listener>
<!-自定义的过滤器 可以忽略->
<!-- sessionFilter -->
<filter>
<filter-name>sessionFilter</filter-name>
<filter-class>
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
</filter-class>
<!-- singleSession默认为true,若设为false则等于没用OpenSessionInView -->
<init-param>
<param-name>singleSession</param-name>
<param-value>true</param-value>
<!--控制hibernate的sessionfactory-->
<param-name>flushMode</param-name>
<param-value>AUTO</param-value>
</init-param>
</filter>
<filter>
<description>字符集设置过滤器</description>
<filter-name>encodingFilter</filter-name>
<filter-class>
org.springframework.web.filter.CharacterEncodingFilter
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>sessionFilter</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
<!-这里是启动spring servlet分发器 必须->
<servlet>
<description>SpringMVC Action</description>
<servlet-name>action</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<!-这里是配置拦截匹配,必须不配置 默认是拦截 html->
<servlet-mapping>
<servlet-name>action</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
上面是web.xml对于springz支持的配置,注意就是配置spring的监听,上下文路径,拦截匹配。
下面是如何实现方法名加类名实现一步到位的配置,很简单,就是很少有人知道去用。
<?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:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd"
default-autowire="byName">
<description>Spring配置文件</description>
<!--spring 辅助配置文件 比如 国际化文件 文件上传附件大小限制等等-->
<!--bean id="SystemConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>/WEB-INF/system.config.properties</value>
</list>
</property>
</bean-->
<!-- Spring MVC -->
<!--import resource="springmvc-support.xml" /-->
<!-这里是配置类名注解,必须!!!!->
<!-- URL Mapping -->
<bean class="org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping">
<property name="caseSensitive" value="true" />
</bean>
<!-这里是配置方法名注解,必须!!!!!->
<!-- Method Mapping -->
<bean id="methodNameResolver" class="org.springframework.web.servlet.mvc.multiaction.InternalPathMethodNameResolver" />
<!-- 文件上传支持Bean -->
<!--bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="${upload.filesize}" />
</bean-->
<!-- 启用标注式申明 ,必须!!!!!!!!-->
<context:annotation-config />
<!-这里配置controller的包扫描路径,spring用来实例化,必须!!!!!!!!!->
<context:component-scan base-package="com.gyx.web.action" />
<context:component-scan base-package="com.gyx.web.controller" />
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName"
value="oracle.jdbc.driver.OracleDriver">
</property>
<property name="url"
value="jdbc:oracle:thin:@127.0.0.1 :1521:demo">
</property>
<property name="username" value="gyx_1"></property>
<property name="password" value="gyx_1"></property>
</bean>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.Oracle9Dialect
</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
</props>
</property>
<!--property name = "hibernate.cache.provider_class">
org.hibernate.cache.HashtableCacheProvider
</property-->
<property name="mappingResources">
<list>
<value>com/gyx/web/model/AdUser.hbm.xml</value>
<value>com/gyx/web/model/AdForm.hbm.xml</value>
<value>com/gyx/web/model/AdPemit.hbm.xml</value>
<value>com/gyx/web/model/AdRole.hbm.xml</value>
<value>com/gyx/web/model/AdUserRole.hbm.xml</value>
<value>com/gyx/web/model/AdFormRole.hbm.xml</value>
<value>com/gyx/web/model/AdSession.hbm.xml</value>
</list>
</property>
</bean>
<!--HibernateTemplate模板 -->
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate"
abstract="false" lazy-init="false" autowire="default"
dependency-check="default">
<property name="sessionFactory">
<ref local="sessionFactory" />
</property>
</bean>
<!-- JDBC模板 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" abstract="false"
lazy-init="false" autowire="default" dependency-check="default">
<property name="dataSource">
<ref local="dataSource" />
</property>
</bean>
<!-- blob、clob设置 -->
<bean id="defaultLobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler"
lazy-init="true" />
<!-- 事务管理 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<bean id="baseTransactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"
abstract="true">
<property name="transactionManager" ref="transactionManager" />
<property name="transactionAttributes">
<props>
<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="persist*">
PROPAGATION_REQUIRED,-Exception
</prop>
<prop key="remove*">
PROPAGATION_REQUIRED,-Exception
</prop>
<prop key="save*">PROPAGATION_REQUIRED</prop>
<prop key="del*">PROPAGATION_REQUIRED</prop>
<prop key="update*">PROPAGATION_REQUIRED</prop>
<prop key="create*">PROPAGATION_REQUIRED</prop>
<prop key="add*">PROPAGATION_REQUIRED</prop>
<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
<!--prop key="*">PROPAGATION_REQUIRED</prop-->
</props>
</property>
</bean>
<bean id="AdUserDAO" class="com.gyx.web.model.AdUserDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<bean id="AdFormDAO" class="com.gyx.web.model.AdFormDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<bean id="AdPemitDAO" class="com.gyx.web.model.AdPemitDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<bean id="AdRoleDAO" class="com.gyx.web.model.AdRoleDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<bean id="AdUserRoleDAO" class="com.gyx.web.model.AdUserRoleDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<bean id="AdFormRoleDAO" class="com.gyx.web.model.AdFormRoleDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<bean id="AdSessionDAO" class="com.gyx.web.model.AdSessionDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
</beans>
上面是核心配置,这样就可以一步到位的去请求后台Java代码啦。
代码部分
实现一个简单的form tree加载,方法不全,仅仅演示使用
@Controller("formAction")
public class FormActionController extends AbstractActionController {
public void tree(HttpServletRequest req, HttpServletResponse resp) throws Exception {
StringBuffer buff = new StringBuffer("[");
ArrayList<Object> params = new ArrayList<Object>();
StringBuffer sql = new StringBuffer( "SELECT F.NAME,F.AD_FORM_ID FROM AD_FORM F WHERE 1=1 AND PARENTID IS NULL AND F.UPDATED >= TO_DATE('2013-04-08','YYYY-MM-DD') ORDER BY F.AD_FORM_ID ");
String sqls = sql.toString();
SqlRowSet rs = getJdbcTemplate().queryForRowSet(sqls, params.toArray());
while (rs.next()) {
buff.append("{id:'" + rs.getInt("AD_Form_ID")).append("',text:'" + rs.getString("Name")).append("',");
int id = rs.getInt("AD_Form_ID");
buff.append(childNode(id));
}
if (rs.isAfterLast()) {
buff.deleteCharAt(buff.length() - 1);
}
buff.append("]");
sendJSON(resp, buff.toString());
}
}
上面的controller只有一个注解 @Controller("formAction")
用于与前台界面进行URL路径匹配。
js
Ext.namespace("App.Form");
App.Form.Manager = function(config) {
config = config || {};
this.moduleId = config.moduleId || 'Form_Manager';
this.action = App.getContextPath() + "formAction";
var pageSize = App.getPageSize();
// 树菜单
var root = new Ext.tree.AsyncTreeNode({
id : '0',
text : "菜单列表",
draggable : false,
leaf : false,
expanded : true
});
var treeloader = new Ext.tree.TreeLoader({
dataUrl : this.action + "/tree.do"
});
var treepanel = new Ext.tree.TreePanel({
rootVisible : true,
hideCollapseTool : true,
collapsible : false,
id : this.moduleId + "_formTree",
width : 200,
minSize : 180,
maxSize : 250,
split : true,
autoHeight : false,
autoScroll : true, // 自动滚动
// containerScroll : true,// 是否支持滚动条
// border : true, // 边框
animate : true, // 动画效果
loader : treeloader,
lines : true,
trackMouseOver : true,
root : root,
listeners : {
scope : this,
"click" : function(node, event) {
node.expand();
var grid = Ext.getCmp(this.moduleId + "_treeGrid");
if (node.isLeaf()) {
return;
}
if (!node.isLeaf() && node.parentNode.id == 0) {
grid.getStore().reload({
params : {
parentID : node.id
}
})
}
}
}
});
}
在js中约束好对应名称即可 this.action = App.getContextPath() + "formAction";
请求方法如下:
dataUrl : this.action + "/tree.do"
这样就实现了完全的spring mvc 无需任何额外的配置啦。