摘要: 首先我們需要一個(gè)被加載的js文件,我在一個(gè)固定文件夾下創(chuàng)建了一個(gè)package.js,打開后在里面寫一個(gè)方法functionOne,很簡單,代碼如下:function functionOne(){
alert("成功加載");
}后面的html文件都創(chuàng)建在同一個(gè)目錄下。方法一:直接document.write在同一個(gè)文件夾下面創(chuàng)建一個(gè)function1.html,代碼如下:<ht...
閱讀全文
posted @
2013-06-01 09:19 Tomas 閱讀(400) |
評論 (0) |
編輯 收藏
多文件上傳 jquery的插件
使用的方法 導(dǎo)入 jquery.js 及 jquery.MultiFile.js ,
方式一: 后臺是文件數(shù)組
private File[] upload; // 與jsp表單中的名稱對應(yīng)
private String[] uploadFileName;
private String[] uploadContentType;
在 form 中加入 <input type="file" name="upload[]" class="multi" /> 即可。
方式二:后臺是List<File>
private List<File> upload; // 與jsp表單中的名稱對應(yīng)
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> |
參數(shù)說明:
參數(shù) |
說明 |
說明 |
class="multi" maxlength="2" |
Limit: 2 files. Allowed extensions: any. |
限制數(shù)量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. |
限制數(shù)量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) |
編輯 收藏
/**
* 數(shù)字轉(zhuǎn)換為大寫人民幣計(jì)數(shù)
* @author 王代軍
* @since Dec 16,2011
*/
public class Num2Rmb
{
private String[] hanArr = {"零" , "壹" , "貳" , "叁" , "肆" ,
"伍" , "陸" , "柒" , "捌" , "玖"};
private String[] unitArr = {"拾","百","千","萬"};
/**
* 把一個(gè)四位的數(shù)字字符串變成漢字字符串
* @param numStr 需要被轉(zhuǎn)換的四位的數(shù)字字符串
* @return 四位的數(shù)字字符串被轉(zhuǎn)換成的漢字字符串。
*/
private String toHanStr(String numStr)
{
String result = "";
int numLen = numStr.length();
//依次遍歷數(shù)字字符串的每一位數(shù)字
for (int i = 0 ; i < numLen ; i++ )
{
//把char型數(shù)字轉(zhuǎn)換成的int型數(shù)字,因?yàn)樗鼈兊腁SCII碼值恰好相差48
//因此把char型數(shù)字減去48得到int型數(shù)字,例如'4'被轉(zhuǎn)換成4。
int num = numStr.charAt(i) - 48;
//如果不是最后一位數(shù)字,而且數(shù)字不是零,則需要添加單位(千、百、十)
if ( i != numLen - 1 && num != 0)
{
result += hanArr[num] + unitArr[numLen - 2 - i];
}
//否則不要添加單位
else
{
//上一個(gè)數(shù)是否為“零”,不為“零”時(shí)就添加
if(result.length()>0 && hanArr[num].equals("零") && result.charAt(result.length()-1)=='零')
continue;
result += hanArr[num];
}
}
//只有個(gè)位數(shù),直接返回
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;
}
}
/**
* 把一個(gè)輸入的數(shù)字字符串變成漢字字符串
* @param numStr 需要被轉(zhuǎn)換得到數(shù)字字符串
* @return 數(shù)字字符串被轉(zhuǎn)換成的漢字RMB字符串。
*/
private String toRmbStr(String numStr){
//獲取字符串長度
int numLen = numStr.length();
//判斷長度小于4(一萬以內(nèi)~0-9999) 調(diào)用toHanStr();
if(numLen<=4){
return toHanStr(numStr);
}
//4<長度<=8 (一億以內(nèi) 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 (百億以內(nèi) 一億-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("只支持整數(shù)(0~99億)");
//測試把一個(gè)四位的數(shù)字字符串變成漢字字符串
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一個(gè)
CommonCrudUtil(本類)實(shí)例 實(shí)現(xiàn)對數(shù)據(jù)的增刪改查
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 要查詢的對象的 可序列化的字段 (本設(shè)計(jì)指主鍵 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();
}
}
/**
* 查詢?nèi)抗δ?br /> * @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 要?jiǎng)h除的對象的類型 obj 要?jiǎng)h除的對象的 唯一標(biāo)識(可序列化)字段 (指主鍵 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;
}
}
調(diào)用實(shí)現(xiàn) dao層的實(shí)現(xiàn)類調(diào)用
CommonCrudUtil 的方法實(shí)現(xiàn)增刪改查
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);
。。。。。。查詢?nèi)俊!!!!?br />
crud.retrieve(IDCard.class);
。。。。。。修改。。。。
crud.update(card);
。。。。。。刪除。。。。
crud.delete(IDCard.class,3);
。。。。。。。。。
寫的簡陋些 只是些想法可借鑒而已 同志們 可以自己完善。。。。
posted @
2011-12-26 13:22 Tomas 閱讀(2011) |
評論 (1) |
編輯 收藏
Oracle的默認(rèn)服務(wù)一共有5個(gè):
1.OracleDBConsoleorcl oem控制臺的服務(wù)進(jìn)程
2.OracleJobSchedulerORCL 定時(shí)器的服務(wù)進(jìn)程
3.OracleOraDb10g_home1iSQL*Plus isql*plus的服務(wù)進(jìn)程
4.OracleOraDb10g_home1TNSListener 監(jiān)聽器的服務(wù)進(jìn)程
5.OracleServiceORCL 數(shù)據(jù)庫服務(wù)進(jìn)程
要查看系統(tǒng)中已啟動(dòng)的服務(wù),我們可以在“開始→控制面板→管理工具”中雙擊“服務(wù)”,或者直接
在“運(yùn)行”中輸入 “Services.msc”打開服務(wù)設(shè)置對話框,就可以看到每一個(gè)服務(wù)都有以下幾個(gè)屬
性:名稱、描述、狀態(tài)、啟動(dòng)類型、登錄身份、依存關(guān)系。
OracleDBConsoleorcl --可以不啟動(dòng),用于管理Oracle的企業(yè)管理器的服務(wù).
OracleJobSchedulerORCL --通常不啟動(dòng),用于定期操作任務(wù)的服務(wù)
OracleOraDb10g_home1iSQL*Plus --可以不啟動(dòng),這是isqlplus服務(wù),用于用網(wǎng)頁執(zhí)行sql執(zhí)行,11g已
經(jīng)取消了這個(gè)功能
OracleOraDb10g_home1TNSListener --必須啟動(dòng),這是臨聽,用于遠(yuǎn)程客戶端連接你的Oracle
OracleServiceORCL --必須啟動(dòng),這是Oracle數(shù)據(jù)庫的服務(wù)
可以用命令啟動(dòng):
#啟動(dòng)listener:
lsnrctl start
#啟動(dòng)數(shù)據(jù)庫
net start OracleServiceORCL
只有這兩項(xiàng)是必須啟動(dòng)的:
OracleOraDb10g_home1TNSListener
OracleServiceORCL
為什么OracleJobSchedulerORCL會(huì)顯示禁用?
數(shù)據(jù)庫工作日程調(diào)度,一般沒有安排工作日程就不需要啟動(dòng),為什么默認(rèn)是禁用?因?yàn)閱?dòng)后會(huì)占用很大的系統(tǒng)資源。
(1)OracleServiceSID
數(shù)據(jù)庫服務(wù),這個(gè)服務(wù)會(huì)自動(dòng)地啟動(dòng)和停止數(shù)據(jù)庫。如果安裝了一個(gè)數(shù)據(jù)庫,它的缺省啟動(dòng)類型為自動(dòng)。服務(wù)進(jìn)程為Oracle.EXE,參數(shù)文件initSID.ora,日志文件SIDALRT.log,控制臺SVRMGRL.EXE、SQLPLUS.EXE。
(2)OracleHOME_NAMETNSListener
監(jiān)聽器服務(wù),服務(wù)只有在數(shù)據(jù)庫需要遠(yuǎn)程訪問時(shí)才需要(無論是通過另外一臺主機(jī)還是在本地通過 SQL.Net 網(wǎng)絡(luò)協(xié)議都屬于遠(yuǎn)程訪問),不用這個(gè)服務(wù)就可以訪問本地?cái)?shù)據(jù)庫,它的缺省啟動(dòng)類型為自動(dòng)。服務(wù)進(jìn)程為TNSLSNR.EXE,參數(shù)文件 Listener.ora,日志文件listener.log,控制臺LSNRCTL.EXE,默認(rèn)端口1521、1526。
(3)OracleHOME_NAMEAgent
OEM代理服務(wù),接收和響應(yīng)來自O(shè)EM控制臺的任務(wù)和事件請求,只有使用OEM管理數(shù)據(jù)庫時(shí)才需要,它的缺省啟動(dòng)類型為自動(dòng)。服務(wù)進(jìn)程為DBSNMP.EXE,參數(shù)文件snmp_rw.ora,日志文件nmi.log,控制臺LSNRCTL.EXE,默認(rèn)端口1748。
(4)OracleHOME_NAMEClientCache
名字緩存服務(wù),服務(wù)緩存用于連接遠(yuǎn)程數(shù)據(jù)庫的Oracle Names 數(shù)據(jù)。它的缺省啟動(dòng)類型是手動(dòng)。然而,除非有一臺Oracle Names 服務(wù)器,否則沒有必要運(yùn)行這個(gè)服務(wù)。服務(wù)進(jìn)程為ONRSD.EXE,參數(shù)文件NAMES.ORA,日志文件ONRSD.LOG,控制臺 NAMESCTL.EXE。
(5)OracleHOME_NAMECMAdmin
連接管理服務(wù),是構(gòu)建Connection Manager服務(wù)器所用,只有服務(wù)器作為Connection Manager才需要,它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程為CMADMIN.EXE,參數(shù)文件CMAN.ORA,日志文件CMADM_PID.TRC,控 制臺CMCTL.EXE,默認(rèn)端口1830。
(6)OracleHOME_NAMECMan
連接網(wǎng)關(guān)服務(wù),是構(gòu)建Connection Manager服務(wù)器所用,只有服務(wù)器作為Connection Manager才需要,它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程為CMGW.EXE,參數(shù)文件CMAN.ORA,日志文件CMAN_PID.TRC,控制臺 CMCTL.EXE,默認(rèn)端口1630。
(7)OracleHOME_NAMEDataGatherer
性能包數(shù)據(jù)采集服務(wù),除非使用Oracle Capacity Planner 和 Oracle Performance Manager,否則不需要啟動(dòng),它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程為VPPDC.EXE,日志文件alert_dg.log,控制臺 vppcntl.exe。
(8)OracleHOME_NAMEHTTPServer
Oracle提供的WEB服務(wù)器,一般情況下我們只用它來訪問Oracle Apache 目錄下的Web 頁面,比如說JSP 或者modplsql 頁面。除非你使用它作為你的HTTP服務(wù),否則不需要啟動(dòng)(若啟動(dòng)它會(huì)接管IIS的服務(wù)),它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程為APACHE.EXE,參 數(shù)文件httpd.conf,默認(rèn)端口80。
(9)OracleHOME_NAMEPagingServer
通過一個(gè)使用調(diào)制解調(diào)器的數(shù)字傳呼機(jī)或者電子郵件發(fā)出警告(沒試過),它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程PAGNTSRV.EXE,日志文件paging.log。
(10)OracleHOME_NAMENames
Oracle Names服務(wù),只有服務(wù)器作為Names Server才需要,它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程N(yùn)AMES.EXE,參數(shù)文件NAMES.ORA,日志文件NAMES.LOG,控制臺NAMESCTL.EXE,默認(rèn)端口1575。
(11)OracleSNMPPeerMasterAgent
SNMP服務(wù)代理,用于支持SNMP的網(wǎng)管軟件對服務(wù)器的管理,除非你使用網(wǎng)管工具監(jiān)控?cái)?shù)據(jù)庫的情況,否則不需要啟動(dòng),它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程為AGNTSVC.EXE,參數(shù)文件MASTER.CFG,默認(rèn)端口161。
(12)OracleSNMPPeerEncapsulater
SNMP協(xié)議封裝服務(wù),用于SNMP協(xié)議轉(zhuǎn)換,除非你使用一個(gè)不兼容的SNMP代理服務(wù),否則不需要啟動(dòng),它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程為ENCSVC.EXE,參數(shù)文件ENCAPS.CFG,默認(rèn)端口1161。
(13)OracleHOME_NAMEManagementServer
OEM管理服務(wù),使用OEM時(shí)需要,它的缺省啟動(dòng)類型是手動(dòng)。服務(wù)進(jìn)程為OMSNTSVR.EXE,日志文件oms.nohup。
OracleServiceMYDB
OracleOraHome92TNSListener
別的一般不用開,有需要再開
附(批處理)
:doit
@echo off
set /p xz=按"kq"鍵啟動(dòng)服務(wù)------按"gb"關(guān)閉服務(wù)
if %xz%==kq goto kq
if %xz%==gb goto gb
goto doit
:kq
@echo off
echo 正在啟動(dòng)oracle服務(wù),請稍等......
net start OracleServiceORCL
net start OracleDBConsoleorcl
net start OracleOraDb10g_home1TNSListener
net start OracleOraDb10g_home1iSQL*Plus
echo 啟動(dòng)oracle服務(wù)完成
echo. & pause
goto doit
:gb
@echo off
echo 正在關(guān)閉oracle服務(wù),請稍等.......
net stop OracleServiceORCL
net stop OracleDBConsoleorcl
net stop OracleOraDb10g_home1TNSListener
net stop OracleOraDb10g_home1iSQL*Plus
echo 關(guān)閉oracle服務(wù)完成
echo. & pause
goto doit
把代碼復(fù)制 保存 修改后綴名為.bat 執(zhí)行即可;
posted @
2011-11-09 11:50 Tomas 閱讀(167) |
評論 (0) |
編輯 收藏