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