亚洲av无码成人精品区在线播放,国产∨亚洲V天堂无码久久久,亚洲人成人网站在线观看http://www.tkk7.com/xiaohei/zh-cnSun, 11 May 2025 14:02:28 GMTSun, 11 May 2025 14:02:28 GMT60JS 動態加載腳本(轉)http://www.tkk7.com/xiaohei/archive/2013/06/01/400049.htmlTomasTomasSat, 01 Jun 2013 01:19:00 GMThttp://www.tkk7.com/xiaohei/archive/2013/06/01/400049.htmlhttp://www.tkk7.com/xiaohei/comments/400049.htmlhttp://www.tkk7.com/xiaohei/archive/2013/06/01/400049.html#Feedback0http://www.tkk7.com/xiaohei/comments/commentRss/400049.htmlhttp://www.tkk7.com/xiaohei/services/trackbacks/400049.html閱讀全文

Tomas 2013-06-01 09:19 發表評論
]]>
多文件上傳http://www.tkk7.com/xiaohei/archive/2013/05/17/399414.htmlTomasTomasFri, 17 May 2013 07:56:00 GMThttp://www.tkk7.com/xiaohei/archive/2013/05/17/399414.htmlhttp://www.tkk7.com/xiaohei/comments/399414.htmlhttp://www.tkk7.com/xiaohei/archive/2013/05/17/399414.html#Feedback2http://www.tkk7.com/xiaohei/comments/commentRss/399414.htmlhttp://www.tkk7.com/xiaohei/services/trackbacks/399414.html
多文件上傳 jquery的插件
使用的方法  導入 jquery.js 及 jquery.MultiFile.js ,
方式一: 后臺是文件數組  
 private File[] upload; // 與jsp表單中的名稱對應
 private String[] uploadFileName;
 private String[] uploadContentType;
在 form 中加入 <input type="file" name="upload[]" class="multi" /> 即可。

方式二:后臺是List<File>
 private List<File> upload; // 與jsp表單中的名稱對應
 private List<String> uploadFileName;
 private List<String> uploadContentType;

jquery.MultiFile.js  將選中的文件列在From中,名字為upload的<input>,所以要用 name="upload[]"(方法一)或者name="upload" (方法二) 來接收
class="multi" 是 jQuery 用來作的文件類型,HTML 部份代碼如下:

<head>
<meta http-equiv='Content-Type' content='text/html; charset=utf-8' />
<title>Untitled Document</title>
<script src="/multiple-file-upload/jquery.js" type="text/javascript" language="javascript"></script>
<script src="/multiple-file-upload/jquery.MultiFile.js" type="text/javascript" language="javascript"></script>

</head>
<body>

<form enctype="multipart/form-data" action="<?php $_SERVER['PHP_SELF'] ?>" method="POST">
<input type="file" name="upload[]" class="multi" maxlength="2"/>
//<input type="file" name="upload" class="multi" />

<input type="submit" value="Upload File" />
</form>

</body>

參數說明:

參數 說明 說明
class="multi" maxlength="2" Limit: 2 files.
Allowed extensions: any.
限制數量2
class="multi" accept="gif|jpg" Limit: no limit.
Allowed extensions: gif and jpg.
格式只能 gif  jpg
class="multi" accept="gif|jpg" maxlength="3" Limit: 3 files
Allowed extensions: gif, jpg.
限制數量3,格式只能 gif  jpg


主頁:http://www.fyneworks.com/jquery/multiple-file-upload/

下載:http://www.fyneworks.com/jquery/multiple-file-upload/#tab-Download

示例:http://www.fyneworks.com/jquery/multiple-file-upload/#tab-Examples



