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

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

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

    隨筆 - 11  文章 - 11  trackbacks - 0

    留言簿(2)

    隨筆分類(13)

    隨筆檔案(11)

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    在Struts1.1-1.2中如果不想沒有登錄的用戶訪問一些action,可以擴展RequestProcessor,并重載processProprocess方法,在其中進行驗證

    public class CustomRequestProcessor
            extends RequestProcessor {
        protected boolean processPreprocess (
                HttpServletRequest request,
                HttpServletResponse response) {
            HttpSession session = request.getSession(false);
            //If user is trying to access login page
            // then don't check
            if( request.getServletPath().equals("/loginInput.do")
                || request.getServletPath().equals("/login.do") )
                return true;
            //Check if userName attribute is there is session.
            //If so, it means user has allready logged in
            if( session != null &&
            session.getAttribute("userName") != null)
                return true;
            else{
                try{
                    //If no redirect user to login Page
                    request.getRequestDispatcher 
                        ("/Login.jsp").forward(request,response);
                }catch(Exception ex){
                }
            }
            return false;
        }
    }
    

    相應的,在struts-config.xml中加入controller元素

    <controller>
     <set-property  property="processorClass"
     value="com.sample.util.CustomRequestProcessor"/>
    </controller>
    

    但剛才看到在Struts1.3中,已經不再使用RequestProcessor,而是用ComposableRequestProcessor 來實現自定義的request響應。






    posted @ 2007-04-09 18:52 hijeff 閱讀(440) | 評論 (0)編輯 收藏

    三個@Entity類Tc, Tracer, Track是三向關聯的的表, @Embeddable類TcTracer則存儲著三個表的ForeignKey

    @Entity
    @Table(name= "tc", catalog="first_hiber")
    public class Tc {
          @org.hibernate.annotations.CollectionOfElements
          @JoinTable(name="tc_tracer", joinColumns=@JoinColumn(name="tc_id"))
          private Set<TcTracer> tcTracers = new HashSet<TcTracer>();
    
          @Id @GeneratedValue
          @Column(name="tc_id", nullable= false)
          private Long id;
    }
    
      @Embeddable
      @Table(name="tc_tracer")
      public class TcTracer {
          @org.hibernate.annotations.Parent
          private Tc tc;
      
    @ManyToOne(cascade=CascadeType.ALL) @JoinColumn(name="tracer_id", nullable=false, updatable=false) private Tracer tracer; @ManyToOne(cascade=CascadeType.ALL) @JoinColumn(name="track_id", nullable=false, updatable=false) private Track track; }

    如上,將TcTracer作為Tc的子元素,從而實現Tc的三相關聯。

    用HQL可以通過特定的Tc,Tracer得到對應的所有Track:

      select tctracers.track
      from Tc tc
          join tc.tcTracers tctracers
      where tc.name="tc name"
          and tctracers.tracer.name="tracer name"
    
     List<Track> tracks = session.createQuery(HQL).list();
    
    posted @ 2007-04-02 17:45 hijeff 閱讀(379) | 評論 (0)編輯 收藏

    今天調試程序的時候,發(fā)現插入數據時老是拋出異常:"a different object with the same identifier value was already associated with the session"

    起初以為是override hashCode()的方法不對。后來google查了查多數問題都出現在detached對象之后,再鏈接session由于對象的改變而出現的異常。

    最后發(fā)現原來問題很簡單....是在用annotation重寫mapping的時候,忘記給@Id加上@GeneratedValue,導致第一個row insert后,再次insert時沒有生成新的id!

    看來annotation雖然方便了mapping,但由于和代碼集中在一塊了,很容易出現疏忽大意的錯誤,而且一般都不會注意到-.-

    想起了python的SQLObject, SQLAlchemy,雖然功能沒有Hibernate豐富,但是簡單實用!

    posted @ 2007-03-29 20:28 hijeff 閱讀(407) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 国产a v无码专区亚洲av| 日韩欧毛片免费视频| 少妇亚洲免费精品| 亚洲AV日韩综合一区尤物| 亚洲性线免费观看视频成熟| 久久精品亚洲日本佐佐木明希| 3344在线看片免费| 亚洲AV永久无码精品水牛影视| 中国好声音第二季免费播放| 亚洲色偷偷综合亚洲AVYP| 花蝴蝶免费视频在线观看高清版 | 亚洲熟妇无码八AV在线播放| 色多多A级毛片免费看| 亚洲国产精品人人做人人爽| 一区二区三区免费电影| 色久悠悠婷婷综合在线亚洲| 青柠影视在线观看免费| 亚洲第一精品福利| 色老头永久免费网站| 亚洲国产成人久久99精品| 日韩免费精品视频| 99亚洲男女激情在线观看| 亚洲毛片av日韩av无码| 青青操视频在线免费观看| 日韩精品亚洲人成在线观看| 在线看片免费不卡人成视频| 亚洲av成人片在线观看| 国产成人精品久久亚洲高清不卡 | 中文在线日本免费永久18近| 亚洲国产天堂久久综合网站| 亚洲三级高清免费| 免费一区二区无码视频在线播放 | 无码欧精品亚洲日韩一区| 久热中文字幕在线精品免费| 亚洲精品一卡2卡3卡四卡乱码| 亚洲AⅤ永久无码精品AA| 免费人成毛片动漫在线播放| 国产99在线|亚洲| 久久久久亚洲AV成人网| 中文字幕免费在线看线人| 黄页视频在线观看免费|