1原生Portlet开发

这是最简单、最本质的开发方式,直接基于Portlet规范定义的接口开发Portlet。优点是贴近底层比较灵活,
缺点当然就是所有事情都要自己去做。就好比不用SpringMVC、Struts,直接基于Servlet开发一样。
这种方式比较适合自己开发Portlet框架。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
public class NativePortlet implements Portlet {
 
    private Logger logger = LoggerFactory.getLogger(NativePortlet.class);
 
    private PortletConfig config;
 
    @Override
    public void init(PortletConfig portletConfig) throws PortletException {
        logger.info("初始化Portlet");
        this.config = portletConfig;
    }
 
    @Override
    public void processAction(ActionRequest actionRequest, ActionResponse actionResponse) throws PortletException, IOException {
        logger.info("处理Action动作");
 
        logger.info("接收到POST请求,用户名为[{}]", actionRequest.getParameter("userName"));
    }
 
    @Override
    public void render(RenderRequest renderRequest, RenderResponse renderResponse) throws PortletException, IOException {
        logger.info("处理Render动作");
 
        WindowState state = renderRequest.getWindowState();
        if (state.equals(WindowState.MINIMIZED)) {
            return;
        }
 
        // doDispatch();
        PortletMode mode = renderRequest.getPortletMode();
        if (PortletMode.VIEW.equals(mode)) {
            // doView();
            String normalPage = config.getInitParameter("ViewPage");
            if (WindowState.NORMAL.equals(state)) {
                this.include(renderRequest, renderResponse, normalPage);
            else {
                this.include(renderRequest, renderResponse, "");
            }
        else if (PortletMode.EDIT.equals(mode)) {
            // doEdit();
        else if (PortletMode.HELP.equals(mode)) {
            // doHelp();
        else {
            throw new PortletException("unknown portlet mode: " + mode);
        }
    }
 
    @Override
    public void destroy() {
        logger.info("销毁Portlet");
    }
 
    private void include(RenderRequest request, RenderResponse response, String viewPage) throws PortletException, IOException {
        response.setContentType("text/html");
        PortletContext context = config.getPortletContext();
        PortletRequestDispatcher requestDispatcher = context.getRequestDispatcher(viewPage);
        requestDispatcher.include(request, response);
    }
 
}

可以看到,在render()方法中,我们要自己处理不同Portlet模式(View,Edit,Help等)的渲染,根据需要做分发。
诸如此类的各种细节都需要我们自己去制定规则,自己处理。

2注解Portlet开发

Portlet规范也提供了注解的方式来开发Portlet。这样不用依赖SpringMVC Portlet等第三方框架,
也能比较方便的开发Portlet,又不用处理特别底层的实现细节。来看一个例子。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
public class AnnotatedPortlet extends GenericPortlet {
 
    private Logger logger = LoggerFactory.getLogger(AnnotatedPortlet.class);
 
    /**
     * 进入主页面(View模式)
     * @param request
     * @param response
     * @throws Exception
     */
    @RenderMode(name = "view")
    public void toIndexPage(RenderRequest request, RenderResponse response) throws Exception {
        getPortletContext().
                getRequestDispatcher(getInitParameter("ViewPage")).
                    include(request, response);
    }
 
    /**
     * 保存用户名
     * @param request
     * @param response
     */
    @ProcessAction(name = "saveUsername")
    public void saveUsername(ActionRequest request, ActionResponse response) {
        String userName = request.getParameter("userName");
 
        logger.info("保存用户名[{}]", userName);
    }
 
    /**
     * 保存电子邮件地址
     * @param request
     * @param response
     */
    @ProcessAction(name = "saveEmail")
    public void saveEmail(ActionRequest request, ActionResponse response) {
        String email = request.getParameter("email");
 
        logger.info("保存Email[{}]", email);
    }
 
}

使用@RenderMode注解定义不同模式下,Portlet渲染的实现方法。@ProcessAction注解可以根据动作名称,
直接将请求交给标有注解的方法去处理,不用我们自己去实现根据注解分发请求的代码了。

附:其他代码

页面代码如下。使用Portlet规范中定义的标签产生ActionUrl。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<%@ page language="java" contentType="text/html; charset=UTF-8"
         pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jstl/fmt" prefix="fmt"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%>
<%@ taglib uri="http://java.sun.com/portlet_2_0" prefix="portlet"%>
<portlet:defineObjects />
 
<h3>这是一个演示FORM表单和AJAX提交的示例程序</h3>
 
<!-- FORM表单提交实例 -->
<form action='<portlet:actionURL name="saveUsername"/>' method="POST">
    <tr>
        <td>用户名:</td>
        <td><input name="userName" type="text" /></td>
    </tr>
    <tr>
        <td><input type="submit" value="表单提交" /></td>
    </tr>
</form>
 
<!-- AJAX提交实例 -->
<tr>
    <td>Email:</td>
    <td><input id="email" type="text"/></td>
</tr>
<tr>
    <input id="ajaxBtn" type="button" value="AJAX提交" />
</tr>
<script>
    $(".ajaxBtn").bind("click", function () {
        var email = $(".email").valueOf();
 
        jQuery.ajax({
            type: "GET",
            async: true,
            url: '<portlet:actionURL name="saveEmail" />',
            dataType: 'json',
            data: {
                "email": email
            },
            success: function (data) {
                alert(data);
            },
            error: function (data, status, e) {
                alert(e);
            },
            beforeSend: function () {
            },
            complete: function () {
            }
        });
    });
</script>

Portlet开发入门实例的更多相关文章

  1. IOS开发入门实例

    关于如何创建第一个 iOS 应用 本篇“第一个 iOS 应用”教程将向你介绍 iOS 应用开发中的“三个T”: Tools(工具)如何利用 Xcode 创建和管理工程. Technologies(技术 ...

  2. 【转】Android NDK开发入门实例

    写这个,目的就是记录一下我自己的NDK是怎么入门的.便于以后查看,而不会忘了又用搜索引擎一顿乱搜.然后希望能够帮助刚学的人入门. 先转一段别人说的话:“NDK全称:Native Development ...

  3. java web 开发入门实例

    学习是个技巧活,关键是要找到重点的地方,新手在这方面的坑尤其多.看别人的教程一步一步的跟着做,隔几步就遇到一个新知识点,忍不住就百度往深处了解,一晃半天就过去了. 有的知识点要深入学习的,有的是了解下 ...

  4. ArcgisAdd-In开发入门实例

    1.开发环境 Vs2012+Arcgis10.2+win7 64bit 2.实现代码 首先在VS2012中新建一个解决方案,命名AddInTest. 接着,给解决方案AddInTest新建一个项目: ...

  5. Android NDK开发入门实例

    AndroidNDK是能使Android应用开发者把从c/c++编译而来的本地代码嵌入到应用包中的一系列工具的组合. 注意: AndroidNDK只能用于Android1.5及以上版本中. I. An ...

  6. Arcgis Add-In开发入门实例

    作为一个本科侧重于应用,工作之后却做了开发的程序员来说,做GIS,开发应该是一门必修课,只是,苦于各种原因吧,做GIS应用的人会开发的很少,做GIS开发的大部分都是计算机出身,痛心疾首啊-- 不好意思 ...

  7. Eclipse_luna_J2EE_For_JS+tomcat8.0环境搭建、配置、开发入门

    一.所有需要的软件.插件等下载地址 J2SE的官方下载路径:http://www.oracle.com/technetwork/java/javase/downloads/index.html Ecl ...

  8. destoon入门实例与常见问题

    收集了一些destoon入门实例与常见问题,大家做个参考. 链接如下: destoon忘记后台密码怎么办?destoon找回管理员密码 忘记destoon管理员后台账号密码怎么办?解决方法 desto ...

  9. Spark+ECLIPSE+JAVA+MAVEN windows开发环境搭建及入门实例【附详细代码】

    http://blog.csdn.net/xiefu5hh/article/details/51707529 Spark+ECLIPSE+JAVA+MAVEN windows开发环境搭建及入门实例[附 ...

随机推荐

  1. 【Codeforces Round 431 (Div. 2) A B C D E五个题】

    先给出比赛地址啦,感觉这场比赛思维考察非常灵活而美妙. A. Odds and Ends ·述大意:      输入n(n<=100)表示长度为n的序列,接下来输入这个序列.询问是否可以将序列划 ...

  2. hdu5587 BestCoder Round #64 (div.2)

    问题描述 Vicky是个热爱数学的魔法师,拥有复制创造的能力. 一开始他拥有一个数列{1}.每过一天,他将他当天的数列复制一遍,放在数列尾,并在两个数列间用0隔开.Vicky想做些改变,于是他将当天新 ...

  3. Ubuntu 16.04 LTS安装搜狗拼音输入法网易云音乐 Remarkable

    第一步 首先在官网上面,下载最新的搜狗拼音输入法 Linux 版本. 第二步 进入命令行 Ctrl+Alt+T sudo dpkg -i sogoupinyin_2.1.0.0082_amd64.de ...

  4. java的数据结构

    常见的数据结构 线性表(list) 1.有序列表,就像小朋友排队(一队)放学出校门,插入的顺序作为遍历的顺序,位置不变(长度固定)  2.顺序存储:从起始位置开始依次向后存储,查询方便,但是插入(排队 ...

  5. StarSpace是用于高效学习实体向量的通用神经模型

    StarSpace是用于高效学习实体向量的通用神经模型,用于解决各种各样的问题: 学习单词,句子或文档级嵌入. 文本分类或任何其他标签任务. 信息检索:实体/文件或对象集合的排序,例如 排名网络文件. ...

  6. 清空dataset中的某行某列的数据

    string tempSFZH = ""; foreach (DataRow rs in ds.Tables[0].Rows) {     tempSFZH = rs[ht[&qu ...

  7. 关于return的一些了解

    写return是一种清晰的风格,可以防止一些意外的错误. 所以书上只说应该写,而不是必须写. 如果符合某个条件要退出的话,可以用return返回,否则可以不写这句代码的,当程序执行到"}&q ...

  8. Servlet技术 Cookie与Session

    会话过程:用户打开浏览器,点击链接访问资源,最后到关闭浏览器的整个过程称之为会话. 会话使用:与服务器进行会话的过程中产生数据,数据被保存下来,服务器根据数据对客户进行辨别,做出个性化的响应. 介绍两 ...

  9. MySQL查看数据库信息

    使用MySQL时,需要了解当前数据库的情况,例如当前的数据库大小.字符集.用户等等.下面总结了一些查看数据库相关信息的命令 1:查看显示所有数据库 mysql> show databases; ...

  10. 浏览器本地下拉框查询选择js

    首先需要引用jquery-1.7.2.js. 页面下拉框有对应的数据,此下拉框的查询将不与服务器交互.本地下拉框查询.暂不支持通过键盘上下按键和enter键控制 // JavaScript Docum ...