Tomas 2013-05-17 15:56 發表評論
]]>
數字轉換為大寫人民幣計數http://www.tkk7.com/xiaohei/archive/2011/12/26/367181.htmlTomasTomasMon, 26 Dec 2011 05:26:00 GMThttp://www.tkk7.com/xiaohei/archive/2011/12/26/367181.htmlhttp://www.tkk7.com/xiaohei/comments/367181.htmlhttp://www.tkk7.com/xiaohei/archive/2011/12/26/367181.html#Feedback0http://www.tkk7.com/xiaohei/comments/commentRss/367181.htmlhttp://www.tkk7.com/xiaohei/services/trackbacks/367181.html/**
 * 數字轉換為大寫人民幣計數
 * @author 王代軍
 * @since Dec 16,2011
 */

public class Num2Rmb
{
    private String[] hanArr = {"零" , "壹" , "貳" , "叁" , "肆" ,
        "伍" , "陸" , "柒" , "捌" , "玖"};
    private String[] unitArr = {"拾","百","千","萬"};

    /**
     * 把一個四位的數字字符串變成漢字字符串
     * @param numStr 需要被轉換的四位的數字字符串
     * @return 四位的數字字符串被轉換成的漢字字符串。
     */
    private String toHanStr(String numStr)
    {
        String result = "";
        int numLen = numStr.length();
        //依次遍歷數字字符串的每一位數字
        for (int i = 0 ; i < numLen ; i++ )
        {
            //把char型數字轉換成的int型數字,因為它們的ASCII碼值恰好相差48
            //因此把char型數字減去48得到int型數字,例如'4'被轉換成4。
            int num = numStr.charAt(i) - 48;
            //如果不是最后一位數字,而且數字不是零,則需要添加單位(千、百、十)
            if ( i != numLen - 1 && num != 0)
            {
                result += hanArr[num] + unitArr[numLen - 2 - i];
            }
            //否則不要添加單位
            else
            {
                
                //上一個數是否為“零”,不為“零”時就添加
                if(result.length()>0 && hanArr[num].equals("零") && result.charAt(result.length()-1)=='零')
                    continue;
                result += hanArr[num];
            }
        }
        //只有個位數,直接返回
        if(result.length()==1)
            return result;
        
        int index=result.length()-1;
        while(result.charAt(index)=='零'){
            index--;
        }
        if(index!=result.length()-1)
            return result.substring(0,index+1);
        else {
            return result;
        }
    }
    /**
     * 把一個輸入的數字字符串變成漢字字符串
     * @param numStr 需要被轉換得到數字字符串
     * @return 數字字符串被轉換成的漢字RMB字符串。
     */
    private String toRmbStr(String numStr){
        //獲取字符串長度
        int numLen = numStr.length();
        //判斷長度小于4(一萬以內~0-9999) 調用toHanStr();
        if(numLen<=4){
            return toHanStr(numStr);
        }
        //4<長度<=8 (一億以內 1000-99999999)
        else if(numLen>4&&numLen<=8){
            String[] subArr={numStr.substring(0, numLen-4),numStr.substring(numLen-4, numLen)};
            return toHanStr(subArr[0])+"萬"+toHanStr(subArr[1]);
        }
        //8<長度<=10 (百億以內 一億-9999999999)
        else if(numLen>8&&numLen<=10){
            String[] subArr={numStr.substring(0,numLen-8),numStr.substring(numLen-8,numLen-4),numStr.substring(numLen-4,numLen)};
            return toHanStr(subArr[0])+"億"+toHanStr(subArr[1])+"萬"+toHanStr(subArr[2]);
        }
        else return "輸入有誤!";    
    }          
    public static void main(String[] args)
    {        
        Num2Rmb nr = new Num2Rmb();
        System.out.println("只支持整數(0~99億)");
        //測試把一個四位的數字字符串變成漢字字符串
        System.out.println(nr.toRmbStr("1"));
        System.out.println(nr.toRmbStr("10"));
        System.out.println(nr.toRmbStr("15"));
        System.out.println(nr.toRmbStr("110"));
        System.out.println(nr.toRmbStr("123"));
        System.out.println(nr.toRmbStr("105"));
        System.out.println(nr.toRmbStr("1000"));
        System.out.println(nr.toRmbStr("1101"));
        System.out.println(nr.toRmbStr("1110"));
        System.out.println(nr.toRmbStr("1005"));
        System.out.println(nr.toRmbStr("101105"));
        System.out.println(nr.toRmbStr("1011109"));
        System.out.println(nr.toRmbStr("9999999999"));
    }
}



