亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

EJB最佳實踐:實體bean保護

2019-11-18 12:36:14
字體:
來源:轉載
供稿:網友

  如何才能使用戶可以訪問您的應用程序數據,又不會將您的實體 bean 直接暴露給 Web 層,從而不會使您的應用程序面臨安全性威脅?Brett McLaughlin 提供了一個解決方案,它可使您的實體 bean 很安全,并且使您的整個應用程序有效率地運行。
  
  EnterPRise javaBeans 技術一般分成三種核心類型的 bean:會話 bean、消息驅動 bean 和實體 bean。bean 還可以分成充當業務對象的 bean 和充當數據對象的 bean。會話 bean 和消息驅動 bean 是業務對象;實體 bean 是數據對象。大多數情況下,只需要將業務對象暴露給 Web 層(有時稱為應用層),因為業務對象可以使用數據對象來處理數據存儲。但在有些情況下,有必要答應用戶直接訪問和操作數據對象,這意味著要將實體 bean 暴露給 Web 層。這會使您的應用程序面臨安全性威脅,而且隨著您的應用程序的發展,還會導致雜亂無章的代碼。
  
  在這篇EJB最佳實踐的文章中,我們將討論為什么絕對不可以將實體 bean 暴露給應用程序的 Web 層,以及為什么這是難以避免的。接著我將向您演示一個變通方法,它既能使您的實體 bean 更安全,又能使您的整個應用程序更有效率。
  
  暴露的風險
  實體bean揭示了大量有關數據庫底層結構的信息。因為每個bean都包含用于數據庫中的各個字段的取值(accessor)和賦值(mutator)方法(即,getxxx() 和 setxxx()),而且因為方法名稱通常與字段名稱連在一起(User bean 中的 getFirstName() 通常訪問 Users表中的firstName字段),所以從應用程序的實體bean推斷這個應用程序的整個數據庫結構是可能的。盡管在單個應用程序中這可能不是什么大問題,但您的bean經常會暴露給其它網絡上另外的應用程序。在 Web 服務系統中尤其會發生這種情況,其中應用程序都是跨多個網絡鏈接的。
  
  暴露的 bean:一個工作示例
  請考慮稱為Movie的實體bean。該bean的方法是getTitle()、getDirector()和getActors()。因為您已暴露了該 bean 的遠程接口,所以您的應用程序和幾個客戶機應用程序都編寫了合并 getDirector() 方法的代碼。但是,隨著應用程序的發展,它應該能接受由多位導演指導的電影,這一點很清楚。數據庫更改了,您的 getDirector() 方法變成了 getDirectors()。現在該方法是復數形式并被編碼為返回一個列表,而不是單一對象。其結果是,所有使用舊方法的代碼都將破壞,從而不得不重寫您的應用程序代碼(以及您的客戶機應用程序代碼)。
  
  除了存在使您數據庫結構暴露給未知應用程序的明顯危險之外,您還應該考慮當數據結構更改時會發生什么。因為實體 bean 與您的數據結構緊密地結合在一起,所以隨著數據庫表中列的更改或新列的添加,實體 bean 經常要隨之更改。通過將您的實體 bean 暴露給應用層,可以使它們的方法名稱可用,而且這些方法名稱幾乎總是被您的應用程序和外部應用程序合并到新的應用程序代碼中。隨著您的實體 bean 的更改以及發展,就會出現嚴重的代碼混亂。
  
  會話虛包模式
  幸運的是,有一個設計模式讓您答應用戶訪問數據對象,同時又不會將實體 bean 暴露給 Web 層。會話虛包(session Facade)模式在實體 bean 和應用程序客戶機之間放置了一個會話 bean。當我通過這種方法使用會話 bean 時,我喜歡把它當作治理器,因為它的任務是治理對其它實體的訪問。
  
  會話bean旨在充當業務邏輯和應用邏輯之間的接口。在我們的工作示例的例子中,邏輯極其簡單,而且它只調出一個底層實體 bean。然而在實際情況中,您可能會選擇讓會話 bean 治理數據驗證、安全性或任何其它特定于業務的功能。通過將實體 bean 封裝在會話 bean 中,您可以訪問所有所需的業務功能,同時不會“污染”您的實體 bean 代碼。
  
  為了解決工作示例中的問題,您可以創建稱為 MovieManager 的會話 bean。MovieManager bean 將包含舊方法 getDirector() 和新方法 getDirectors()。當添加了新方法時,它只是被“代理”到您的實體 bean。因為第一個方法在實體 bean 中不再可用,所以會話 bean 使用助手方法來隱藏它,如清單 1 所示:
  
  清單 1. 隱藏已不使用的方法
  public Person getDirector() {
  // We can't call getDirector() any more on the entity bean
  // Call the new method, through this manager
  List directors = getDirectors();
  // Return the first one in the list
  return (Person)directors.item(0);
  }
  
  清單 1 的適用性不是非凡健壯,但它獲得了成功。因為隱藏了舊方法(而不是刪除),所以所有與它相關的應用程序代碼都一直存在。通過將助手方法放置在它所屬的業務對象中,您還將它排斥在實體 bean 之外。解決了這個緊急的問題后,您可以選擇將 bean 的客戶機手工移植到新方法,或讓助手方法一直處理移植工作。不管是哪種方法,都不會影響您的應用程序代碼和您的客戶機代碼。
  
  隱藏數據結構
  盡管上面的解決方案確實解決了更改治理的問題,但它不能消除安全性問題。您仍需要保護實體bean(并由此保護您的數據結構),以免暴露給Web層。通過向會話bean添加一些簡單的業務邏輯和數據操作功能,您不僅可以隱藏應用程序的數據結構,還可以提供對它所包含的信息的更復雜訪問。
  
  例如,隨著應用程序的發展,您可能發現讓用戶依次訪問各種數據對象(例如,導演、制片人、演員)的效率很低。因為這類信息幾乎總是被放在一起,并一起使用,所以您可能發現重新確定會話 bean 的用途會很有幫助。您的會話 bean 將不包含 getDirector() 或 getDirectors() 方法,而是包含了如清單 2 所示的新的業務邏輯:
  
  清單 2. 用會話 bean 掩蓋數據結構
  public List getCrew(String movieName)
  throws NamingException, RemoteException {
  List crew = new LinkedList();
  EJBHomeFactory f = EJBHomeFactory.getInstance();
  MovieHome movieHome =
  (MovieHome)f.lookup("java:comp/env/ejb/Movie", MovieHome.class);
  Movie movie = movieHome.findByName(movieName);
  crew.add(movie.getDirectors());
  crew.add(movie.getProdUCers());
  crew.add(movie.getExecutiveProducers());
  // and so on...
  return crew;
  }
  public List getCast(String movieName)
  throws NamingException, RemoteException {
  List cast = new LinkedList();
  EJBHomeFactory f = EJBHomeFactory.getInstance();
  MovieHome movieHome =
  (MovieHome)f.lookup("java:comp/env/ejb/Movie", MovieHome.class);
  Movie movie = movieHome.findByName(movieName);
  crew.add(movie.getActors());
  crew.add(movie.getStandIns());
  // and so on...
  return cast;
  }
  
  通過分離不同的應用程序層,以及使用業務邏輯來處理數據操作,您既阻止了對實體 bean 直接而且可能不安全的訪問,又為您的 Web 層創建了更有意義的方法集。本例中,會話虛包充當了實體 bean 的封裝器以及真正的業務邏輯單元,從而將原始數據轉變成有意義的信息。
  
  會話虛包模式是許多其它設計模式的基本構件,其優點遠遠不止這里所討論的。在 EJB 最佳實踐的下一篇專欄文章中,我們將使用本系列的第一篇技巧文章中研究的業務接口(Business Interface)模式,以及您在這里了解到的某些訣竅來進一步抽象出使用您應用程序中所有類型 EJB 組件的過程。
  
  要避免的解決方案
  解決所描述的這類問題的一個常見解決方案是簡單地將助手方法添加到實體bean本身。但這樣做的后果可能是災難性的。即使您實體bean中的每個方法每年只更改一次,但bean會在那年結束時將擁有雙倍數量的方法。當您考慮方法不只是每年更改一次,而是以頻繁得多的頻率更改時,為什么這個“邦迪式(Band-Aid)”方法不起作用就很明顯了。當實體bean看上去不再象數據對象而開始象助手類時,您知道您已經有問題了。另一方面,會話 bean 經??瓷先ナ窒笾诸?,因為那是會話 bean 旨在實現的功能之一。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线观看久久久久久| 亚洲国产精品va在线看黑人动漫| 国产999精品视频| 亚洲国产精品va| 欧美成人精品在线观看| 国产亚洲精品久久久| 久久久久国产精品www| 久久伊人免费视频| 久色乳综合思思在线视频| 色悠久久久久综合先锋影音下载| 欧美激情亚洲国产| 亚洲国产日韩欧美在线99| 欧美国产日本高清在线| 日韩大陆毛片av| 欧美性资源免费| 97在线精品视频| 国产精品久久久久久久久借妻| 国产精品自产拍在线观看| 日韩欧美在线字幕| 亚洲欧美一区二区三区情侣bbw| 亚洲国模精品一区| 97**国产露脸精品国产| 精品一区二区三区四区在线| 午夜欧美大片免费观看| 欧美一级高清免费播放| 66m—66摸成人免费视频| 亚洲欧美激情精品一区二区| 国产欧美日韩中文字幕| 精品久久香蕉国产线看观看亚洲| 亚洲国产精品成人av| 成人网页在线免费观看| 国产一区av在线| 免费成人高清视频| 日韩动漫免费观看电视剧高清| 欧美精品午夜视频| 伊人久久大香线蕉av一区二区| 日韩av快播网址| 国产主播喷水一区二区| 久久久久国色av免费观看性色| 欧美日韩性生活视频| 精品福利在线观看| 亚州精品天堂中文字幕| 91九色在线视频| 91性高湖久久久久久久久_久久99| 久久久在线免费观看| 久久久欧美一区二区| 精品国产依人香蕉在线精品| 成人激情免费在线| 久久久亚洲福利精品午夜| 国产成+人+综合+亚洲欧洲| 精品福利在线观看| 免费97视频在线精品国自产拍| 国产精品自在线| 久久久99久久精品女同性| 亚洲色图激情小说| 九九九热精品免费视频观看网站| 97成人在线视频| 久国内精品在线| 国产精品最新在线观看| 国产精品一区二区久久精品| 久久久噜噜噜久久| 亚洲精品国精品久久99热| 亚洲精品免费av| 国产成人精品综合久久久| y97精品国产97久久久久久| 亚洲视频在线免费看| 在线看国产精品| 久久免费视频观看| 欧美日韩国产综合新一区| 91亚洲精品在线| 欧美性猛交xxxx乱大交3| 91精品国产免费久久久久久| 日韩亚洲在线观看| 国产啪精品视频网站| 日韩av毛片网| 亚洲欧美激情视频| 57pao国产精品一区| 日本伊人精品一区二区三区介绍| 九九久久久久久久久激情| 欧美日韩亚洲天堂| 日本aⅴ大伊香蕉精品视频| 成人黄色影片在线| 日韩在线观看精品| 亚洲最大av在线| 最新国产精品亚洲| 亚洲美女av网站| 中文字幕精品在线视频| 日韩hd视频在线观看| 国产亚洲在线播放| 少妇激情综合网| 日韩av影片在线观看| 日本精品久久久久久久| 久久久久久久久国产精品| 成人高清视频观看www| 成人妇女免费播放久久久| 91av视频在线播放| 国产福利成人在线| 亚洲欧洲日产国码av系列天堂| 亲爱的老师9免费观看全集电视剧| 日韩中文字幕免费视频| 日韩精品久久久久久福利| 影音先锋日韩有码| 亚洲毛茸茸少妇高潮呻吟| 国产成人+综合亚洲+天堂| 久久人人爽国产| 日韩成人av一区| 18一19gay欧美视频网站| 国产精品亚洲欧美导航| 日韩最新在线视频| 久久99国产综合精品女同| 国产精品美女www| 欧美在线一区二区视频| 久久理论片午夜琪琪电影网| 久久这里只有精品视频首页| 久久国产精品久久国产精品| 国产精品在线看| 97国产suv精品一区二区62| 91系列在线播放| 亚洲视频axxx| 揄拍成人国产精品视频| 亚洲国产精品一区二区久| 日韩美女福利视频| 日韩av在线导航| 97在线观看免费| 欧美日韩人人澡狠狠躁视频| 亚洲开心激情网| 中文字幕亚洲一区二区三区五十路| 国产精品成人v| 国产精品老牛影院在线观看| 亚洲欧美成人在线| 久久久久免费精品国产| 亚洲精品第一页| 一本一本久久a久久精品牛牛影视| 久久天天躁狠狠躁夜夜躁2014| 欧美高清视频一区二区| 久久成人综合视频| 国产精品日韩电影| 亚洲人成欧美中文字幕| 国产精品视频26uuu| 亚洲自拍欧美色图| 68精品久久久久久欧美| 国产suv精品一区二区三区88区| 国产精品久久综合av爱欲tv| 中文字幕亚洲情99在线| 日韩欧美高清在线视频| 亚洲资源在线看| 久久精品影视伊人网| 日本sm极度另类视频| 欧美精品videos另类日本| 欧美电影在线观看完整版| 久久久久久久激情视频| 国产午夜精品视频免费不卡69堂| 国产成人精品在线| 精品久久久久久久久中文字幕| 亚洲一区二区免费在线| 亚洲一区二区黄| 欧美一区二区三区……| 久久久久久久久久久久久久久久久久av| 精品国产福利视频| 亚洲区在线播放| 上原亚衣av一区二区三区| 91美女片黄在线观看游戏| 国产精品美乳一区二区免费| 亚洲激情第一页|