11dwr - dwr.xml配置(allow标签-Creator属性)
allow 部分定义了 DWR 能够创建和转换的类。
Creator
每一个在类中被调用的方法需要一个<create …>有若干类型的 creator,使用“new”关键字或者 Spring 框架等。
create 元素是如下的结构:
<allow>
<create creator="..." javascript="..." scope="...">
<param name="..." value="..." />
<auth method="..." role="..." />
<exclude method="..." />
<include method="..." />
</create>
...
</allow>
creator 属性
1).new:Java 用“new”关键字创造对象
是 DWR 默认的 creator,如下所示:
<create id="new" class="org.directwebremoting.create.NewCreator"/>
没有必要把它加入 dwr.xml,它已经在 DWR 内部文件了。
这个 creator 将使用默认构造器创建类的实例,以下是用 new 创建器的好处
- 安全:DWR 创造的对象生存的时间越短,多次调用中间的值不一致的错误机会越少。
- 内存消耗低: 如果你的站点用户量非常大,这个创造器可以减少 VM 的内存溢出。
2).none: 它不创建对象,看下面的原因。 (v1.1+)
none 创建器不创建任何对象,它会假设你不须要创建对象。有 2 个使用的原因:
-
你可能在使用的 scope 不是"page"(看上面),并在在前面已经把这个对象创建到这个 scope 中了,
这时你就不需要再创建对象了。 -
还有一种情况是要调用的方法是静态的,这时也不需要创建对象。DWR 会在调用创建器之前先检
查一下这个方法是不是静态的。
对于上诉两种情况,你仍然需要 class 参数,用来告诉 DWR 它是在操作的对象类型是什么。
3). scripted: 通过 BSF 使用脚本语言创建对象,例如 BeanShell 或 Groovy。
要使用这个创造器,你需要把一些辅助库放到 WEB-INF/lib 文件夹下:比如 BSF 的 jar 包 ,你要用的脚本语言的 jar 包 。
new 创造器在 DWR 中已经默认声明了:
<creator id="script" class="uk.ltd.getahead.dwr.create.ScriptedCreator"/>
这个创造器用 BSF 来执行脚本得到 Bean,例如:
<allow>
...
<create creator="script" javascript="EmailValidator">
<param name="language" value="beanshell" />
<param name="script">
import org.apache.commons.validator.EmailValidator;
return EmailValidator.getInstance();
</param>
</create>
...
</allow>
script 创造器有如下参数:
注意:
当一个类是用 script 创造出来的,并且 scope 是 session 或 application,如果你的脚本改变,session 中的
类和 script 中的类就不一致了。这样会出现错误。虽然 web 容器不用重启,但是用户需要先登出(或以某种
方式清空 session),然后再登录。
当 clazz 参数不为空,并且用来创造新实例,DWR 简单的调用 class.newInstance() 方法。这种方法是没
问题的,除非脚本正在用某个参数创建一个类,或者调用某个函数来配置这个类。 不幸的是,每次请求都
要重新运行 script 并造成上面的问题。
javascript 属性
在浏览器里给你创建的对象命名。避免使用 JavaScript 保留字。这个名字将在页面里作为 js 被导入。
dwr.xml:
<create creator="new" javascript="service">
<param name="class" value="helloWorld.Service" />
</create>
html / jsp:
<html>
<head>
…
<script type='text/javascript' src='dwr/interface/service.js'>
…
scope 属性
和定义在 servlet 的 scope 一样大的范围,它允许你指定哪个 bean 是可以获得的。选项可以是:application,session, request 和 page。这些值应该已经被开发者们熟悉了。
scope 选项是可选的,默认为 page, 使用 session 请求 cookies。目前,DWR 还不支持 URL 重写。
param 元素
被用来指定创造器的其他参数,每种构造器各有不同。例如,"new"创造器需要知道要创建的对象类型是什么。每一个创造器的参数在各自的文档中能找到。
include 和 exclude 元素
允许一个创造器去限制进入类的方法。一个创造器必须指定 include 列表或 exclude 列表之一。如果是include 列表则暗示默认的访问策略是"拒绝",include 中的每个方法就是允许访问的方法;如果是 exclude列表则暗示默认的访问策略是"允许",exclude 中的每个方法就是拒绝访问的方法。
比如:
<create creator="new" javascript="Fred">
<param name="class" value="com.example.Fred" />
<include method="setWibble" />
</create>
说明你只能在 DWR 中使用 Fred 的是 setWibble 方法。
auth 元素
允许你指定一个 J2EE 的角色作为将来的访问控制检查:
<create creator="new" javascript="Fred">
<param name="class" value="com.example.Fred" />
<auth method="setWibble" role="admin" />
</create>
使用静态方法
DWR 会在调用创建器之前先检查一下这个方法是不是静态的,如果是那么创造器不会被调用。很显然这个
逻辑适用于所有创造器,尽管如此"null"创造器是最容易配置的。
使用单例类
对于单例类的创建,最好适用 BeanShell 和 BSF 来实例化对象。
DWR 与 HttpSessionBindingListeners
DWR1.x 中存贮已经创造的 Bean 的方法需要注意,它在每次请求时都会调用相同的 setAttribute() 方法。就是说,如果一个 Bean 在 dwr.xml 中的声明周期设置为 session,再每次调用 bean 中的方法时,DWR都会执行一次 session.setAttribute(yourBean) 。这看上去没有什么危害,但是如果你要使用 servlet 的事件机制的,就是说用了 HttpSessionBindingListener 接口,你就会发现 valueBound 和 valueUnbound 事件在每次调用时都会发生,而不是你想像的在 bean 被创建时以及 session 过期时。
DWR2 只在第一次创建对象时调用 setAttribute()
相关文章
- BootstrapValidator 解决多属性被同时校验问题
- Jquery插件 easyUI属性汇总
- spring boot下为配置属性值加密的正确姿势
- Selenium webdriver 获取属性值 元素里的value
- 前端学习 -- Css -- 属性选择器
- java 15: jinfo查看jvm配置参数和系统属性
- Spark配置属性整理(非常全面)
- spring boot通过命令行配置属性
- 在ArcEngine下实现图层属性过滤的两种方法
- 简述css中的不同盒模型的特性,以及应用,介绍box-sizing属性
- SAP UI5 SimpleForm 控件的 adjustLabelSpan 属性
- css flex属性学习笔记
- Atitit xml转json总结 目录 1.1. XML和JSON之间没有直接映射;元素类型问题1 1.2. Xml与json的对应关系2 1.3. 范例2 2. Jsonlib的问题,,不
- SpringBoot配置属性之NOSQL
- SpringBoot配置属性之Server
- 关于 Angular 应用 tsconfig.json 中的 target 属性
- XML——读取文件夹下所有的Xml文件,并修改属性,保留上次打开文件的位置
- Vue学习之--------脚手架的分析、Ref属性、Props配置(2022/7/28)
- 【Android Gradle 插件】Gradle 扩展属性 ① ( Gradle 扩展属性简介 | Gradle 自定义 task 任务示例 )
- 【Android Gradle 插件】PackagingOptions 配置 ③ ( merges 属性配置 | excludes 属性配置 )
- 【Android Gradle 插件】LintOptions 配置 ⑦ ( explainIssues 属性配置 | htmlOutput 属性配置 | htmlReport 属性配置 )
- 【Android Gradle 插件】LintOptions 配置 ⑥ ( checkReleaseBuilds 属性配置 | disable 属性配置 | enable 属性配置 )
- 【Android Gradle 插件】DexOptions 配置 ⑧ ( preDexLibraries 属性配置 | threadCount 属性配置 )
- 【Android Gradle 插件】DexOptions 配置 ③ ( additionalParameters 属性配置 | 多 dex 参数配置 | --multi-dex 参数 )
- 【Android Gradle 插件】DataBindingOptions 配置 ( BaseExtension#dataBinding 脚配块配置 | DataBindingOptions 属性)
- elastalert 用import属性来组织,引入配置
- 【微服务笔记15】微服务组件之Config配置中心实现用户认证、配置属性加解密
- 【微服务笔记02】微服务组件之Eureka常见的几个配置属性及其常见的几个概念