Tomas 2011-12-26 13:26 發表評論
]]>
hibernate 通用的增該查 工具類 供Dao層使用http://www.tkk7.com/xiaohei/archive/2011/12/26/367180.htmlTomasTomasMon, 26 Dec 2011 05:22:00 GMThttp://www.tkk7.com/xiaohei/archive/2011/12/26/367180.htmlhttp://www.tkk7.com/xiaohei/comments/367180.htmlhttp://www.tkk7.com/xiaohei/archive/2011/12/26/367180.html#Feedback1http://www.tkk7.com/xiaohei/comments/commentRss/367180.htmlhttp://www.tkk7.com/xiaohei/services/trackbacks/367180.htmlCommonCrudUtil(本類)實例  實現對數據的增刪改查



package com.XXXXX.util;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import org.hibernate.*;
/**
 * 通用增刪改查工具類
 * @author 王代軍
 * @since Dec 19,2011
 * @version 1.0
 */
@SuppressWarnings("unchecked")
public class CommonCrudUtil<T> {
    /**
     * 添加功能
     * @param obj 要保存的對象
     */
    public boolean create(Object obj){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=null;
        boolean flag=false;
        try{
            tx=session.beginTransaction();
            session.persist(obj);
            tx.commit();
            flag=true;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){        
                tx.rollback();
            }
        }finally{
            session.close();
        }    
        return flag;
    }
    /**
     * 查詢功能
     * @param clazz 要查詢對象的類型  obj 要查詢的對象的 可序列化的字段 (本設計指主鍵 id)
     */
    public Object retrieve(Class clazz,Object obj){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=null;
        try{
            tx=session.beginTransaction();
            Object object=session.get(clazz,(Serializable) obj);
            tx.commit();
            return object;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){        
                tx.rollback();
            }
            return null;
        }finally{
            session.close();
        }        
    }    
    /**
     * 查詢全部功能
     * @param clazz 要查詢的對象的類型
     */
    public List<T> retrieve(Class clazz){
        Session session=HibernateSessionFactory.getSession();
        List<T> list=new ArrayList<T>();
        Transaction tx=null;
        try{
            tx=session.beginTransaction();
            Criteria cr=session.createCriteria(clazz);
            list=cr.list();
            tx.commit();
            return list;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){            
                tx.rollback();
            }
            return null;
        }finally{
            session.close();
        }
    }
    /**
     * 更新功能
     * @param obj 要更新的對象
     */
    public boolean update(Object obj){
        Session session=HibernateSessionFactory.getSession();
        boolean flag=false;
        Transaction tx=null;
        try{
            tx=session.beginTransaction();
            session.update(obj);
            tx.commit();
            flag=true;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){            
                tx.rollback();
            }
        }finally{
            session.close();
        }
        return flag;
    }
    /**
     * 刪除功能
     * @param clazz 要刪除的對象的類型 obj 要刪除的對象的 唯一標識(可序列化)字段 (指主鍵 id)
     */
    public boolean delete(Class clazz,Object obj){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=null;
        boolean flag=false;
        try{
            tx=session.beginTransaction();
            Object object=session.get(clazz,(Serializable) obj);
            session.delete(object);
            tx.commit();
            flag=true;
        }catch(Exception e){
            e.printStackTrace();
            if(tx!=null){        
                tx.rollback();
            }
        }finally{
            session.close();
        }    
        return flag;
    }
    
}



調用實現   dao層的實現類調用 
   CommonCrudUtil  的方法實現增刪改查

import java.util.Date;
import java.util.List;

import org.hibernate.Query;
import com.zhongyou.bean.IDCard;
import com.zhongyou.util.CommonCrudUtil;

