什么是Spring
Spring是构建(building)Java应用程序的一个平台,它包含许多易于使用的解决方案,用来构建基于web的应用程序。
使用Spring的准备
首先你需要完成下列工作:
将spring.jar复制到你的Web library
在使用Spring之前,需要下载它,并将jar文件放到应用程序的目录下。
下载 Spring library (
http://www.springframework.org/download)
将spring.jar 放到$myApp/WEB-INF/lib/下
$myApp代表你的应用程序的名字。
配置web.xml
在 web.xml 内,你需要定义org.springframework.web.context.ContextLoaderListener,并指名配置文件的位置来加载bean定义。
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
创建Spring
配置文件
在applicationContext.xml文件内定义bean,并将此文件放到你的WEB-INF目录。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<bean id="DataSource" Bean类
在面向对象编程(OOP)中,你需要定义一个DataSource接口:
DataSource.java
package test;
public interface DataSource
{
java.util.List getElementsList();
}
它的实现类为:
DataSourceImpl.java
package test;
import java.util.*;
public class DataSourceImpl implements DataSource
{
public List getElementsList()
{
List list = new ArrayList();
list.add("Tom");
list.add("Henri");
list.add("Jim");
return list;
}
}
在ZUML 页面内访问 Spring Bean在ZUML页面内有两种方式来访问基于Spring的bean。第一种方式是variable-resolver,另一种方式是 SpringUtil。使用哪个要看你的习惯,在ZUML页面内,我们建议你使用variable-resolver。使用 variable-Resolver在ZUML页面的顶部简单的为 org.zkoss.zkplus.spring.DelegatingVariableResolver声明variable-resolver,然后,在下面的页面里,你可以使用bean的id来访问任何Spring-managed bean。<?variable-resolver <window>
<grid>
<rows>
<row forEach="${DataSource.elementsList}">
<label value="${each}"/>
</row>
</rows>
</grid>
</window>
variable- resolver将会为你自动查找名字为DataSource的bean,然后返回一个list到forEach循环。 使用 SpringUtilorg.zkoss.zkplus.spring.SpringUtil是一个实用类,它允许你使用简单的方式来获取 Spring-managed bean。<window>
<zscript>
import org.zkoss.zkplus.spring.SpringUtil;
import test.*;
DataScource dataSource = SpringUtil.getBean("DataSource");
List list = dataSource.getElementsList();
</zscript>
<grid>
<rows>
<row forEach="${list}">
<label value="${each}"/>
</row>
</rows>
</grid>
</window>
在这里forEach循环集合来打印集合内每个对象的${each}属性。Spring SecuritySpring Security 2.0 是Spring框架的下一代安全系统。它在上一代Acegi安全系统上又添加了许多新特性。运行一个简单的应用程序下载war 文件
http://downloads.sourceforge.net/zkforge/zkspringsec2.war该示例程序来自于Spring Security 2.0,已经做了修改以保证和ZK一起顺利工作。部署war 文件Tomcat 5.5 或更高版本。将zkspringsec2.war 复制到Tomcat服务器的$Tomcat_Home/webapps/文件夹,然后重启Tomcat。使用你的浏览器访问:
http://localhost:8080/zkspringsec2/username/password 为rod/koala 使用Spring Security的准备为使Spring Security和ZK一起工作,你需要复制下面的jar到/WEB-INF/lib。ZK Spring Library jar 文件zkspring.jar
Spring Security library jar 文件aopalliance-1.0.jar
aspectjrt-1.5.4.jar
commons-codec-1.3.jar
commons-collections-3.2.jar
commons-lang.jar
commons-logging-1.1.1.jar
jstl-1.1.2.jar
log4j-1.2.14.jar
spring-security-acl-2.0.3.jar
spring-security-core-2.0.3.jar
spring-security-core-tiger-2.0.3.jar
spring-security-taglibs-2.0.3.jar
spring.jar
standard-1.1.2.jar
配置/WEB-INF/web.xml 文件为使Tomcat 和Spring Security一起工作,你需要指明spring-security配置文件的位置,然后定义spring的listener和spring- security 的filter,如下: <!--
- Location of the XML file that defines the root application context
- Applied by ContextLoaderListener.
-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
...
/WEB-INF/applicationContext-security.xml
</param-value>
</context-param>
<!--
- Loads the root application context of this web app at startup.
- The application context is then available via
- WebApplicationContextUtils.getWebApplicationContext(servletContext).
-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!--
- Spring Security Filter Chains
-->
<filter>
<filter-name>springSecurityFilterChain</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
创建 /WEB-INF/applicationContext-security.xml在$myApp/WEB-INF/目录下创建 application-security.xml。此文件包含了spring-security所需要的配置(dentitions)。<!--
- Spring namespace-based configuration
-->
<beans:beans xmlns="http://www.springframework.org/schema/security"
xmlns:beans="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 http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-2.0.1.xsd">
<!--
- Enable the @Secured annotation to secure service layer methods
-->
<global-method-security secured-annotations="enabled">
</global-method-security>
<!--
- Secure the page per the URL pattern
-->
<http auto-config="true">
<intercept-url pattern="/secure/extreme/**" access="ROLE_SUPERVISOR"/>
<intercept-url pattern="/secure/**" access="IS_AUTHENTICATED_REMEMBERED" />
<intercept-url pattern="/**" access="IS_AUTHENTICATED_ANONYMOUSLY" />
<!-- use own login page rather than the default one -->
<form-login login-page="/login.zul"/>
</http>
<!--
Usernames/Passwords are
rod/koala
dianne/emu
scott/wombat
peter/opal
-->
<authentication-provider>
<password-encoder hash="md5"/>
<user-service>
<user name="rod" password="a564de63c2d0da68cf47586ee05984d7" authorities="ROLE_SUPERVISOR, ROLE_USER, ROLE_TELLER" />
<user name="dianne" password="65d15fe9156f9c4bbffd98085992a44e" authorities="ROLE_USER,ROLE_TELLER" />
<user name="scott" password="2b58af6dddbd072ed27ffc86725d7d3a" authorities="ROLE_USER" />
<user name="peter" password="22b5c9accc6e1ba628cedc63a72d57f8" authorities="ROLE_USER" />
</user-service>
</authentication-provider>
</beans:beans>
定义哪些服务被保护使用Spring Security 注释@Secured来保护商业服务的调用,如下:public interface BankService {
@Secured("IS_AUTHENTICATED_ANONYMOUSLY")
public Account readAccount(Long id);
@Secured("IS_AUTHENTICATED_ANONYMOUSLY")
public Account[] findAccounts();
@Secured("ROLE_TELLER")
public Account post(Account account, double amount);
}
定义那些ZK事件被保护在/WEB-INF/applicationContext-security.xml内定义zk命名空间需要的配置,并指定哪个ZK事件需要被保护,如下,<!--
- Spring namespace-based configuration
-->
<beans:beans xmlns="http://www.springframework.org/schema/security"
xmlns:zksp="http://www.zkoss.org/2008/zkspring"
xmlns:beans="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 http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-2.0.1.xsd http://www.zkoss.org/2008/zkspring http://www.zkoss.org/2008/zkspring/zkspring.xsd">
<http ...>
...
</http>
...
<!--
- Secure the ZK event processing per the event name and ZK component path pattern
-->
<zksp:zk-event login-template-close-delay="5">
<zksp:intercept-event event="onClick" path="//**/btn_*" access="ROLE_TELLER"/>
<zksp:intercept-event path="/**" access="IS_AUTHENTICATED_ANONYMOUSLY"/>
</zksp:zk-event>
</beans:beans>
xmlns:zksp="http://www.zkoss.org/2008/zkspring 告诉Spring Security引擎我们将要使用ZK Spring命名空间配置,并定义命名空间为zksp。
http://www.zkoss.org/2008/zkspringhttp://www.zkoss.org/2008/zkspring/zkspring.xsd 告诉Spring Security引擎哪里可以找到这个 ZK Spring命名空间的配置schema。<zksp:zk-event> 告诉Spring Security引擎我们要保护ZK事件处理。这将会自动配置需要的 listeners,filters和 Spring bean。在这个例子中,login-template-close-delay="5"告诉ZK登录成功5秒后自动关闭这个登录窗口;zero(0)意味着登录成功后立即关闭登录窗口;而一个负数值则意味着要等待用户的操作。<zksp:intercept-event event="onClick" path="//**/btn_*" access="ROLE_TELLER"/>t告诉Spring Security引擎我们想要保护哪些ZK事件和组件。在这个例子中,例如任何一个id以btn_开头的组件的onClick 事件被触发后,它都会被ROLE_TELLER authority 检查。<zksp:intercept-event path="/**" access="IS_AUTHENTICATED_ANONYMOUSLY"/> 表示所有的匿名用户可以访问所有的事件和组件。ZUML页面在下面的例子中,当他/她企图该改变帐户余额(the balance of account)时,ZK会提示终止用户登录,因为Button组件的onClick事件已经被Spring-Security 保护了。<?variable-resolver title="Accouts" border="normal" width="500px">
<zscript><![CDATA[
void adjBalance(Button btn) {
double bal = new Double((String)btn.getAttribute("bal")).doubleValue();
//get the account object
bigbank.Account a = bankService.readAccount(btn.getAttribute("aid"));
//change the account balance
bankService.post(a, bal);
//update the account balance on the browser
btn.getFellow("bal_"+a.getId()).setValue(""+a.getBalance());
}
]]>
</zscript>
<grid>
<rows>
<row forEach="${accounts}">
<label value="${each.id}"/>
<label value="${each.holder}"/>
<label id="bal_${each.id}" value="${each.balance}"/>
<button id="btn_m20_${each.id}" label="-$20" onClick="adjBalance(self)">
<custom-attributes aid="${each.id}" bal="-20"/>
</button>
<button id="btn_m5_${each.id}" label="-$5" onClick="adjBalance(self)">
<custom-attributes aid="${each.id}" bal="-5"/>
</button>
...................
</row>
</rows>
</grid>
</window>
<button label="Home" href="/index.zul"/>
<button label="Logout" href="/j_spring_security_logout"/>
</zk>
相关推荐
在自个学习zk和其他两个框架整合的时候,总是找不到合适的整合demo进行参考,希望此次上传能对初学者有用
数据库是mysql的 都在压缩文件中了 里面有具体的操作步骤。项目是一个zk+spring+hibernate整合
在自个学习zk和其他两个框架整合的时候,总是找不到合适的整合demo进行参考,希望此次上传能对初学者有用,能够给你们一个完整的代码,让你们可以直接把项目运行起来,这样对于开发来说是最重要的
zk+spring+hibernate增删改查,整合实例,亲测可用zk+spring+hibernate增删改查,整合实例,亲测可用
ZK Spring hibernate 完美整合
很多zk初学者对zk与spring和hibernate的整合很头疼,在这花了一晚上的时间整了个完整工程包供大家学习参考,所需jar包很大,都抓成图片了,具体看工程说明. 在遇到zk方面的问题可以加qq群:71714290交流。
ZK7+Spring4+Hibernate4框架整合,Spring所需jar包,整合过程见我的博客。
ZK7+Spring4+Hibernate4框架整合,ZK所需jar包,整合过程见我的博客。
新增「整合Spring」 及「整合Hibernate」
包含构建spring+springmvc+jpa(hibernate)架构框架的所需文件
spring kafka的整合, kafka zk需要自己下载。 配置自己百度
zk简体中文开发手册3.5.1 全 ajax hibernate spring 整合
abapi-spring-cloud-alibaba简介本项目为spring-cloud-alibaba整合分为框架整合和常用插件模块abapi-cloud-start是spring cloud alibaba 微服务架构组件模块abapi-cloud-web-start是springboot启动框架,引入改jar包...
对常见技术的整合,以及前沿新技术的整合(如:kotlin,webflux) 启动说明 如果是不依赖中间件的模块,单独运行main方法即可运行 如果有依赖redis,zookeeper等的模块,建议用docker启动,同时绑主机访问 主办: ...
Springboot整合Dubbo/ZooKeeper_demo。我目前把我的资源全部调成了0分,我希望不要因为其他什么原因改变我的资源下载积分,不然以后只能搞百度云等链接了。
java的spring-boot工程使用digest方式对zookeeper进行权限控制,包括初始化zk,以及增删改查等
eclipse springboot+dubbo+zk+mybatis restful编程风格 学习搭建框架的好例子
ZK7+Spring4+Hibernate4框架整合,Hibernate所需jar包,整合过程见我的博客。
demo——spring配置文件形式整合dubbo+zk
该资源包含springboot整合dubbo的一个小demo,和zookeeper的window版本。博客链接为:https://blog.csdn.net/dayonglove2018/article/details/109156635