WebSphere-Portlet开发知识积累

本文分享了 WebSphere Portlet 开发中的实用技巧,包括 JavaBean 的使用、页面编码设置、状态保存方法、超链接及图片路径的正确写法等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转帖自  http://hi.baidu.com/hivemind/blog/item/1c3efb43ba8d301372f05d16.html

 

WebSphere-Portlet开发知识积累

 

1 javabean的写法
- java页面的代码:
public void doView(RenderRequest request, RenderResponse response)
                                   throws PortletException, IOException {
    request.setAttribute("username","liuzhaoy ##################");
}
- jsp页面的写法
 <jsp:useBean id="username" class="java.lang.String" scope="request"></jsp:useBean>
 <%=username %>
- 展示结果10bfd7ad207.jpg

2 页面编码的写法
<%@ page import="javax.portlet.*, java.util.*" session="false"%>
<%@ taglib uri="http://java.sun.com/portlet" prefix="portletAPI" %>

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" %>
如果让其支持汉语,就改为:gb2312喽,呵呵。

3 图片路径的写法
<IMG src="<%=renderRequest.getContextPath()%>/testportlet/images/mark.gif"><br>
<IMG src="<%=renderResponse.encodeURL(renderRequest.getContextPath()+"/testportlet/images/mark.gif")%>">
其中renderResponse.encodeURL表示编码。目录结构截图:

10bff7a0e02.jpg
4 状态的保存
怎么让一个textbox框保持其状态呢,就是输入框里的内容在点击提交按钮后信息不会丢失。
jsp文件
<jsp:useBean id="saveUrl" scope="request" class="java.lang.String"></jsp:useBean>
<jsp:useBean id="username" class="java.lang.String" scope="request"></jsp:useBean>
<FORM method="post" action="<%=saveUrl %>">
<INPUT size="20" type="text" name="username" value="<%=username %>">
<input type="submit" name="save" value="Save"/>
</FORM>
--------------------------
java文件
声明一个变量:
private String UN=null;
在doView()方法如下:
public void doView(RenderRequest request, RenderResponse response) throws PortletException, IOException {
  request.setAttribute("username",UN);
  PortletURL saveUrl=response.createActionURL();
  saveUrl.setParameter("save","save222");
  request.setAttribute("saveUrl",saveUrl.toString());
}
--------------------------
processAction()方法:
public void processAction(ActionRequest request, ActionResponse response) throws PortletException, java.io.IOException {
  String saveStr=request.getParameter("save");
  System.out.println(saveStr);
  if(saveStr!=null){
//   PortletPreferences prefs=request.getPreferences();
//   prefs.setValue("userName",request.getParameter("username"));
//   prefs.store();
   String username=request.getParameter("username");
   UN=username;
  }
}
这样当点击Save按钮时,触发processAction()方法,给UN负值,即UN=username;然后doView()事件触发,在这里,给username负值UN,然后在jsp中用javabean接收即可,即:<jsp:useBean id="username" class="java.lang.String" scope="request"></jsp:useBean>如图:10bff8aa287.jpg另外,如果在doView()中写了request.setAttribute("username",UN); 在jsp中用<%=renderRequest.getAttribute("username")%>可以直接接收的到,用这样的方法保存状态可能更简单些。:)
另外一种更简单的写法:
java文件的processAction()方法中:
if( request.getParameter(FORM_SUBMIT) != null ) {
    response.setRenderParameter("saveValue",saveValue);
}
在jsp中直接接收即可:
<INPUT name="<%=Portlet01Portlet.FORM_TEXT%>" type="text" value="<%=request.getParameter("saveValue") %>"/>

5. 超链接的写法
超链接这个东西折磨了我好久,今天终于把它解决掉了。超链接主要使用renderURL来解决。可以这样理解,renderURL是actionURL的一种优化,Portlet开发过程中尽可能使用renderURL而避免使用actionURL,actionURL使用于确实有Action行为的情况,比如说,form标单的提交,persistent状态的改变,session的操作,preference的修改等。而renderURL通常用来操作portlet内容的导航。
renderURL的写法有两种。
1.使用标签
<portlet:renderURL var="pu2">
<portlet:param name="testURL" value="testURL2"/>
</portlet:renderURL>
我的超链接:&nbsp;&nbsp;<A href="<%=pu2%>">viewURL</A>

当然,这种情况必须引入:<%@ taglib uri="http://java.sun.com/portlet" prefix="portlet" %>这个标签定义了。
2.写程序
<%
PortletURL pu=renderResponse.createRenderURL();
pu.setParameter("testURL","urlTest");
 %>
<A href="<%=pu %>">testHref</A>
3. 直接使用标签
<%
String dd="hello portal";
%>
<A href="<portlet:renderURL><portlet:param name="startPos" value="<%=dd %>"/></portlet:renderURL>"><%=dd%></A>
不管那种写法,都会触发render()函数,此函数是父类GenericPortlet的一个方法,这里属于覆盖。如下:
 public void render(RenderRequest request, RenderResponse response)
   throws PortletException, IOException {
//  super.render(request, response);
  String markValue=request.getParameter("mark");
  PortletContext context=getPortletConfig().getPortletContext();
  if(markValue!=null){
   if(markValue.toString().equals("test01")){
    context.getRequestDispatcher("/portlet01/webApp/test01.jsp").include(request,response);
   }
   else if(markValue.equals("homepage")){
    request.setAttribute("saveValue",saveValue);
    context.getRequestDispatcher("/portlet01/jsp/html/Portlet01PortletView.jsp").include(request,response);
   }
   else if(markValue.equals("test02_new")){
    if(request.getParameter("mark_test02")!=null){
     request.setAttribute("hasButton","true");
    }
    context.getRequestDispatcher("/portlet01/webApp/test02.jsp").include(request,response);
   }
  }
  else{
    doView(request,response);
  } 
}
根据设置的testURL参数值,来判断链接的文件。

