隨筆 - 7  文章 - 3  trackbacks - 0
          <2011年10月>
          2526272829301
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345

          常用鏈接

          留言簿

          隨筆檔案

          文章分類

          文章檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

               摘要: 首先我們需要一個被加載的js文件,我在一個固定文件夾下創建了一個package.js,打開后在里面寫一個方法functionOne,很簡單,代碼如下:function functionOne(){ alert("成功加載"); }后面的html文件都創建在同一個目錄下。方法一:直接document.write在同一個文件夾下面創建一個function1.html,代碼如下:<ht...  閱讀全文
          posted @ 2013-06-01 09:19 Tomas 閱讀(400) | 評論 (0)編輯 收藏


          多文件上傳 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

          posted @ 2013-05-17 15:56 Tomas 閱讀(4191) | 評論 (2)編輯 收藏
          /**
           * 數字轉換為大寫人民幣計數
           * @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"));
              }
          }

          posted @ 2011-12-26 13:26 Tomas 閱讀(569) | 評論 (0)編輯 收藏
          通用的增刪該查工具類  可在dao層 new一個
          CommonCrudUtil(本類)實例  實現對數據的增刪改查




          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);
          。。。。。。。。。



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




          posted @ 2011-12-26 13:22 Tomas 閱讀(2011) | 評論 (1)編輯 收藏

          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 執行即可;

          posted @ 2011-11-09 11:50 Tomas 閱讀(167) | 評論 (0)編輯 收藏





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

          我們都知道,為了在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。

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

          posted @ 2011-10-16 21:29 Tomas 閱讀(241) | 評論 (0)編輯 收藏
          主站蜘蛛池模板: 富源县| 凉山| 绵阳市| 双峰县| 定远县| 德安县| 彰化市| 盈江县| 华池县| 新建县| 晴隆县| 静海县| 绥化市| 孟州市| 大足县| 香格里拉县| 南乐县| 资中县| 沂水县| 崇阳县| 兴化市| 营口市| 河北省| 新津县| 屏南县| 黔西| 禹州市| 澄城县| 宾阳县| 保定市| 江口县| 石家庄市| 安岳县| 紫云| 凤台县| 厦门市| 洛川县| 来宾市| 南充市| 德庆县| 秦安县|