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

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

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

    北大青鳥IT教育博客

     

    JDBC與JSP簡單模擬MVC三層設計結構(查詢)

      M是指數據模型,V是指用戶界面,C則是控制器。使用MVC的目的是將M和V的實現代碼分離,從而使同一個程序可以使用不同的表現形式。比如一批統計數據你可以分別用柱狀圖、餅圖來表示。C存在的目的則是確保M和V的同步,一旦M改變,V應該同步更新。


      模型-視圖-控制器(MVC)是Xerox PARC在八十年代為編程語言Smalltalk-80發明的一種軟件設計模式,至今已被廣泛使用。最近幾年被推薦為Sun公司J2EE平臺的設計模式,并且受到越來越多的使用 ColdFusion 和 PHP 的開發者的歡迎。模型-視圖-控制器模式是一個有用的工具箱,它有很多好處,但也有一些缺點。


      MVC是一個設計模式,它強制性的使應用程序的輸入、處理和輸出分開。使用MVC應用程序被分成三個核心部件:模型、視圖、控制器。它們各自處理自己的任務。


      視圖
      視圖是用戶看到并與之交互的界面。對老式的Web應用程序來說,視圖就是由HTML元素組成的界面,在新式的Web應用程序中,HTML依舊在視圖中扮演著重要的角色.
      如何處理應用程序的界面變得越來越有挑戰性。MVC一個大的好處是它能為你的應用程序處理很多不同的視圖。在視圖中其實沒有真正的處理發生,不管這些數據是聯機存儲的還是一個雇員列表,作為視圖來講,它只是作為一種輸出數據并允許用戶操縱的方式。


      代碼實現:
      package com.accp;
      public class StudentForm {
      private int studId;
      private String studName;
      private String studAge;
      public int getStudId() {
      return studId;
      }
      public void setStudId(int studId) {
      this.studId = studId;
      }
      public String getStudName() {
      return studName;
      }
      public void setStudName(String studName) {
      this.studName = studName;
      }
      public String getStudAge() {
      return studAge;
      }
      public void setStudAge(String studAge) {
      this.studAge = studAge;
      }
      }
      JSP:
      <%
      SimpleDateFormat  sf = new SimpleDateFormat("yyyy年MM月dd日");
      String dateString  = sf.format(new Date());
      out.print(dateString);
      StudentModel smodel = new StudentModel();
      ArrayList list =  smodel.ListStudent(DbConnection.getConnection());
      Iterator it = list.iterator();
      StudentForm sform=null;
      while(it.hasNext()){
      sform = (StudentForm)it.next();
      %>
      <tr><td><%=sform.getStudId() %> </td><td> <%=sform.getStudName() %></td><td> <%=sform.getStudAge() %></td>
      </tr>
      <%
      }%>
      模型
      模型表示企業數據和業務規則。在MVC的三個部件中,模型擁有最多的處理任務。例如它可能用象EJBs和ColdFusion Components這樣的構件對象來處理數據庫。被模型返回的數據是中立的,就是說模型與數據格式無關,這樣一個模型能為多個視圖提供數據。由于應用于模型的代碼只需寫一次就可以被多個視圖重用,所以減少了代碼的重復性。
      package com.accp;
      import java.util.ArrayList;
      import java.sql.Connection;
      import java.sql.PreparedStatement;
      import java.sql.Statement;
      import java.sql.ResultSet;
      public class StudentModel {
      private final String SQL_LIST = "SELECT studId,studName,studAge FROM StudentInfo";
      private final String SQL_ADD = "INSERT INTO StudentInfo(studName,studAge) VALUES(?,?)";
      public ArrayList ListStudent(Connection conn) {
      ArrayList list = null;
      Statement stmt = null;
      ResultSet rs = null;
      try {
      list = new ArrayList();
      stmt = conn.createStatement();
      rs = stmt.executeQuery(SQL_LIST);
      while(rs.next()){
      StudentForm sf = new StudentForm();
      sf.setStudId(rs.getInt("studId"));
      sf.setStudName(rs.getString("studName"));
      sf.setStudAge(rs.getString("studAge"));
      list.add(sf);
      }
      } catch (Exception e) {
      // TODO: handle exception
      System.out.println("查詢異常:"+e.toString());
      } finally {
      DbConnection.closeResultSet(rs);
      DbConnection.closeStatement(stmt);
      DbConnection.closeConnection(conn);
      }
      return list;
      }
      }
      數據連接:
      package com.accp;
      import java.sql.Connection;
      import java.sql.DriverManager;
      import java.sql.ResultSet;
      import java.sql.Statement;
      import java.sql.PreparedStatement;
      public class DbConnection {
      private static String DRIVER_CLASS = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
      private static String DATABASE_URL = "jdbc:sqlserver://localhost:1433;databaseName=Student";
      private static String DATABASE_USER = "sa";
      private static String DATABASE_PASSWORD = "sasa";
      public static Connection getConnection (){
      Connection conn= null;
      try {
      Class.forName(DRIVER_CLASS);
      conn = DriverManager.getConnection(DATABASE_URL, DATABASE_USER,
      DATABASE_PASSWORD);
      System.out.println("SQL2005 連接成功!");
      } catch (Exception ex) {
      System.out.println("2111:" + ex.getMessage());
      }
      return conn;
      }
      public static void closeConnection (Connection conn){
      try {
      if (conn != null) {
      conn.close();
      }
      } catch (Exception e) {
      System.out.println(e.toString());
      }
      }
      public static void closeStatement (Statement stmt){
      try {
      if (stmt != null) {
      stmt.close();
      }
      } catch (Exception e) {
      System.out.println(e.toString());
      }
      }
      public static void closeResultSet (ResultSet rs){
      try {
      if (rs != null) {
      rs.close();
      }
      } catch (Exception e) {
      System.out.println(e.toString());
      }
      }
      }
      控制器
      控制器接受用戶的輸入并調用模型和視圖去完成用戶的需求。所以當單擊Web頁面中的超鏈接和發送HTML表單時,控制器本身不輸出任何東西和做任何處理。它只是接收請求并決定調用哪個模型構件去處理請求,然后確定用哪個視圖來顯示模型處理返回的數據。
      現在我們總結MVC的處理過程,首先控制器接收用戶的請求,并決定應該調用哪個模型來進行處理,然后模型用業務邏輯來處理用戶的請求并返回數據,最后控制器用相應的視圖格式化模型返回的數據,并通過表示層呈現給用戶。(武漢北大青鳥魯廣校區金老師)

    posted on 2009-05-12 16:41 武漢北大青鳥 閱讀(94) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     

    導航

    統計

    常用鏈接

    留言簿

    隨筆分類

    隨筆檔案

    文章檔案

    默認

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 久久av免费天堂小草播放| 精品亚洲成a人在线观看| 久久免费公开视频| 国产亚洲综合网曝门系列| 国产97视频人人做人人爱免费| 婷婷综合缴情亚洲狠狠尤物| 国产精品亚洲精品爽爽| 国产免费私拍一区二区三区| 国产亚洲精品AAAA片APP| 国产一级高清免费观看| 羞羞网站免费观看| 亚洲日本一区二区三区在线不卡| 人人公开免费超级碰碰碰视频| 国产精品亚洲玖玖玖在线观看| 国产区在线免费观看| 亚洲大成色www永久网站| 91香焦国产线观看看免费| 亚洲人成在线播放| 成年女人18级毛片毛片免费| 亚洲av无码一区二区三区人妖| 免费在线观看理论片| 在线观看免费无码视频| 亚洲视频在线不卡| 精品国产免费一区二区| 黄色视频在线免费观看| 亚洲无线电影官网| 在线观看免费大黄网站| 美女视频黄视大全视频免费的| 亚洲人成影院在线无码按摩店| 全部免费毛片在线播放| 亚洲色欲色欲www在线播放| 免费人成视网站在线观看不卡| 中文在线观看国语高清免费| 中文字幕亚洲第一在线| 国产精品冒白浆免费视频| 四虎成人免费影院网址| 成年大片免费高清在线看黄| 亚洲黄色免费网站| 又粗又硬又黄又爽的免费视频| 黄网站免费在线观看| 亚洲欧洲无卡二区视頻|