5. 获取portlet.xml中的初始值:
 public void doView(RenderRequest request, RenderResponse response) throws PortletException, IOException {
  System.out.println(getPortletConfig().getInitParameter("view"));
 }
---------------------------
portlet.xml文件
  <init-param>
   <name>view</name>
   <value>/fragments/portletrequest/view_portletrequest.jsp</value>
  </init-param>
系统会打印出/fragments/portletrequest/view_portletrequest.jsp来,这样,可以把一些值放到这里面在程序中获取。

6. 用renderRequest负值,在jsp页面直接接收
java页面
public void render(RenderRequest request, RenderResponse response)
   throws PortletException, IOException {
    String viewParam=request.getParameter("linkParam2");
    request.setAttribute("voteResult_titleID",viewParam);
}
jsp页面
<%
out.println("----"+request.getAttribute("voteResult_titleID"));
%>

7. Action提交时保持跳转状态
jsp页面
<form name="form1" method="post" action="<portlet:actionURL><portlet:param name="jumpPath" value="<%=request.getRequestURI() %>"/><portlet:param name="inquireIdAnswerQuestion" value="<%=inquireIdStr %>"/></portlet:actionURL>" onsubmit="return answerSubmit(this)">

   <input type="submit" name="inquireAnswerQuestion" value="保 存" class="font13">

</form>
--------------------------
java页面
public void processAction(ActionRequest request, ActionResponse response) throws PortletException, java.io.IOException {
  if(request.getParameter("inquireAnswerQuestion")!=null){
      String jump_Path=request.getParameter("jumpPath");
      String idInquireStr=request.getParameter("inquireIdAnswerQuestion"); //获取ID编号
      response.setRenderParameter("inquireID",idInquireStr);
      System.out.println(idInquireStr);
      jumpPath=rtnPath(jump_Path);
  }

}

 private String rtnPath(String path){
  int dealPathDivideDot=path.indexOf("/vote/");
  String jumppath=path.substring(dealPathDivideDot);
  return jumppath;
 }

public void render(RenderRequest request, RenderResponse response)
   throws PortletException, IOException {
   if(jumpPath!=null){
    String voteTitleId=request.getParameter("voteTitleID");
    context.getRequestDispatcher(jumpPath).include(request,response); 
   }
}
这里主要的思想就是通过<%=request.getRequestURI() %>获取本页的路径,然后通过<portlet:param name="jumpPath" value="<%=request.getRequestURI() %>"/> 进行参数传递,注意<portlet:actionURL>的参数传递方式和<portlet:renderURL>是一样的,然后再在processAction()中通过String jump_Path=request.getParameter("jumpPath");进行接收,给公共变量jumpPath负值后,在render()中就完成了跳转。
--------------------------
新认知例子
1.怎么让页面上的renderRequest不会出现出错提示呢,经过这样类型转换后即可
RenderRequest renderRequest =(RenderRequest)request.getAttribute("javax.portlet.request");
RenderResponse renderResponse =(RenderResponse)request.getAttribute("javax.portlet.response");
PortletConfig portletConfig =(PortletConfig)request.getAttribute("javax.portlet.config");

原来用问号的方式也可以传递参数,不错
Code in the portlet
String path = "/jsptest/jsp/html/testCase.jsp?name=Hailey";
PortletRequestDispatcher rd = getPortletContext().getRequestDispatcher(path);
rd.include(request,response);
Code in JSP
Hello <%= renderRequest.getParameter("name") %>

JSTL标签,用它可以读属性文件,不错,避免把一些东东写死在java文件里,便于管理
<%@ taglib uri="http://java.sun.com/jstl/fmt" prefix="fmt" %>
<fmt:setBundle basename="nls.NLSExample"/>
<fmt:message key="message"/>

内容概要:本文深入探讨了Kotlin语言在函数式编程和跨平台开发方面的特性和优势,结合详细的代码案例,展示了Kotlin的核心技巧和应用场景。文章首先介绍了高阶函数和Lambda表达式的使用,解释了它们如何简化集合操作和回调函数处理。接着,详细讲解了Kotlin Multiplatform(KMP)的实现方式,包括共享模块的创建和平台特定模块的配置,展示了如何通过共享业务逻辑代码提高开发效率。最后,文章总结了Kotlin在Android开发、跨平台移动开发、后端开发和Web开发中的应用场景,并展望了其未来发展趋势,指出Kotlin将继续在函数式编程和跨平台开发领域不断完善和发展。; 适合人群:对函数式编程和跨平台开发感兴趣的开发者,尤其是有一定编程基础的Kotlin初学者和中级开发者。; 使用场景及目标:①理解Kotlin中高阶函数和Lambda表达式的使用方法及其在实际开发中的应用场景;②掌握Kotlin Multiplatform的实现方式,能够在多个平台上共享业务逻辑代码,提高开发效率;③了解Kotlin在不同开发领域的应用场景,为选择合适的技术栈提供参考。; 其他说明:本文不仅提供了理论知识,还结合了大量代码案例,帮助读者更好地理解和实践Kotlin的函数式编程特性和跨平台开发能力。建议读者在学习过程中动手实践代码案例,以加深理解和掌握。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值