WebX框架解析及使用教程

article/2025/9/29 8:17:27
WebX框架是阿里巴巴集团开发的,它建立在SpringEx的基础上,具有超强的扩展能力。
一、Webx的层次结构(从里到外)
(1)SpringExt:基于Spring,提供扩展组件的能力
(2)Webx Framework:基于Servlet API,提供基础服务
(3)Webx Turbine:基于Webx Framework,实现具体的网页功能
二、Webx的初始化
位置:/WEB-INF/web.xml文件

【重要】WebX框架解析及使用教程之一

结果:自动搜索/WEB-INF目录下的XML配置文件,并创建级联的Spring容器。

/WEB-INF/webx.xml->/WEB-INF/web-app1.xml->/WEB-INF/webx-app2.xml
三、初始化日志系统

添加方式:

【重要】WebX框架解析及使用教程之一

四、Webx响应请求

Webx响应请求的流程:

(1)WebxFrameworkFilter接收请求

(2)WebxRootController创建和处理request context,路由到子应用,并提供处理异常、开发模式功能。

(3)WebxController进行apps' pipeline

当一个HTTP请求到达时,WebxFrameworkFilter接收请求的模板配置(/WEB-INF/webx.xml)如下:

【重要】WebX框架解析及使用教程之一

为什么使用filter而不是servlet?如果webx发现某个请求不应该由webx来处理,就会把控制返还给原来的控制器,而Servlet不具备返还控制的机制。

RequestContext对象的标准模板如下:【重要】WebX框架解析及使用教程之一

五、Webx Turbine

它的基本准则是:约定胜于配置,即:工程师只需要根据一定的规则,将模板放在指定的目录、按照预定的方式命令module(也就是screenactioncontrol等),就不再需要额外的配置。

Turbine的基本页面组成为:

 

(1)Screen:代表页面的主体

(2)Layout:代表页面的布局

(3)Control:代表嵌在screen和layout中的页面片段

页面布局图如下:

【重要】WebX框架解析及使用教程之一

六、Webx Turbine处理页面的基本流程

Webx Turbine的处理流程被定义在pipeline中,pipeline推荐的配置如下:

【重要】WebX框架解析及使用教程之一

流程具体解读如下:

(1) 分析URL:用户访问的主页target

(2) 进入choose,进行多重分支选择

(3)performAction执行action

(4) performTemplateScreen查找并执行screen

假设targetxxx/yyy/zzz,那么Webx Turbine查找screen模块的顺序为:

Screen.xxx.yyy.zzz

Screen.xxx.yyy.Default

Screen.xxx.Default

Screen.Default

(5) 渲染模板

首先映射成screen template,以及映射成layout template

假设targetxxx/yyy/zzz,那么Webx Turbine会查找下面的screen模板:/templates/screen/xxx/yyy/zzzScreen模板如果未找到,就会报404 Not Found错误。 找到screen模板以后,Webx Turbine还会试着查找下面的layout模板:

/templates/layout/xxx/yyy/zzz

/templates/layout/xxx/yyy/default

/templates/layout/xxx/default

/templates/layout/default

Layout模板如果找不到,就直接渲染screen模板;如果存在,则把渲染screen模板后的结果嵌入到layout模板中。
七、Filter的用途

页面授权:根据登录用户的权限,阻止或许可用户访问特定的页面。

日志和审计:记录和检查用户访问WEB应用的情况。

图片转换:改变图片的格式、精度、尺寸等。

页面压缩:压缩页面内容,加快下载速度。

本地化:显示本地语言和风格的页面。

XSLT转换:对XML内容进行XSLT转换,使之适用于多种客户端。

高速缓存:高速缓存页面,提高响应速度。

使用方法:
【重要】WebX框架解析及使用教程之一

Webx提供了Request Contexts服务以及Pipeline作为对Filter功能缺陷的补充,作用分别如下:

(1) Request Contexts:负责访问和修改requestresponse,但不负责改变应用执行的流程

(2) Pipeline:提供应用执行的流程,但不关心和requestresponse

八、Spring中依赖注入的限制

小作用域的对象不能被注入到大作用域的对象。你不能把request和response作用域的对象注入到singleton对象中。前者在每次WEB请求时,均会创建新的实例,每个线程独享这个request/session作用域的对象;后者是在Spring初始化或第一次使用时被创建,然后被所有的线程共享。假如把某个request/session作用域的对象意外注入到singleton对象中,将可能产生致命的应用错误,甚至导致数据库的错乱。