public class IDCardDaoImpl implements IDCardDaoIf {

    
     CommonCrudUtil crud=new CommonCrudUtil<IDCard>();
   
     public int addInformation(IDCard card) {

     IDCard card=new IDCard();
     card.setId(16);
     card.setName("xiaoxiao");
     card.setAddress("xiaoxiao");
     card.setBirthday(new Date());
     card.setNumber("29472398734");
     card.setSex("男");


     crud.create(card);//增加.......

}
 
     。。。。。。查詢。。。。。
     crud.retrieve(IDCard.class,3);
    。。。。。。查詢全部。。。。。
     crud.retrieve(IDCard.class);

    。。。。。。修改。。。。
     crud.update(card);
    。。。。。。刪除。。。。
     crud.delete(IDCard.class,3);
。。。。。。。。。



寫的簡陋些  只是些想法可借鑒而已 同志們 可以自己完善。。。。






Tomas 2011-12-26 13:22 發表評論
]]>
Oracle 服務詳解http://www.tkk7.com/xiaohei/archive/2011/11/09/363282.htmlTomasTomasWed, 09 Nov 2011 03:50:00 GMThttp://www.tkk7.com/xiaohei/archive/2011/11/09/363282.htmlhttp://www.tkk7.com/xiaohei/comments/363282.htmlhttp://www.tkk7.com/xiaohei/archive/2011/11/09/363282.html#Feedback0http://www.tkk7.com/xiaohei/comments/commentRss/363282.htmlhttp://www.tkk7.com/xiaohei/services/trackbacks/363282.html

Oracle的默認服務一共有5個:

1.OracleDBConsoleorcl oem控制臺的服務進程

2.OracleJobSchedulerORCL 定時器的服務進程

3.OracleOraDb10g_home1iSQL*Plus isql*plus的服務進程

4.OracleOraDb10g_home1TNSListener 監聽器的服務進程


5.OracleServiceORCL 數據庫服務進程

要查看系統中已啟動的服務,我們可以在“開始→控制面板→管理工具”中雙擊“服務”,或者直接

在“運行”中輸入 “Services.msc”打開服務設置對話框,就可以看到每一個服務都有以下幾個屬

性:名稱、描述、狀態、啟動類型、登錄身份、依存關系。

OracleDBConsoleorcl --可以不啟動,用于管理Oracle的企業管理器的服務.

OracleJobSchedulerORCL --通常不啟動,用于定期操作任務的服務

OracleOraDb10g_home1iSQL*Plus --可以不啟動,這是isqlplus服務,用于用網頁執行sql執行,11g已

經取消了這個功能

OracleOraDb10g_home1TNSListener --必須啟動,這是臨聽,用于遠程客戶端連接你的Oracle

OracleServiceORCL --必須啟動,這是Oracle數據庫的服務

可以用命令啟動:

#啟動listener:

lsnrctl start

#啟動數據庫

net start OracleServiceORCL

只有這兩項是必須啟動的:

OracleOraDb10g_home1TNSListener

OracleServiceORCL

為什么OracleJobSchedulerORCL會顯示禁用?

數據庫工作日程調度,一般沒有安排工作日程就不需要啟動,為什么默認是禁用?因為啟動后會占用很大的系統資源。

(1)OracleServiceSID                    

數據庫服務,這個服務會自動地啟動和停止數據庫。如果安裝了一個數據庫,它的缺省啟動類型為自動。服務進程為Oracle.EXE,參數文件initSID.ora,日志文件SIDALRT.log,控制臺SVRMGRL.EXE、SQLPLUS.EXE。

(2)OracleHOME_NAMETNSListener

監聽器服務,服務只有在數據庫需要遠程訪問時才需要(無論是通過另外一臺主機還是在本地通過 SQL.Net 網絡協議都屬于遠程訪問),不用這個服務就可以訪問本地數據庫,它的缺省啟動類型為自動。服務進程為TNSLSNR.EXE,參數文件 Listener.ora,日志文件listener.log,控制臺LSNRCTL.EXE,默認端口1521、1526。

