<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-124  評(píng)論-49  文章-56  trackbacks-0
      2011年5月30日
         摘要: JSF學(xué)習(xí)筆記   JSF事件驅(qū)動(dòng)型的MVC框架,與流行的struts比較學(xué)習(xí),易于理解。jsf component event事件是指從瀏覽器由用戶操作觸發(fā)的事件,Struts application event 是用Action來接受瀏覽器表單提交的事件,一個(gè)表單只能對(duì)應(yīng)一個(gè)事件,application event和component event相比是一種粗粒度的事件。優(yōu)點(diǎn):事件...  閱讀全文
    posted @ 2011-05-30 21:48 junly 閱讀(1275) | 評(píng)論 (2)編輯 收藏
    Struts2 的UITag原理:
    Struts2 UITag分三部份組成,一部份用于定義Tag的內(nèi)容與邏輯的UIBean,一部份用于定義JSP Tag,也就是平時(shí)我們定義的那種,最后就是Template,它存放在你的theme目錄之下,是一個(gè)FreeMarker模板文件。

    我現(xiàn)在輯寫一份MMTag,它主要是用于輸出帶鏈接的文字,比如像這樣:
    <cur:mm message="'I am a boy.'" />
    就會(huì)輸出:
    <a href="http://www.tkk7.com/natlive">I am boy.</a>

    我們先寫UIBean部份:我們把它定義為MM,它繼承于 org.apache.struts2.components.UIBean:

    package limitstudy.corestruts2.tag;

    import org.apache.struts2.components.UIBean;
    import org.apache.struts2.views.annotations.StrutsTag;
    import org.apache.struts2.views.annotations.StrutsTagAttribute;
    import com.opensymphony.xwork2.util.ValueStack;

    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;

    @StrutsTag(name="mm", tldTagClass="limitstudy.corestruts2.tag.MMTag", description="MM")
    public class MM extends UIBean {
        private String message;

        public MM(ValueStack stack, HttpServletRequest request, HttpServletResponse response) {
            super(stack, request, response);
        }

        @Override
        protected String getDefaultTemplate() {
            return "mm";
        }

        @StrutsTagAttribute(description="set message", type="String")
        public void setMessage(String message) {
            this.message = message;
        }

        @Override
        protected void evaluateExtraParams() {
            super.evaluateExtraParams();

            if (null != message) {
                addParameter("message", findString(message));
            }
        }
    }


    * strutsTag注解指明了該UIBean的名字 和Tag類的類名。
    * getDefaultTemplate()方法用于返回模板的名 字,Struts2會(huì)自動(dòng)在后面加入.ftl擴(kuò)展名以找到特定的模板文件。
    * setXXX,設(shè)置UIBean的屬性,一般Tag中有幾個(gè)這樣的屬性,這里就有幾個(gè)。@StrutsTagAttribute(description="set message", type="String") 注解,說明該屬性是字符串(也可以是其它),這一步很重要。
    * 覆寫evaluateExtraParams() 方法,在UIBean初始化后會(huì)調(diào)用這個(gè)方法來初始化設(shè)定參數(shù),如addParameter方法,會(huì)在freemarker里的parameters里加 入一個(gè)key value。這里要注意findString,還有相關(guān)的findxxxx方法,它們是已經(jīng)封裝好了的解釋ognl語法的工具,具體是怎么樣的,大家可以 查看一下UIBean的api doc。

    然后是Tag部份:

    package limitstudy.corestruts2.tag;

    import org.apache.struts2.views.jsp.ui.AbstractUITag;
    import org.apache.struts2.components.Component;
    import com.opensymphony.xwork2.util.ValueStack;

    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;

    public class MMTag extends AbstractUITag {
        private String message;

        @Override
        public Component getBean(ValueStack stack, HttpServletRequest request, HttpServletResponse response) {
            return new MM(stack, request, response);
        }

        @Override
        protected void populateParams() {
            super.populateParams();

            MM mm = (MM)component;
            mm.setMessage(message);
        }

        public void setMessage(String message) {
            this.message = message;
        }
    }


    * getBean()返回該Tag中的UIBean。
    * populateParams()初始化參數(shù),一般用來初始化UIBean(Component)。
    * setXXXX設(shè)置屬性,和jsp tag是一樣的。

    在/WEB-INF/tlds/下建立current.tld文件(文名隨你喜歡):

    <?xml version="1.0" encoding="UTF-8"?>
    <taglib xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.0"
            xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd">
        <description>test</description>
        <tlib-version>2.0</tlib-version>
        <short-name>cur</short-name>
        <uri>/cur</uri>

        <tag>
            <name>mm</name>
            <tag-class>limitstudy.corestruts2.tag.MMTag</tag-class>
            <body-content>JSP</body-content>
            <attribute>
                <name>message</name>
                <required>true</required>
            </attribute>
        </tag>
    </taglib>


    在源代碼目錄中建立template/simple目錄(這個(gè)目錄名和你的theme有關(guān)),然后在里面建一個(gè) mm.ftl文件:

    <href="http://www.yinsha.com">${parameters.message?html}</a>


    建一個(gè)action測(cè)試一下,視圖文件:

    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <%@ taglib prefix="s" uri="/struts-tags" %>
    <%@ taglib prefix="cur" uri="/cur" %>
    <html>
    <head>
        <title><s:property value="message" /></title>
    </head>
    <body>
    <cur:mm message="haoahahhahaha" />
    </body>
    </html>


    完。

    PS: 寫得有些粗鄙,所以,如有問題的,可以留言。

     

     

     

    http://devilkirin.javaeye.com/blog/427395

    http://xiaojianhx.javaeye.com/blog/482888
    posted @ 2011-05-30 21:43 junly 閱讀(1133) | 評(píng)論 (1)編輯 收藏

    Page


    The following is register.jsp, which takes required information from user regarding registration. For this example, we focus only on validation of username and not the actual registration process.

    The most important thing is to know how to access JSF component from JQuery. The id given to inputText is consisting of formid:componentid. So in this example the id given to textbox is  registerform:username. But the presence of : (colon) causes problem to JQuery. So, we need to escape : (colon) using two \\ characters before colon - registerform\\:username.

    //register.jsp
    <%@page contentType="text/html" %>de">

    <%@page contentType=
    "text/html" %>
    <!DOCTYPE HTML PUBLIC 
    "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
    <html>
        
    <head>
            
    <script language="javascript" src="jquery-1.4.2.js"></script>
            
    <script language="javascript">
                
    function checkUsername(){
                    $.get( 
    "checkusername.jsp",{username : $("#registerform\\:username").val()},updateUsername);
                }
                
    function updateUsername(response)
                {
                    
    if (response) {
                        $(
    "#usernameresult").text(response);  // update SPAN item with result
                }
            
    </script>
            
    <title>Registration</title>
        
    </head>
        
    <body>
            
    <%@taglib prefix="f" uri="http://java.sun.com/jsf/core"%>
            
    <%@taglib prefix="h" uri="http://java.sun.com/jsf/html"%>
            
    <f:view>
               
    <h2>Registration </h2>
               
    <h:form  id="registerform">
               
    <table>
                        
    <tr>
                            
    <td>Username : </td>
                            
    <td><h:inputText id="username" value="#{userBean.username}"  required="true" onblur="checkUsername()" />
                                
    <h:message for="username" />
                                
    <span id="usernameresult" />
                        
    </tr>
                        
    <tr>
                            
    <td>Password : </td>
                            
    <td><h:inputSecret id="password" value="#{userBean.password}"  required="true" /> <h:message for="password" /> </td>
                        
    </tr>
                        
    <tr>
                            
    <td>Re-enter Password : </td>
                            
    <td><h:inputSecret id="confirmPwd" value="#{userBean.confirmPwd}"  required="true" /> <h:message for="confirmPwd" /> </td>
                        
    </tr>
                        
    <tr>
                            
    <td>Email Address  : </td>
                            
    <td><h:inputText id="email" value="#{userBean.email}" required="true" onblur="checkEmail()"  /> <h:message for="email" /> </td>
                                
    <span id="emailresult" />
                        
    </tr>
                   
    </table>
                                    
                  
    <p/>
                  
    <h:commandButton actionListener="#{userBean.register}" value="Register" />
                  
    <p/>
                  
    <h3><h:outputText value="#{userBean.message}" escape="false"  /> </h3>
                  
    <p/>
               
    </h:form>
            
    </f:view>
        
    </body>
    </html>lt;/f:view>
        
    </body>
    </html>

    Bean


    The above JSF Form uses userBean, which is the name given to beans.UserBean class. The class and its entries in faces-config.xml file are given below.
    UserBean is the managed bean that stores data coming from JSF form. It contains an action listener - register(), which is supposed to process the data to complete registration process. We don't deal with it as our focus is only on validating username.
    //UserBean.java
    package beans;

    public class UserBean {
        
    private String username, password, email,confirmPwd, message;

        
    public UserBean() {
        }

        
    public String getPassword() {
            
    return password;
        }

        
    public void setPassword(String password) {
            
    this.password = password;
        }

        
    public String getUsername() {
            
    return username;
        }

        
    public void setUsername(String username) {
            
    this.username = username;
        }

        
    public String getConfirmPwd() {
            
    return confirmPwd;
        }

        
    public void setConfirmPwd(String confirmPwd) {
            
    this.confirmPwd = confirmPwd;
        }

        
    public String getEmail() {
            
    return email;
        }

        
    public void setEmail(String email) {
            
    this.email = email;
        }

        
    public String getMessage() {
            
    return message;
        }

        
    public void setMessage(String message) {
            
    this.message = message;
        }

        
    public void  register(ActionEvent evt) {
           
    if (! password.equals(confirmPwd))
           {
                 message 
    = "Password do not match!";
                 
    return;
           }
           
    // do registration
        } // register
    }

    xml


    The following entry is required in faces-config.xml for UserBean managed bean.
    <!-- faces-config.xml -->
    <managed-bean>
            
    <managed-bean-name>userBean</managed-bean-name>
            
    <managed-bean-class>beans.UserBean</managed-bean-class>
            
    <managed-bean-scope>request</managed-bean-scope>
    </managed-bean>  

    Check

    Now create a checkusername.jsp to check whether given username is valid. It sends a message if username is already exists otherwise it sends empty string (nothing).
    <%@ page import="java.sql.*"  contentType="text/plain"%>
    <%
     String username 
    = request.getParameter("username");  // sent from client
     
    // connect to oracle using thin driver
     Class.forName("oracle.jdbc.driver.OracleDriver");
     Connection con 
    = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe","youruser","yourpassword");
     PreparedStatement ps 
    = con.prepareStatement("select username from users where username = ?");
     ps.setString(
    1,username);
     ResultSet  rs 
    = ps.executeQuery();
     
    if ( rs.next()) { // found username
        out.println("Username is already present!");  // send this to client
     }
     rs.close();
     ps.close();
     con.close();
    %>

    Deploy and Test

    Now deploy the web application and run register.jsp. If you enter a username that is already present in USERS table then we get message - Username is already present - in SPAN item on the right of username field. If username is unique then SPAN item is set to empty string ( as JSP returns nothing).

    from:http://www.srikanthtechnologies.com/blog/java/jquerywithjsf.aspx
    posted @ 2011-05-30 21:38 junly 閱讀(791) | 評(píng)論 (0)編輯 收藏
    主站蜘蛛池模板: 亚洲а∨天堂久久精品| 成人人免费夜夜视频观看| 7m凹凸精品分类大全免费| 国内精自视频品线六区免费| 一二三四免费观看在线电影| 国产美女精品视频免费观看 | 91精品成人免费国产片| 黄在线观看www免费看| 日本免费一区二区三区最新| 亚洲精品NV久久久久久久久久| 亚洲码国产精品高潮在线| 亚洲沟沟美女亚洲沟沟| 亚洲国产精品ⅴa在线观看| 一级免费黄色毛片| 99re在线这里只有精品免费| 毛片A级毛片免费播放| 亚洲免费无码在线| 久久精品国产亚洲av麻豆色欲| 在线观看亚洲AV每日更新无码| 男男黄GAY片免费网站WWW| 久久国产精品萌白酱免费| 国产在线国偷精品产拍免费| 亚洲国产a级视频| 亚洲高清美女一区二区三区| 在线观看亚洲专区| 午夜视频在线免费观看| 四色在线精品免费观看| 久久九九亚洲精品| 亚洲欧洲日韩极速播放| 成全视成人免费观看在线看| 免费可以看黄的视频s色| 亚洲免费在线观看| 亚洲AV无码国产精品色| 一区视频免费观看| 在线观看免费高清视频| 中文字幕亚洲乱码熟女一区二区| 亚洲国产综合自在线另类| eeuss草民免费| 亚洲成在人线aⅴ免费毛片| 亚洲小说区图片区另类春色| 国内精品久久久久影院亚洲|