在Webx中,这样做是可以的!奥秘在于Request Contexts服务对上表所列的这些短期对象作了特殊的处理,使它们可以被注入到singleton对象中。事实上,被注入的只是一个“空壳”,真正的对象是在被访问到的时候才会从线程中取得的。

九、buffered缓存response中内存的实现原理

Webx支持用layout/screen/control等部件共同构成一个页面。其中,每个layout可包含一个screen和多个control,每个screen可包含多个control,每个control还可以在包含其他的control。

一般页面比如通过out.println("

hello world

");就直接输出了,为了还能分开然后再一起显示呢。例如,一个screen中包含了一个control,那么screen可以获得它所调用的control的完整的渲染内容。

这个玄机就是靠来实现的。改变了response的输出流,包括output stream和writer,使写到输出流中的内容被暂存在内存中。当需要时,可以取得缓存中的所有内容。

Buffered机制会延迟服务器对用户的响应,所以某些场景需要关闭该服务。

十、表单验证的模板

该文件form.xml位于WEB-INF的每个子目录中,用于表单的验证

【重要】WebX框架解析及使用教程之一

十一、Eclipse中开发Webx应用

(1)Webx工程目录结构 

src\main:存放开发代码

src\test:存放开发自测代码,如单元测试代码

main\java:存放java代码

main\resources:存放资源定义文件

main\webapp:web应用配置文件

webapp目录包含(举例):

【重要】WebX框架解析及使用教程之一

1)子应用模板目录admin、home、store、user,每个模板目录又由layout、control、screen三个子目录组成,包含对应的模板文件(.vm文件)

2)通用模板目录common

3)WEB-INF目录

这是java web应用必备的配置目录,包含了web.xml(java web应用必备的配置文件)、webx.xml(webx配置文件)、日志配置文件(log4j.xml、logback.xml)、子应用配置文件(webx-admin.xml、webx-home.xml、webx-store.xml、webx-user.xml);另外还有对应每个子应用的文件夹,用于存放form定义文件(form.xml)和访问权限定义文件(access.xml);common文件夹中的pipeline.xml和pipeline-exception.xml定义了相关的管道操作流程。

(2)页面获取JAVA层的数据PullTool

在velocity模板中使用pulltool方便我们进行页面输出内容的控制,组织页面的展示,或者是直接取得web层相关的一些对象,直接在vm中调用。由页面拉动业务逻辑,获取并控制需要展示的内容,而非应用程序推动push,这符合webx的页面驱动的模式。

1)是否启动pull服务:

 【重要】WebX框架解析及使用教程之一

在webx.xml文件中进行总的控制

2)指定获取数据的JAVA处理模块

【重要】WebX框架解析及使用教程之一   

指定了获取的数据位于com.xx.web.ui.module.*

3)在/xx/templates/screen下创建testMain.vm(M需要大写)文件,内容如下:

  【重要】WebX框架解析及使用教程之一

4)在/src/main/java/com/web/ui/module/screen下创建文件TestMain.java(webx会自动匹配同名的文件),内容如下:

 

package com.yunos.tv.openbase.web.ui.module.screen;


import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import com.alibaba.citrus.turbine.Context;


public class TestMain {

public void execute(HttpServletRequest request, HttpServletResponse response, Context context) throws Exception{

context.put("name", "Hugh");

}


}

 execute方法就是专门用来处理对应请求的,是webx潜规则的地方,它是页面渲染之前处理的方法。
有些参数为:public void execute(@Param("systemVersion") String systemVersion,HttpServletRequest request, HttpServletResponse response, Context context, Navigator nav),说明如下:第一个参数为传进来的信息,context对象负责页面渲染时部分数据的修改。

(2)实现form表单功能
实现用户账号登陆的功能,如果用户不输入则提示用户输入相关信息,效果如下:【重要】WebX框架解析及使用教程之一

【重要】WebX框架解析及使用教程之一

其具体代码如下:
login.vm文件:
【重要】WebX框架解析及使用教程之一
form.xml文件:
【重要】WebX框架解析及使用教程之一

关键点说明如下:
1.【重要】WebX框架解析及使用教程之一 
这表示提交之后执行的是LoginAction.java,这里的value值login_action在程序内部会被处理成 LoginAction,因此这里如果写成value="LoginAction",结果是一样的