(3)OracleHOME_NAMEAgent

OEM代理服務,接收和響應來自OEM控制臺的任務和事件請求,只有使用OEM管理數據庫時才需要,它的缺省啟動類型為自動。服務進程為DBSNMP.EXE,參數文件snmp_rw.ora,日志文件nmi.log,控制臺LSNRCTL.EXE,默認端口1748。

(4)OracleHOME_NAMEClientCache      

名字緩存服務,服務緩存用于連接遠程數據庫的Oracle Names 數據。它的缺省啟動類型是手動。然而,除非有一臺Oracle Names 服務器,否則沒有必要運行這個服務。服務進程為ONRSD.EXE,參數文件NAMES.ORA,日志文件ONRSD.LOG,控制臺 NAMESCTL.EXE。

(5)OracleHOME_NAMECMAdmin                    

連接管理服務,是構建Connection Manager服務器所用,只有服務器作為Connection Manager才需要,它的缺省啟動類型是手動。服務進程為CMADMIN.EXE,參數文件CMAN.ORA,日志文件CMADM_PID.TRC,控 制臺CMCTL.EXE,默認端口1830。

(6)OracleHOME_NAMECMan                    

連接網關服務,是構建Connection Manager服務器所用,只有服務器作為Connection Manager才需要,它的缺省啟動類型是手動。服務進程為CMGW.EXE,參數文件CMAN.ORA,日志文件CMAN_PID.TRC,控制臺 CMCTL.EXE,默認端口1630。

(7)OracleHOME_NAMEDataGatherer

性能包數據采集服務,除非使用Oracle Capacity Planner 和 Oracle Performance Manager,否則不需要啟動,它的缺省啟動類型是手動。服務進程為VPPDC.EXE,日志文件alert_dg.log,控制臺 vppcntl.exe。

(8)OracleHOME_NAMEHTTPServer

Oracle提供的WEB服務器,一般情況下我們只用它來訪問Oracle Apache 目錄下的Web 頁面,比如說JSP 或者modplsql 頁面。除非你使用它作為你的HTTP服務,否則不需要啟動(若啟動它會接管IIS的服務),它的缺省啟動類型是手動。服務進程為APACHE.EXE,參 數文件httpd.conf,默認端口80。

(9)OracleHOME_NAMEPagingServer

通過一個使用調制解調器的數字傳呼機或者電子郵件發出警告(沒試過),它的缺省啟動類型是手動。服務進程PAGNTSRV.EXE,日志文件paging.log。

(10)OracleHOME_NAMENames

Oracle Names服務,只有服務器作為Names Server才需要,它的缺省啟動類型是手動。服務進程NAMES.EXE,參數文件NAMES.ORA,日志文件NAMES.LOG,控制臺NAMESCTL.EXE,默認端口1575。

(11)OracleSNMPPeerMasterAgent

SNMP服務代理,用于支持SNMP的網管軟件對服務器的管理,除非你使用網管工具監控數據庫的情況,否則不需要啟動,它的缺省啟動類型是手動。服務進程為AGNTSVC.EXE,參數文件MASTER.CFG,默認端口161。

(12)OracleSNMPPeerEncapsulater

SNMP協議封裝服務,用于SNMP協議轉換,除非你使用一個不兼容的SNMP代理服務,否則不需要啟動,它的缺省啟動類型是手動。服務進程為ENCSVC.EXE,參數文件ENCAPS.CFG,默認端口1161。

(13)OracleHOME_NAMEManagementServer

OEM管理服務,使用OEM時需要,它的缺省啟動類型是手動。服務進程為OMSNTSVR.EXE,日志文件oms.nohup。

OracleServiceMYDB

OracleOraHome92TNSListener

別的一般不用開,有需要再開






附(批處理)