2.【重要】WebX框架解析及使用教程之一
这里提交后表示执行的方法是doUserInfoSumbit方法,如果你要执行其他方法请修改name值name="event_submit_你的方法"

3.关联form.xml:首先 #set ($group = $form.loginInfoGroup.defaultInstance)[固定写法,loginInfoGroup对应form.xml中的services:group name="loginInfoGroup"],然后
 【重要】WebX框架解析及使用教程之一
name对应到form.xml中的规则,group.username.message就是需要显示的错误信息。

4.$csrfToken.hiddenField是必须要添加的,防止跨站请求伪造攻击。如果不添加的话,数据是不会从显示层传送给JAVA层的。

(3)实现form表单往JAVA层传送数据功能
1、构造与表单对应的类LoginInfo:
package com.yunos.tv.openbase.biz.dataobject;

public class LoginInfo {
private String username;
private String password;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}

}
、1q     其中username和password的值需要和form.xml中定义的保持一致,否则两者无法建立联系。
(2)   2.编辑业务功能LoginAction.java:
     
import com.alibaba.citrus.turbine.dataresolver.FormGroup;
import com.yunos.tv.openbase.biz.dataobject.LoginInfo;

public class LoginAction {

public void doUserInfoSumbit(@FormGroup("loginInfoGroup")LoginInfo userLoginInfo, HttpServletResponse response, Context context, Navigator nav) throws Exception{
System.out.println("hello");
System.out.println(userLoginInfo.getUsername());
   3.     
            3.如果数据模型LoginInfo和LoginAction不在同一个工程中,则LoginAction应该探测不到LoginInfo.class,需要LoginInfo先编译生成class文件,然后LoginAction才可以使用LoginInfo类。在LoginInfo所在的工程使用mvn clean install命令重新进行编译,然后在LoginAction刷新下引入该类。

http://chatgpt.dhexx.cn/article/XdkkOwEi.shtml

相关文章

VSCode中Emmet使用

文章目录 HTML部分1. 添加类,id,文本和属性2. 嵌套和分组3. 隐式标签4. 定义多个元素* 和 编号$5. 添加虚拟文字6. 其它 CSS部分1. 属性和属性值的缩写2. 属性值的单位其它 HTML部分 1. 添加类,id,文本和属性 div.box#box > …

linux vim emmet,emmet-vim

最近啊,我投奔了网页的开发,看了一本《head first HTML and CSS》的书,感觉非常不错,然后又配置了一些vim里面用到的插件,现在我把学习到的东西记录下来! 首先,我不会在这里写emmet 的具体操作方…

Emmet 语法

Emmet语法前身是Zen coding,来提高html和css的编写速度,vscode内部已经集成该语法了 1、快速生成html结构语法 生成标签: 直接输入标签名,再按TAB键,such as 你打个 div 再按tab,就会直接生成 (这里打不出…

emmet写法

1.写一个递增的img路径 img[srcimage/com/$$.png]*10 效果

6.Emmet 语法与快速格式化代码

Emmet语法可以让我们在写网页的时候速度更快,我当前写网页的工具是pycharm,在pycharm中使用Emmet,我们需要点击File,然后点击Setting 搜索emmet,保证这里是勾选状态 安装后如果不进行其他设置,emmet自动被勾选 目录 …

Emmet语法总结

1 Emmet简介 Emmet是一个Web开发工具,用于加快HTML和CSS代码的编写速度。使用Emmet能够通过简短的表达式生成HTML或CSS代码片段。另外,截至2022年,主流的编辑器工具如Visual Studio Code、WebStorm都已经集成了Emmet工具,无需手动…

Linux 配置全面讲解(安装JDK、Mysql、Nginx)

1 Linux概述 1.1 Linux介绍 Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思…

【JAVA秒会技术之ConcurrentHashMap】JDK1.7与JDK1.8源码区别

前言 以前写过介绍HashMap的文章,文中提到过HashMap在put的时候,插入的元素超过了容量(由负载因子决定)的范围就会触发扩容操作,就是rehash,这个会重新将原数组的内容重新hash到新的扩容数组中,…

安装笔记--eclipse+jdk+neo4j安装与配置

1.eclipse安装2.JDK安装3.环境变量配置4.在eclipse中创建与导入项目4-1 eclipse导入项目 5.neo4j配置 1.eclipse安装 第一步:下载eclipse,并安装。 下载链接: http://www.eclipse.org/downloads/. 点击 Download Packages; 如图:根据自己的…

JDK7与JDK8中HashMap的实现

JDK7中的HashMap HashMap底层维护一个数组&#xff0c;数组中的每一项都是一个Entry transient Entry<K,V>[] table;我们向 HashMap 中所放置的对象实际上是存储在该数组当中&#xff1b; 而Map中的key&#xff0c;value则以Entry的形式存放在数组中 static class En…

VirtualBox虚拟机安装CentOS,安装jdk

CentOS 安装&#xff0c;安装jdk 1. CentOS 简介 CentOS 是一个基于Red Hat Linux 提供的可自由使用源代码的企业级Linux发行版本。每个版本的 CentOS都会获得十年的支持&#xff08;通过安全更新方式&#xff09;。新版本的 CentOS 大约每两年发行一次&#xff0c;而每个版本…

JDK1.7安装及校验

JDK的全称是JavaSE Development Kit&#xff0c;即java开发工具包&#xff0c;是sun公司提供的一套用于开发java应用程序的开发包&#xff0c;它提供了编译、运行java程序所需的各种工具和资源&#xff0c;包括java编译器、java运行时环境&#xff0c;以及常用的java类库等。 …

JVM调优(jdk8)与垃圾回收器详解

JVM调优与垃圾回收器详解 这张是jdk8的jvm模型&#xff1a; 黄色框的是线程共享区域、蓝色框的是线程私有(也就是每个线程单独一份) jvm模型从大的角度说有&#xff1a;类装载子系统、字节码执行引擎、运行时数据区。我这里主要讲运行时数据区。 一、JVM内存模型 1、名词解释…

下载并安装JDK7

JDK的全称是JavaSE Development Kit&#xff0c;即java开发工具包&#xff0c;是sun公司提供的一套用于开发java应用程序的开发包&#xff0c;它提供了编译、运行java程序所需的各种工具和资源&#xff0c;包括java编译器、java运行时环境&#xff0c;以及常用的java类库等。 …

VMware虚拟机安装以及在虚拟机上安装JDK+Tomcat+MySQL

1. VMware虚拟机安装 注意&#xff1a;最好不要安装在C盘&#xff0c;会使电脑变得很卡。 注意&#xff1a;这里去掉“启动时检查产品更新”&#xff0c;每次启动更新麻烦&#xff0c;影响效率。 下一步&#xff0c;直到&#xff1a; 点击“许可证”&#xff0c;输入许可证…

spark 安装部署与介绍

spark spark 概述一. spark和hadoop二. 应用常景和解决生态系统组件应用场景Spark执行任务流程图 三. Spark安装四. Spark部署模式1、单机本地模式&#xff08;Spark所有进程都运行在一台机器的JVM中&#xff09;2、伪分布式模式 &#xff08;在一台机器中模拟集群运行,相关的…

TLS协议与JDK版本之间微妙的关系

TLS协议与JDK版本之间微妙的关系 首先想知道TLS协议与JDK版本之间微妙的关系&#xff0c;就必须知道什么是TLS协议&#xff1f; 维基百科是这样说的&#xff1a; 传输层安全性协定&#xff08;英语&#xff1a;Transport Layer Security&#xff0c;缩写作TLS&#xff09;&…

linux jdk免安装配置,生产环境免安装jdk的使用方法

以下为《生产环境免安装jdk的使用方法》的无排版文字预览&#xff0c;完整格式请下载 下载前请仔细阅读文字预览以及下方图片预览。图片预览是什么样的&#xff0c;下载的文档就是什么样的。 使用流程 一、概述 医院的生产环境可能已经安装过jdk&#xff0c;如果jdk的版本不是1…

jdk1.8的安装教程

1、下载java1.8 URL: http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 下载eclipse URL: http://www.onlinedown.net/soft/558304.htm 下载并安装maven地址&#xff1a; http://maven.apache.org/download.html 先选择Accept&…

在linux上安装jdk

1. 概述 此篇主要向你介绍如何一步一步的在linux环境上面安装jdk&#xff0c;包括jdk的下载、安装、和环境变量的配置。 2. 概念 2.1.JDK(Java Development Kit) 它是 Java 语言的软件开发工具包(SDK)。 JDK包含的基本组件包括&#xff1a; javac – 编译器&#xff0c;…