:doit

  @echo off

  set /p xz=按"kq"鍵啟動服務------按"gb"關閉服務

  if %xz%==kq goto kq

  if %xz%==gb goto gb

  goto doit

  :kq

  @echo off

  echo 正在啟動oracle服務,請稍等......

  net start OracleServiceORCL

  net start OracleDBConsoleorcl

  net start OracleOraDb10g_home1TNSListener

  net start OracleOraDb10g_home1iSQL*Plus

  echo 啟動oracle服務完成

  echo. & pause

  goto doit

  :gb

  @echo off

  echo 正在關閉oracle服務,請稍等.......

  net stop OracleServiceORCL

  net stop OracleDBConsoleorcl

  net stop OracleOraDb10g_home1TNSListener

  net stop OracleOraDb10g_home1iSQL*Plus

  echo 關閉oracle服務完成

  echo. & pause

  goto doit

把代碼復制 保存  修改后綴名為.bat 執行即可;



Tomas 2011-11-09 11:50 發表評論
]]>
解析--Sessionhttp://www.tkk7.com/xiaohei/archive/2011/10/16/361375.htmlTomasTomasSun, 16 Oct 2011 13:29:00 GMThttp://www.tkk7.com/xiaohei/archive/2011/10/16/361375.htmlhttp://www.tkk7.com/xiaohei/comments/361375.htmlhttp://www.tkk7.com/xiaohei/archive/2011/10/16/361375.html#Feedback0http://www.tkk7.com/xiaohei/comments/commentRss/361375.htmlhttp://www.tkk7.com/xiaohei/services/trackbacks/361375.html



會話跟蹤,其原理是什么。

我們都知道,為了在WEB服務器中識別發出請求的用戶,對于每一個訪問者WEB服


務器都會給其創建一個session。在會話的創建于使用中,比較容易犯錯誤的地


方主要是當我們需要讀取出保存在session的數據時,沒有轉化為相應的格式,


導致程序出錯。比如:

HttpSession session=request.getSession();


|\\\\\\\\\\


注意Session在為進行HttpSession session=request.getSession();之前


out.println(request.getSession());


HttpSession hs=request.getSession();
out.println(hs);
兩者執行的結果相同;


第一個是獲得Tomcat內置的默認Session (就是會話建立時自動生成的Session唯一標記本次會話)


第二次 是把 唯一的標識Session 通過request.getSession()獲取內存地址 給hs 然后hs


會獲取Session 然后對其操作  其實本質上是對本次會話的唯一Session進行操作.


\\\\\\\\\\\\\\

String MyName="Hello Accp";

session.setAttribute("name",MyName);

String name=seeeion.getAttribute("name");//錯誤的

String name=(String)seeeion.getAttribute("name");//正確的

由于WEB服務器為用戶創建的Session會占用系統內存,所以通常服務器都需要及


時的刪除Session信息以釋放資源,方法有:

①關閉瀏覽器,關閉Session。

②調用HttpSession的invalidate()方法,刪除HttpSession對象和數據。

③兩次訪問時間間隔大于Session定義的非活動時間。

在Servlet中的HttpRequestServlet對象創建HttpSession對象有兩種方法:

①HttpSession session=request.getSession(boolean value);

②HttpSession session=request.getSession();

第一中方法中,布爾值為true時,如果存在于當前請求相關聯的會話,就返回該


會話,否則就返回一個新會話。反之,布爾值為false時,如果存在當前請求相


關聯的會話,就返回該會話,否則就返回null。

第二種方法與第一種方法的第一種情況相同。通常我們都喜歡使用第二種方法。



Tomas 2011-10-16 21:29 發表評論
]]>
Java Bean 的學習心得(轉)http://www.tkk7.com/xiaohei/archive/2011/10/10/360916.htmlTomasTomasMon, 10 Oct 2011 15:18:00 GMThttp://www.tkk7.com/xiaohei/archive/2011/10/10/360916.htmlhttp://www.tkk7.com/xiaohei/comments/360916.htmlhttp://www.tkk7.com/xiaohei/archive/2011/10/10/360916.html#Feedback0http://www.tkk7.com/xiaohei/comments/commentRss/360916.htmlhttp://www.tkk7.com/xiaohei/services/trackbacks/360916.html

 今天主要講解了一下知識點:
  JavaBean、javaBean規范、javaBean的動作、開發模式

先講一下javaBean的作用,以及我們為什么要使用javabean?
 其實javabean的一個最主要的作用就是對數據進行一個封裝,其次是增強代碼的復用性、結構更清晰等。
在換句話說javabean他其實本身就是一個對象,之所以學習javabean的好處,就是讓我們像操作對象一樣進行操作數據。讓代碼變得更靈活、更簡單。

舉個小小的例子:
 比如你做一個注冊功能。首先呢我們是需要獲取用戶界面的信息。然后在獲取進來的數據傳給持久層,進行持久的時候大家有沒有注意到,如果表單里面的數據少的話還可以,直接傳入參數,而數據一旦超過10個數據,那么你可以想象一個你傳入的參數,那該是多么的一大串,所以我們采取javabean的方式,把從頁面上取來的信息把它存放到一個對象當中,那么我們在進行持久化傳參的時候就只需要傳入一個對象就OK。 這就是javabean的好處之一。

JavaBean規范:
 一個javabean由四部分組成:
  第一部分:javabean必須有一個無慘的構造方法。
  第二部分:所有的屬性必須都是private的。
  第三部分:必須生成get/set方法。
  第四部分:必須實現序列化(Serializable)這個接口。

下面我呢針對上面這些javabean的規范做一個解釋,以及為什么要定義這個規范?
 1:javabean為什么需要一個無慘的構造方法呢?
回答:這個無慘的構造方法的作用主要是針對反射。為什么會針對反射呢?大家知道使用反射實例化一個類,是實例化該類的一個無慘的構造方法。
 比如:
  如果他是一個無慘的構造方法: Class.forName("com.lovo.User").newInstance.
  如果他沒有一個無慘的構造方法:Class c = Class.forName("com.lovo.User");
        手動實例化他所有的公共的構造方法: Constructor[] con = c.getConstructors()

 2:javabean為什么所有的屬性都是private的呢,為什么不可以是public的?
回答:private屬性增強javabean安全性。他們的區別就是如果他的屬性設置為public的話,我們可以任意的進行訪問或修改(沒有安全性)。而private屬性為什么要通過get/set去訪問這就是下面馬上講到的。

 3:javaBean的get/set方法。
回答:get/set方法也是增加代碼的安全性。比如我們可以讓外部只可以訪問屬性不能修改屬性的話,那么我在這里只需要生成get方法就行了,無須生成set方法,而public就無法做到這一點。還有一個就是比如我們在設置他的age的時候我們還可以進行驗證工作,比如如果你的age小于18,那么就直接跳出,不允許設置該屬性。這個功能也是很強大的。

舉個小小列子:
 public void setAge(int age){
 //驗證傳入進來的age否大于18,如果小于就直接return,否則就添加到該對象的age屬性中。
  if(age<18){
   return; 
 }
 this.age = age;
}

 4:實現serializable接口?
回答:為了實現遠程調用。比如我們要把該JavaBean從一個操作系統中傳輸到另一臺操作系統,我們就只有采取實現該接口。

JavaBean的動作:
    <!-- 創建user對象 -->
 1: 創建動作:  <jsp:useBean id="user" class="com.lovo.User" scope="request" />
    id:一個變量名。可以任意取。
    classs:指明變量的類型,也就是說具體描述的一個對象。包名加類名
    scope:總用于范圍。 也就是說在我們在查找一個屬性值的時候,首先是從他的一個作用域中去進行查找,如果找到就直接把它輸出,否則創建一個新的(null)。

    <!-- 設置user對象中的userName屬性 單一屬性。。-->
 2:設置動作:     <jsp:setProperty name="user" property="userName" value="222" param="123"/> 
     name:必須和創建動作的id一樣。
     property:具體的某一個屬性值。
     value:設置該屬性的值。
     param:是將請求到的值附加到userName屬性中.
  
    <!-- 代表名字相同的自動填充。 如:http://localhost:8080/Huang_JavaBean/index.jsp?userName=444&password=123-->
     <jsp:setProperty name="user" property="*"  /> 
     name:必須和創建動作的id一樣。
     property:設置相同屬性名的值他會自動填充。
    
 3:輸出動作:
   
   <!-- 輸出信息 。 相似于 out.println(user.getuserName()) -->
   <jsp:getProperty name="user" property="userName" />
   <jsp:getProperty name="user" property = "password"/>
開發模式:
 為什么進行分層的開發?
  1:主要是為了并發性的開發項目。比如:你做持久層,我做業務層
  2:可以獨立的測試,每一個方法。
  3:分層的開發的好處還有一個就是一處代碼的改變不會影響到另一處代碼的改變。

在這里說一下servlet和jsp的一些缺陷.
 servlet的缺陷使web應用程序開發變得非常繁瑣且不利于分工協作。
 jsp頁面嚴重的缺乏代碼的可讀性而且沒有將頁面的表現和業務邏輯分開,使維護變得更加復雜。

在這章講到了兩種開發模式:
 模式一:JSP+JavaBean
 模式二:JSP+Servlet+JavaBean

現在大多數情況下都不用模式一,所以我就解釋了。
所謂的模式二就是現在比較流行的一個模式,也叫MVC模式。

那么什么是MVC模式?

      M(model)模型層,即完成業務功能部分,也要完成持久功能。

      V(view)視圖層,用于客戶端進行頁面展現的部分,一般是jsp和html。

      C(controller)控制層,轉么用于調用業務層,進行邏輯判斷,看他跳入那個頁面。

MVC的一個最大的好處是實現了良好的松散耦合。

  PO(persistentobject)持久化對象,它通常是在分析系統需求時,外名詞或名詞短語中抽取出來(javaBan).

  DAO(datebase access  object)數據庫訪問對象,用于對象關系映射時或對象持久化,他封裝了所有的JDBC操作

  BO(business   Object)業務層對象,用于完成業務功能的類

  VO(value object)值對象,用于封裝各層次間要傳輸的數據

 



Tomas 2011-10-10 23:18 發表評論
]]>
主站蜘蛛池模板: 精品97国产免费人成视频| 一级免费黄色大片| 国产香蕉免费精品视频| 亚洲AV无码AV男人的天堂| 国产一级a毛一级a看免费人娇| 国产精品V亚洲精品V日韩精品 | 成人毛片免费观看视频| 亚洲三级在线播放| 久久不见久久见免费影院| 99久久国产亚洲综合精品| 日韩中文字幕在线免费观看| 羞羞网站免费观看| 亚洲国产成人精品91久久久| 亚洲一级片免费看| 99人中文字幕亚洲区| 免费A级毛片无码无遮挡内射| 国产精品亚洲片在线va| 又爽又黄无遮挡高清免费视频| 深夜A级毛片视频免费| 一本色道久久综合亚洲精品高清| 女人隐私秘视频黄www免费| 亚洲另类激情综合偷自拍 | 老司机午夜在线视频免费| 亚洲国产中文字幕在线观看| 免费萌白酱国产一区二区三区| 91天堂素人精品系列全集亚洲| 成人性生交视频免费观看| 免费又黄又爽又猛大片午夜| 久久精品国产亚洲香蕉| 久久久www成人免费毛片| 免费人成在线观看播放a| 亚洲国产精彩中文乱码AV| 大地资源免费更新在线播放| 色吊丝性永久免费看码| 亚洲视频在线观看一区| 日韩一区二区免费视频| 中文无码成人免费视频在线观看| 亚洲日韩乱码中文字幕| 亚洲中文字幕无码永久在线| 国产成人免费在线| 一级毛片免费在线|