2012年2月10日
1 package poi;
2 import java.io.FileInputStream;
3 import java.io.IOException;
4 import java.io.InputStream;
5 import java.util.Iterator;
6 import org.apache.poi.hssf.usermodel.HSSFCell;
7 import org.apache.poi.hssf.usermodel.HSSFWorkbook;
8 import org.apache.poi.ss.usermodel.Cell;
9 import org.apache.poi.ss.usermodel.Row;
10 import org.apache.poi.ss.usermodel.Sheet;
11 import org.apache.poi.ss.usermodel.Workbook;
12 import org.apache.poi.xssf.usermodel.XSSFWorkbook;
13
14 public class ReadExcel001 {
15 public static void main(String[] args) {
16 readXml("D:/test.xlsx");
17 System.out.println("-------------");
18 readXml("d:/test2.xls");
19 }
20 public static void readXml(String fileName){
21 boolean isE2007 = false; //判斷是否是excel2007格式
22 if(fileName.endsWith("xlsx"))
23 isE2007 = true;
24 try {
25 InputStream input = new FileInputStream(fileName); //建立輸入流
26 Workbook wb = null;
27 //根據文件格式(2003或者2007)來初始化
28 if(isE2007)
29 wb = new XSSFWorkbook(input);
30 else
31 wb = new HSSFWorkbook(input);
32 Sheet sheet = wb.getSheetAt(0); //獲得第一個表單
33 Iterator<Row> rows = sheet.rowIterator(); //獲得第一個表單的迭代器
34 while (rows.hasNext()) {
35 Row row = rows.next(); //獲得行數據
36 System.out.println("Row #" + row.getRowNum()); //獲得行號從0開始
37 Iterator<Cell> cells = row.cellIterator(); //獲得第一行的迭代器
38 while (cells.hasNext()) {
39 Cell cell = cells.next();
40 System.out.println("Cell #" + cell.getColumnIndex());
41 switch (cell.getCellType()) { //根據cell中的類型來輸出數據
42 case HSSFCell.CELL_TYPE_NUMERIC:
43 System.out.println(cell.getNumericCellValue());
44 break;
45 case HSSFCell.CELL_TYPE_STRING:
46 System.out.println(cell.getStringCellValue());
47 break;
48 case HSSFCell.CELL_TYPE_BOOLEAN:
49 System.out.println(cell.getBooleanCellValue());
50 break;
51 case HSSFCell.CELL_TYPE_FORMULA:
52 System.out.println(cell.getCellFormula());
53 break;
54 default:
55 System.out.println("unsuported sell type");
56 break;
57 }
58 }
59 }
60 } catch (IOException ex) {
61 ex.printStackTrace();
62 }
63 }
64 }
tomcat如果是通過windows服務啟動,執行的是bin\tomcat.exe.他讀取注冊表中的值,而不是catalina.bat的設置.解決辦法:修改注冊表HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Procrun 2.0\Tomcat6\Parameters\JavaOptions原值為-Dcatalina.home=E:\Tomcat 6.0-Dcatalina.base=E:\Tomcat 6.0-Djava.endorsed.dirs=E:\Tomcat 6.0\common\endorsed-Djava.io.tmpdir=E:\Tomcat 6.0\temp-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager-Djava.util.logging.config.file=E:\Tomcat 6.0\conf\logging.properties
在后面增加即可:
-Xms128M
-Xmx512M
-XX:PermSize=128M
-XX:MaxPermSize=512M
必須要分行寫。
最終效果如下:

當一個數據庫的數據文件達到表空間的最大值時,報ORA-1653:的錯誤。如下:
ORA-1653: unable to extend table TEST.COMM_DTTR_SVR_LOG by64 in tablespace TEST_SPACE
解決:
可以在該表空間中增加一個數據文件,增加的數據文件為自動擴展,無限擴大。
查看數據文件的大小和最大的值,可以查詢dba_data_files;
Sql>
alter tablespace TEST_SPACE
adddatafile'/Oracle/oms/oradata/pub/Norm_data001.dbf'
size 10M autoextend on MAXSIZE UNLIMITED;
或者把該表空間所在的數據文件設置成自動擴張,設置該maxsize更大,unlimited表示沒有限制。
SQL>
alter database
datafile '/oracle/oms/oradata/pub/Pub_Norm_data001.dbf'
autoextend on maxsize unlimited;
共計以下4個文件 點擊“下載”
login.html
welcome.html
cookie.js
common.js
login.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>login</title>
<script type="text/javascript" src="cookie.js"></script>
<script type="text/javascript" src="common.js"></script>
</head>
<body>
<form action="">
<p>
<span>UserName:</span>
<input id="userName" type="text" value=""/></p>
<p>
<span>Password:</span>
<input id="password" type="password" value=""/></p>
<p>
<span style="font-size:12px; color:blue;">記住密碼</span>
<input id="saveCookie" type="checkbox" value="" /></p>
<p>
<input id="submit" type="button" value="GO" />
</p>
</form>
</body>
</html>
welcome.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>welcome</title>
</head>
<body>
<h1>Welcome!</h1>
<a href="login.html">點擊返回登陸框</a>
</body>
</html>
cookie.js
//新建cookie。
//hours為空字符串時,cookie的生存期至瀏覽器會話結束。hours為數字0時,建立的是一個失效的cookie,這個cookie會覆蓋已經建立過的同名、同path的cookie(如果這個cookie存在)。
function setCookie(name,value,hours,path){
var name = escape(name);
var value = escape(value);
var expires = new Date();
expires.setTime(expires.getTime() + hours*3600000);
path = path == "" ? "" : ";path=" + path;
_expires = (typeof hours) == "string" ? "" : ";expires=" + expires.toUTCString();
document.cookie = name + "=" + value + _expires + path;
}
//獲取cookie值
function getCookieValue(name){
var name = escape(name);
//讀cookie屬性,這將返回文檔的所有cookie
var allcookies = document.cookie;
//查找名為name的cookie的開始位置
name += "=";
var pos = allcookies.indexOf(name);
//如果找到了具有該名字的cookie,那么提取并使用它的值
if (pos != -1){ //如果pos值為-1則說明搜索"version="失敗
var start = pos + name.length; //cookie值開始的位置
var end = allcookies.indexOf(";",start); //從cookie值開始的位置起搜索第一個";"的位置,即cookie值結尾的位置
if (end == -1) end = allcookies.length; //如果end值為-1說明cookie列表里只有一個cookie
var value = allcookies.substring(start,end); //提取cookie的值
return (value); //對它解碼
}
else return ""; //搜索失敗,返回空字符串
}
//刪除cookie
function deleteCookie(name,path){
var name = escape(name);
var expires = new Date(0);
path = path == "" ? "" : ";path=" + path;
document.cookie = name + "="+ ";expires=" + expires.toUTCString() + path;
}
common.js
function $(objStr){return document.getElementById(objStr);}
window.onload = function(){
//分析cookie值,顯示上次的登陸信息
var userNameValue = getCookieValue("userName");
$("userName").value = userNameValue;
var passwordValue = getCookieValue("password");
$("password").value = passwordValue;
//寫入點擊事件
$("submit").onclick = function()
{
var userNameValue = $("userName").value;
var passwordValue = $("password").value;
//服務器驗證(模擬)
var isAdmin = userNameValue == "admin" && passwordValue =="123456";
var isUserA = userNameValue == "userA" && passwordValue =="userA";
var isMatched = isAdmin || isUserA;
if(isMatched){
if( $("saveCookie").checked){
setCookie("userName",$("userName").value,24,"/");
setCookie("password",$("password").value,24,"/");
}
alert("登陸成功,歡迎你," + userNameValue + "!");
self.location.replace("welcome.html");
}
else alert("用戶名或密碼錯誤,請重新輸入!");
}
}
Oracle提示錯誤消息ORA-28001: the password has expired
Oracle提示錯誤消息ORA-28001: the password has expired,
經調查是由于Oracle11G的新特性所致, Oracle11G創建用戶時缺省密碼過期限制是180天, 如果超過180天用戶密碼未做修改則該用戶無法登錄。
可通過
SELECT * FROM dba_profiles WHERE profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME'
語句查詢密碼的有效期設置,
LIMIT字段是密碼有效天數。在密碼將要過期或已經過期時可通過
ALTER USER 用戶名 IDENTIFIED BY 密碼 ;
語句進行修改密碼,密碼修改后該用戶可正常連接數據庫。
長久對應可通過
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED
語句將口令有效期默認值180天修改成“無限制”。出于數據庫安全性考慮,不建議將PASSWORD_LIFE_TIME值設置成UNLIMITED,
建議客戶定期修改數據庫用戶口令。
轉載于
http://hi.baidu.com/yuelsygfixbqsuq/item/ddfc8e4b4888ae1e896d10c0
1、安裝eclipse的jrebel插件
Help » Install New Software
然后通過 如下 URL http://www.zeroturnaround.com/update-site/
如果要離線下載的話,可以通過下載離線包的方式進行 http://www.zeroturnaround.com/update-site/update-site.zip

2、下載jrebel5破解版
下載jrebel5破解版以后解壓到D盤根目錄即可
下載地址 :http://download.csdn.net/detail/lushengdi/5080360
配置jrebel破解版JAR包的路徑 :
3、配置jetty實現熱部署
這是為jetty加載jrebel的關鍵。
項目右鍵 》 run as 》 run configuation.. 》 點擊jetty項目
在mvn jetty:run的JRE管理選項卡中的VM參數中加入
-noverify -javaagent:d:/jrebel/jrebel.jar

現在在eclipse中啟動mvn jetty:run,jrebel將被加載,修改java代碼可以不重啟jetty而熱部署生效了,
修改java文件后自動在輸出窗口中顯示重新加載的信息

tomcat 配置 參考
http://zeroturnaround.com/jrebel/how-to-install-and-use-jrebel-formerly-javarebel-in-tomcat-with-the-eclipse-ide/
摘要: 安裝篇jspSmartUpload是由www.jspsmart.com網站開發的一個可免費使用的全功能的文件上傳下載組件,適于嵌入執行上傳下載操作的JSP文件中。該組件有以下幾個特點:1、使用簡單。在JSP文件中僅僅書寫三五行JAVA代碼就可以搞定文件的上傳或下載,方便。2、能全程控制上傳。利用jspSmartUpload組件提供的對象及其操作方法,可以獲得全部上傳文件的信息(包括文件名,大小,類...
閱讀全文
摘要:
瀏覽器緩存內幕及解決方案 在下面三種不同的情況下,瀏覽器的緩存情況不同: 1).Servlet沒有覆蓋getLastModified方法,響應消息中無LastModified頭字段,在瀏覽器緩存的文檔無“上次修改時間”. 2).有ge...
閱讀全文
純js的判斷瀏覽器的版本,包括IE(6,7,8),FF,chrome,opera,safari的,很好用,很多地方會用到,有時不需要為了一個效果而導入一個js庫來調用,用這段代碼就很好。Code:
<script type="text/javascript">
var Sys = {};
var ua = navigator.userAgent.toLowerCase();
var s;
(s = ua.match(/msie ([\d.]+)/)) ? Sys.ie = s[1] :
(s = ua.match(/firefox\/([\d.]+)/)) ? Sys.firefox = s[1] :
(s = ua.match(/chrome\/([\d.]+)/)) ? Sys.chrome = s[1] :
(s = ua.match(/opera.([\d.]+)/)) ? Sys.opera = s[1] :
(s = ua.match(/version\/([\d.]+).*safari/)) ? Sys.safari = s[1] : 0;
/*以下進行測試
if (Sys.ie) alert('IE: ' + Sys.ie);
if (Sys.firefox) alert('Firefox: ' + Sys.firefox);
if (Sys.chrome) alert('Chrome: ' + Sys.chrome);
if (Sys.opera) alert('Opera: ' + Sys.opera);
if (Sys.safari) alert('Safari: ' + Sys.safari);
if (Sys.ie == 6.0){alert("fuck!")}
*/
</script>
密碼過期,需要更換新密碼
SQL> alter user test identified by [new password];
解鎖
SQL> alter user test account unlock;
User altered.
一般數據庫默認是10次嘗試失敗后鎖住用戶
1、查看FAILED_LOGIN_ATTEMPTS的值
select * from dba_profiles
2、修改為30次
alter profile default limit FAILED_LOGIN_ATTEMPTS 30;
3、修改為無限次(為安全起見,不建議使用)
alter profile default limit FAILED_LOGIN_ATTEMPTS unlimited;
設置用戶密碼永不過期
1 查看用戶概要文件(一般是DEFAULT)
select * from dba_users where username=test;
2 查看指定概要文件(如default)的密碼有效期設置(默認在default概要文件中設置了 “PASSWORD_LIFE_TIME=180天”):
SELECT * FROM dba_profiles WHERE profile='DEFAULT' and resource_name='PASSWORD_LIFE_TIME';
3 將密碼有效期由默認的180天修改成“無限制”:
sql>ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;
修改之后不需要重啟動數據庫,會立即生效。
轉載于 http://database.51cto.com/art/201108/280966.htm
步驟一--完成一層
1、第一層十字,可能出現兩種情況,可用以下公式還原
a)R2
b)D'F'RF
2、第一層角
a)D'R'DR
b)R'D'R
步驟二--第二層
a)y'RURURU'R'U'R'U' 五順五逆
b)R'U'R'U'R'URURU 五逆五順
步驟三--OLL
1、頂層十字
FRUR'U'F'
2、頂層角塊
R'U2RUR'UR
步驟四--PLL
1、頂層角還原
x' R2 U2 R D R' U2 R D' R x
2、頂層棱還原
(RU'R)(URUR)(U'R'U'R2)
假設你的存儲過程名為PROC_RAIN_JM 再寫一個存儲過程名為PROC_JOB_RAIN_JM 內容是: - Create Or Replace Procedure PROC_JOB_RAIN_JM
- Is
- li_jobno Number;
-
- Begin
- DBMS_JOB.SUBMIT(li_jobno,'PROC_RAIN_JM;',SYSDATE,'TRUNC(SYSDATE + 1)');
- End;
提交job語法: - begin
- sys.dbms_job.submit(job => :job,
- what => 'P_CLEAR_PACKBAL;',
- next_date => to_date('04-08-2008 05:44:09', 'dd-mm-yyyy hh24:mi:ss'),
- interval => 'sysdate+ 1/360');
- commit;
- end;
------------------------- 創建JOB - variable jobno number;
- begin
- dbms_job.submit(:jobno, 'P_CRED_PLAN;',SYSDATE,'SYSDATE+1/2880',TRUE);
- commit;
運行JOB - begin
- dbms_job.run(:job1);
- end;
刪除JOB - begin
- dbms_job.remove(:job1);
- end;
DBA_JOBS ========================================= 字段(列) 類型 描述 JOB NUMBER 任務的唯一標示號 LOG_USER VARCHAR2(30) 提交任務的用戶 PRIV_USER VARCHAR2(30) 賦予任務權限的用戶 SCHEMA_USER VARCHAR2(30) 對任務作語法分析的用戶模式 LAST_DATE DATE 最后一次成功運行任務的時間 LAST_SEC VARCHAR2(8) 如HH24:MM:SS格式的last_date日期的小時,分鐘和秒 THIS_DATE DATE 正在運行任務的開始時間,如果沒有運行任務則為null THIS_SEC VARCHAR2(8) 如HH24:MM:SS格式的this_date日期的小時,分鐘和秒 NEXT_DATE DATE 下一次定時運行任務的時間 NEXT_SEC VARCHAR2(8) 如HH24:MM:SS格式的next_date日期的小時,分鐘和秒 TOTAL_TIME NUMBER 該任務運行所需要的總時間,單位為秒 BROKEN VARCHAR2(1) 標志參數,Y標示任務中斷,以后不會運行 INTERVAL VARCHAR2(200) 用于計算下一運行時間的表達式 FAILURES NUMBER 任務運行連續沒有成功的次數 WHAT VARCHAR2(2000) 執行任務的PL/SQL塊 CURRENT_SESSION_LABEL RAW MLSLABEL 該任務的信任Oracle會話符 CLEARANCE_HI RAW MLSLABEL 該任務可信任的Oracle最大間隙 CLEARANCE_LO RAW MLSLABEL 該任務可信任的Oracle最小間隙 NLS_ENV VARCHAR2(2000) 任務運行的NLS會話設置 MISC_ENV RAW(32) 任務運行的其他一些會話參數 -------------------------- 描述 INTERVAL參數值 每天午夜12點 'TRUNC(SYSDATE + 1)' 每天早上8點30分 'TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)' 每星期二中午12點 'NEXT_DAY(TRUNC(SYSDATE ), ''TUESDAY'' ) + 12/24' 每個月第一天的午夜12點 'TRUNC(LAST_DAY(SYSDATE ) + 1)' 每個季度最后一天的晚上11點 'TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), 'Q' ) -1/24' 每星期六和日早上6點10分 'TRUNC(LEAST(NEXT_DAY(SYSDATE, ''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)' -------------------------- 1:每分鐘執行 Interval => TRUNC(sysdate,'mi') + 1/ (24*60) 2:每天定時執行 例如:每天的凌晨1點執行 Interval => TRUNC(sysdate) + 1 +1/ (24) 3:每周定時執行 例如:每周一凌晨1點執行 Interval => TRUNC(next_day(sysdate,'星期一'))+1/24 4:每月定時執行 例如:每月1日凌晨1點執行 Interval =>TRUNC(LAST_DAY(SYSDATE))+1+1/24 5:每季度定時執行 例如每季度的第一天凌晨1點執行 Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 1/24 6:每半年定時執行 例如:每年7月1日和1月1日凌晨1點 Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24 7:每年定時執行 例如:每年1月1日凌晨1點執行 Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24 TRUNC()函數分兩種 trunc實際上是truncate函數,字面意思是截斷,截尾。 1.TRUNC(for dates) TRUNC函數為指定元素而截去的日期值。截尾后返回最近日期 其具體的語法格式如下: TRUNC(date[,fmt]) date 一個日期值 fmt 日期格式,該日期將由指定的元素格式所截去。忽略它則由最近的日期截去 下面是該函數的使用情況: select trunc(sysdate,'mm') from dual=2009-1-1 2.TRUNC(for number) TRUNC函數的功能是將數字進行截斷,對所截取的結果并不四舍五入。 其具體的語法格式如下 TRUNC(number[,decimals]) number 待做截取處理的數值 decimals 指明需保留小數點后面的位數。可選項,忽略它則截去所有的小數部分 下面是該函數的使用情況: TRUNC(89.985,2)=89.98 TRUNC(89.985)=89 TRUNC(89.985,-1)=80 注意:第二個參數可以為負數,表示為小數點左邊指定位數后面的部分截去,即均以0記。 轉載于
http://virgoooos.iteye.com/blog/342421
Eclipse是著名的跨平臺的自由集成開發環境(IDE)。6月22日Eclipse 3.7 正式發布,代號是 Indigo 。

在 Windows 7 下初始后化,發現界面變化不大,但中文字體卻面目全非,小得根本看不見,而且也看起來很不爽。其實這是 Eclipse 的默認字體換了,以前的一直是 Courier New ,這次eclipse用的字體是 Consolas ,這是一個很好的編程字體了,無奈就是中文默認太小了。

于是上網找了 Consolas 和微軟雅黑混合字體,完美解決了中文字體小的問題,同時保持了Consolas字體的優雅,效果如下圖:

是不是比較滿意?哈哈,那就趕緊下載這個混合字體吧。
下載地址:
http://files.xiaogui.org/eclipse-indigo/YaHei.Consolas.1.12.rar
下載好后把 YaHei.Consolas.1.12.ttfw 文件復制到 C:\Windows\Fonts 目錄下,這樣字體就安裝完成,
然后打開 eclipse 的 “preferences” , “General” -> “Appearance” -> “Colors and Fonts” ,打開 “basic” ,雙擊 “Text Font” ,然后選擇字體:”YaHei Consolas Hybrid” ,確定即可。
操作可參考下圖:


備注:在上圖此處選字體的時候,只需在字體框里面輸入字母 “Y”, Eclipse 就會智能的跳轉至 “YaHei Consolas Hybrid” 字體。
轉載于 http://xiaogui.org/eclipse-indigo-3-7-font.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=gb2312" />
<title>簡潔Tab</title>
<style type="text/css">
<!--
body,div,ul,li{
margin:0 auto;
padding:0;
}
body{
font:12px "宋體";
text-align:center;
}
a:link{
color:#00F;
text-decoration:none;
}
a:visited {
color: #00F;
text-decoration:none;
}
a:hover {
color: #c00;
text-decoration:underline;
}
ul{
list-style:none;
}
.main{
clear:both;
padding:8px;
text-align:center;
}
/*第一種形式*/
#tabs0 {
height: 200px;
width: 400px;
border: 1px solid #cbcbcb;
background-color: #f2f6fb;
}
.menu0{
width: 400px;
}
.menu0 li{
display:block;
float: left;
padding: 4px 0;
width:100px;
text-align: center;
cursor:pointer;
background: #FFFFff;
}
.menu0 li.hover{
background: #f2f6fb;
}
#main0 ul{
display: none;
}
#main0 ul.block{
display: block;
}
/*第二種形式*/
#tabs1{
text-align:left;
width:400px;
}
.menu1box{
position:relative;
overflow:hidden;
height:22px;
width:400px;
text-align:left;
}
#menu1{
position:absolute;
top:0;
left:0;
z-index:1;
}
#menu1 li{
float:left;
display:block;
cursor:pointer;
width:72px;
text-align:center;
line-height:21px;
height:21px;
}
#menu1 li.hover{
background:#fff;
border-left:1px solid #333;
border-top:1px solid #333;
border-right:1px solid #333;
}
.main1box{
clear:both;
margin-top:-1px;
border:1px solid #333;
height:181px;
width:400px;
}
#main1 ul{
display: none;
}
#main1 ul.block{
display: block;
}
/*第三種形式*/
.menu2box{
position:relative;
overflow:hidden;
height:22px;
width:400px;
text-align:left;
background: #FFFFff;
}
#tabs2 {
height: 200px;
width: 400px;
border: 1px solid #cbcbcb;
background-color: #f2f6fb;
}
#tip2{
position:absolute;
top:0;
left:0;
height:22px;
line-height:22px;
z-index:0;
width:100px;
background: #f2f6fb;
}
#menu2{
position:absolute;
top:0;
left:0;
z-index:1;
}
#menu2 li{
display:block;
float: left;
padding: 4px 0;
width:100px;
text-align: center;
cursor:pointer;
}
-->
</style>
<script>
<!--
/*第一種形式 第二種形式 更換顯示樣式*/
function setTab(m,n){
var tli=document.getElementById("menu"+m).getElementsByTagName("li");
var mli=document.getElementById("main"+m).getElementsByTagName("ul");
for(i=0;i<tli.length;i++){
tli[i].className=i==n?"hover":"";
mli[i].style.display=i==n?"block":"none";
}
}
/*第三種形式 利用一個背景層定位*/
var m3={0:"",1:"評論內容",2:"技術內容",3:"點評內容"}
function nowtab(m,n){
if(n!=0&&m3[0]=="")m3[0]=document.getElementById("main2").innerHTML;
document.getElementById("tip"+m).style.left=n*100+'px';
document.getElementById("main2").innerHTML=m3[n];
}
//-->
</script>
</head>
<body>
<br />
<br />
<!--第一種形式-->
<div id="tabs0">
<ul class="menu0" id="menu0">
<li onclick="setTab(0,0)" class="hover">新聞</li>
<li onclick="setTab(0,1)">評論</li>
<li onclick="setTab(0,2)">技術</li>
<li onclick="setTab(0,3)">點評</li>
</ul>
<div class="main" id="main0">
<ul class="block"><li>新聞列表</li></ul>
<ul><li>評論列表</li></ul>
<ul><li>技術列表</li></ul>
<ul><li>點評列表</li></ul>
</div>
</div>
<br />
<br />
<!--第二種形式-->
<div id="tabs1">
<div class="menu1box">
<ul id="menu1">
<li class="hover" onmouseover="setTab(1,0)"><a href="#">新聞</a></li>
<li onmouseover="setTab(1,1)"><a href="#">評論</a></li>
<li onmouseover="setTab(1,2)"><a href="#">技術</a></li>
<li onmouseover="setTab(1,3)"><a href="#">點評</a></li>
</ul>
</div>
<div class="main1box">
<div class="main" id="main1">
<ul class="block"><li>新聞列表</li></ul>
<ul><li>評論列表</li></ul>
<ul><li>技術列表</li></ul>
<ul><li>點評列表</li></ul>
</div>
</div>
</div>
<br />
<br />
<!--第三種形式-->
<div id="tabs2">
<div class="menu2box">
<div id="tip2"></div>
<ul id="menu2">
<li class="hover" onmouseover="nowtab(2,0)"><a href="#">新聞</a></li>
<li onmouseover="nowtab(2,1)"><a href="#">評論</a></li>
<li onmouseover="nowtab(2,2)"><a href="#">技術</a></li>
<li onmouseover="nowtab(2,3)"><a href="#">點評</a></li>
</ul>
</div>
<div class="main" id="main2">
新聞內容
</div>
</div>
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
</body>
</html>
轉換成Eclipse項目
- 啟動命令行,輸入play new <項目名>,Play會在當前路徑下創建項目。
- 輸入play eclipsify <項目名>,Play會在項目目錄中創建eclipse需要的配置文件,將其轉換成eclipse項目。
- 在eclipse中導入創建的項目。

調試
Play轉換eclipse項目時,在eclipse目錄中生成了三個啟動配置:
- JPDA:連接到已經啟動的Play Server,實現alive調試
- helloworld:本地運行
- Test:測試
選中它們,右鍵執行Run As,即可完成相應的任務。
本地調試
直接Debug As 執行helloworld會報錯:
Error occurred during initialization of VM
agent library failed to init: jdwp
ERROR: Cannot load this JVM TI agent twice, check your java command line for duplicate jdwp options.
需要:
打開helloworld.launch,找到
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Xdebug -Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n -Dplay.debug=yes -Dplay.id= -Dapplication.path …/>
將-Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n 去掉。
然后Debug As,即可成功啟動調試。附加Play源碼后,即可調試Play本身。
轉載于 http://www.cnblogs.com/Chaos/archive/2011/04/16/2018444.html
假如你的筆記本需要在家里和公司頻繁地進行IP地址切換,是不是很煩?而網上大量的切換工具對Win7均無效,怎么辦?請不要擔心,自己DIY一個批處理文件就行了。
注意,以下是針對IPv4進行的修改。
另外,安裝了360可能會有風險提醒,請大家不要擔心,放心點擊通過,此代碼毫無風險,童叟無欺,盡可安全使用。
首先,打開記事本,新建一個"IP切換.txt",內容如下,
最后,把文件名改為"IP切換.bat"就大功告成了。
@echo off
rem //設置變量本地連接, 根據你的需要更改
set Nic="本地連接 3"
rem //可以根據你的需要更改
set Addr=192.168.1.11
set Mask=255.255.255.0
set Gway=192.168.1.1
set Dns=192.168.1.1
set Addr2=10.32.66.34
set Mask2=255.255.255.192
set Gway2=10.32.66.62
set Dns1=202.107.196.144
set Dns2=202.101.172.46
rem //以上對應分別是IP地址、子網掩碼、網關、首選DNS、備用DNS ,自己根據情況修改
rem //家里的DNS和公司一樣則可以用以上代碼,不一樣可能需要稍作修改
echo ↗Design by 魯勝迪,龍騰虎躍↖
echo ★ 1 設置為公司IP ★
echo ★ 2 設置為***綜合樓IP★
echo ★ 3 設置為動態IP ★
echo ★ 4 退出 ★
echo ●●●請選擇項目回車●●●
set /p answer=
if %answer%==1 goto 1
if %answer%==2 goto 2
if %answer%==3 goto 3
if %answer%==4 goto 4
:1
echo 正在進行靜態公司IP 設置,請稍等...
rem //可以根據你的需要更改
echo. I P 地址 = %Addr%
echo. 子網掩碼 = %Mask%
netsh interface ipv4 set address name=%Nic% source=static addr=%Addr% mask=%Mask% gateway=%Gway% gwmetric=0 >nul
echo. 首選 DNS = %Dns%
netsh interface ipv4 set dns name=%Nic% source=static addr=%Dns% register=PRIMARY >nul
echo. 備用 DNS = %Dns%
netsh interface ipv4 add dns name=%Nic% addr=%Dns% index=2 >nul
echo ----
echo 全部設置完成!
pause
goto end
:2
echo 正在進行靜態蕭山區政府綜合樓IP設置,請稍等...
rem //可以根據你的需要更改
echo. I P 地址 = %addr2%
echo. 子網掩碼 = %Mask2%
netsh interface ipv4 set address name=%Nic% source=static addr=%addr2% mask=%Mask2% gateway=%Gway2% gwmetric=0 >nul
echo. 首選 DNS = %Dns1%
netsh interface ipv4 set dns name=%Nic% source=static addr=%Dns1% register=PRIMARY >nul
echo. 備用 DNS = %Dns2%
netsh interface ipv4 add dns name=%Nic% addr=%Dns2% index=2 >nul
echo ----
echo 全部設置完成!
pause
goto end
:3
echo 正在進行動態IP設置,請稍等...
echo. IP 地址正在從DHCP自動獲取...
netsh interface ip set address %Nic% dhcp
echo. DNS地址正在從DHCP自動獲取...
netsh interface ip set dns %Nic% dhcp
echo ----
echo 全部設置完成!
pause
:4
echo bye!
goto end
前言:架設基于寬帶服務器要解決的幾個問題
***第一個問題是:如何解決動態IP地址映射成局域網的靜態IP地址
***第二個問題是:如何架設WEB服務器
***第三個問題是:如何架設FTP服務器
下面就這三個問題,提供如下的解決方案。
一.動態IP地址映射成靜態IP地址
現在聯接Internet的寬帶用戶,方式很多,如有線通、ADSL、 FTTB,但這些方式獲得的因特網的IP地址是動態的(當然也可以到電信申請一個固定的IP地址,但這樣的月租費特別貴,一個月可能要一千多元,而家庭動態IP用戶,月租可能50-100元。當然靜態IP用戶可以跳過第一個問題)。如果家里有幾臺電腦,共享上網,設置的IP地址是局域網的IP地址,不能直接路由到因特網,所以必須找一個第三方軟件作因特網動態IP地址和局域網的靜態IP地址的映射。這方面的軟件很多,比較優秀的軟件是花生殼。
下面是花生殼軟件的介紹:
花生殼是一套完全免費的動態域名解析服務客戶端軟件。當您安裝并注冊該項服務,無論您在任何地點、任何時間、使用任何線路,均可利用這一服務建立擁有固定域名和最大自主權的互聯網主機。“花生殼”支持的線路包括普通電話線、ISDN、ADSL、有線電視網絡、雙絞線到戶的寬帶網和其它任何能夠提供互聯網真實IP的接入服務線路,而無論連接獲得的IP屬于動態還是靜態。
花生殼3系列版本從2005年4月份發布3.0版本,已有1年多的時間,并完全替代了花生殼1.0和2.x,3.9版將是花生殼3系列的最后一個版本發布,2006年底花生殼將推出全新內核和界面的新版本。
Oray九月推出瘋狂的CN,免費送CN域名,還同時免費贈送橄欖郵局系統。
活動主題頁面:http://www.oray.net/Activity/0609/
花生殼3.9版新特征描述:
1、該版本增加了對英文操作系統的完全支持;
2、去除原有“花生吧”功能,降低前臺程序內存占用;
3、修改了一些界面處理bug;
4、完善WebService獲取信息部分,比以前登陸速度更快;
5、完善針對中文域名處理部分,對中文域名的支持更加完美;
Oray于2006年8月1日永久停止花生殼1.0、2.1版客戶端服務通告
https://www.oray.net/News/News_Details.asp?ID=101
下面介紹具體的操作步驟:
1.下載花生殼客戶端:下載地址1 下載地址2
2.安裝花生殼,一般直接點“下一步”就可以安裝完成(安裝過程類似安裝QQ軟件)。
花生殼客戶端安裝后,它會隨系統一起啟動。在默認設置下,它會啟動前臺控制和后臺服務,并在系統的通知區域顯示為一個小盒子,當網絡連通且登錄到花生殼服務器時,它會是彩色的,我們現在還沒連接到花生殼服務器,所以它是灰色的。
3.申請一個網域護照 ( 賬戶 ),才能連接到花生殼服務器(申請過程類似申請QQ號碼)。
登錄到 http://www.oray.net/ ,在最左邊點擊“免費注冊oray護照”,或直接在花生殼客戶端“狀態”選項卡上左鍵單擊“申請網域護照”,進入網域護照的申請網頁,在那里簽署用戶協議、填寫護照基本信息、設置密碼提示問題后,就會得到一個網域護照。
如下圖所示:



4.在網域申請一個免費的域名。
登錄網域后,點“申請免費域名”,如下圖所示:

在彈出的頁面,點“免費域名”,如下圖所示:

在彈出的頁面,輸入您喜歡的域名,如我的網站jsjzx.xicp.cn,在文本框里面輸入jsjzx,再在下面您要的后綴前面打鉤,再點“查詢域名”,通過查看“搜索結果”,此域名已經被注冊,如下圖所示:

重新輸入jsjzxnet,選擇.xicp.net,再點“查詢域名”,可以知道,此域名沒有被注冊,在“jsjzxnet.xicp.net”前面點一下,再點“注冊選定免費域名”,如下圖所示:

在彈出的頁面中填入您的真實信息(當然有的私人信息還是保密比較好),如下圖所示:

再點“申請免費域名”,下面彈出的頁面步驟和上面一樣,如下圖所示:


在彈出的頁面,點“確認申請”,如下圖所示:

在彈出的頁面,選擇“是”,再點“下一步”,如下圖所示:

在彈出的頁面中,輸入網站的一些信息,然后點“同意以下條款,提交信息”,如下圖所示:

于是,二級免費域名jsjzxnet.xicp.net申請成功,如果WEB服務器設置好后,網友就可以輸入http://jsjzxnet.xicp.net訪問您的網站了(當然,還要做一些設置才可以,下面會具體介紹),如下圖所示:

5.登錄花生殼(登錄過程類似登錄QQ軟件):
用自己申請的護照名和密碼,登錄花生殼服務器,如下圖所示:(友情提示:最好把“自動登錄,忘記密碼”打上鉤,這樣系統開機自動就登錄,花生殼服務就開啟了)

點“免費域名”,如果能看到“jsjzx.xicp.net”(注意:這是我網站的二級域名,不是用上面的號碼登錄,而是用的另一個號碼登錄)就說明服務開啟成功,如下圖所示:

6.解決局域網的端口映射:
如果是幾臺電腦共享上網,必須作端口映射,才可以做服務器(如果是一臺電腦,可以跳過這步)。
打開IE瀏覽器,輸入192.168.1.1,敲回車(注意,不同的ADSL貓,IP地址不同,有的是192.168.1.254,這個IP地址,可以看您的路由器說明書,或者ADSL貓說明書,上面有說明,當然在百度也可以查到),如下圖所示:

在彈出的窗口,輸入用戶名和密碼,一般用戶名admin或者root,密碼admin或者root(當然可以查看說明書),點“確定”如下圖所示:

在彈出的窗口中,點“轉發規則”,在“服務端口”中輸入80,在“IP地址”中輸入192.168.1.8(這是我電腦的IP地址,您也可以設置其它IP地址),在協議中選擇ALL,在啟用中“打鉤”。按照同樣的方法,輸入端口號21。如下圖所示:
友情提示:設置80端口,是為了做WEB服務器,輸入21端口,是為了做FTP服務器。另外,教大家一招提高BT下載速度的方法,在“服務端口”輸入22557,再打開BT軟件,點工具欄上的“選項”-“選項”,在彈出的窗口中的“監聽端口”輸入 22557,再點“確定”就可以了。另外,根據我的經驗,在“全局最大上傳速率”設置成30kB/s,下載速度最快,當然您也可以根據自己的網絡去設置成一個合理的值。



二.架設WEB服務器
關于WEB服務器的更多詳細信息見計算機網絡實驗三。下面只介紹我自己電腦作WEB服務器的設置。
做WEB服務器,可以用IIS,它比較簡單和方便,但它有人數限制,好象同一時刻只能連接100人,所以推薦大家用 Apache。
1.下載 Apache:下載地址
2.安裝Apache:基本上點“下一步”就可以。
安裝好后,測試一下按默認配置運行的網站界面,在 IE 地址欄打 “http://127.0.0.1” ,點 “ 轉到 ” ,如果出現配置成功,表示 Apache 服務器已安裝成功。
友情提示:如果 IIS 打開了,要停止它(開始-控制面板-管理工具-服務-IIS Admin禁止),否則 apache 不能啟動!
3.設置Apache:
“ 開始 ”- “ 所有程序 ”- “Apache HTTP Server 2.0.55”- “Configure Apache Server”- “Edit the Apache httpd conf Configuration file” ,點擊打開。
友情提示:每次配置文件的改變,保存后, 必須在 Apache 服務器重啟動后生效 ,可以用前面講的小圖標方便的控制服務器隨時 “ 重啟動 ” 。
查找關鍵字 “DocumentRoot” (也就是網站根目錄),找到如下圖所示地方,然后將 "" 內的地址改成你的網站根目錄,地址格式請照圖上的寫 ,主要是一般文件地址的 “\” 在 Apache 里要改成 “/” 。 比如我的網站就是: DocumentRoot "f:/web" 。
查找 “<Directory” 來定位,將 "" 內的地址改成跟 DocumentRoot 的一樣。 比如我的網站: <Directory "f:/web"> 。
查找“DirectoryIndex” (目錄索引,也就是在僅指定目錄的情況下,默認顯示的文件名),可以添加很多,系統會根據從左至右的順序來優先顯示,以單個半角空格隔開,比如有些網站的首頁是 index.htm ,就在光標那里加上 “index.htm ” 文件名是任意的,不一定非得 “index.html” ,比如 “test.php” 等,都可以。 比如我的網站: DirectoryIndex index.html 。
好了,簡單的 Apache 配置就到此結束了,現在利用先前的小圖標重啟動,所有的配置就生效了,你的網站就成了一個網站服務器,如果你加載了防火墻,請打開 80 或 8080 端口,或者允許 Apache 程序訪問網絡,否則別人不能訪問。然后告訴您朋友二級域名,他們就可以訪問了,如我網站的新服務器地址:http://jsjzx.xicp.net。
三.架設FTP服務器
關于FTP服務器的更多詳細信息見計算機網絡實驗四。下面只介紹我自己電腦作FTP服務器的設置。
做FTP服務器,可以用IIS,它比較簡單,但管理不方便,所以推薦大家用 serv-u 。
1.下載 serv-u:下載地址
2.安裝 serv-u:基本上點下一步就可以了。
3.配置serv-u:具體操作步驟點這里。
通過這三步設置,您的電腦就可以作FTP服務器和WEB服務器了,如果有任何問題和建議,請與站長QQ317154001聯系。
轉載于 http://cs.ecust.edu.cn/snwei/studypc/networks/server.htm
一、oracle10g安裝,比較簡單
1.去Oracle網站下載Vista版的Oracle:Oracle Database 10g Release 2 (10.2.0.4) for Microsoft Windows Vista x64 and Microsoft Windows Server 2008 x64
2.解壓下載的安裝文件10204_vista_w2k8_x64_production_db.zip
3.修改驗證文件來支持windows7
修改\stage\prereq\db\refhost.xml
加入<!--Microsoft Windows 7-->
<OPERATING_SYSTEM>
<VERSION VALUE="6.1"/>
</OPERATING_SYSTEM>
修改\install\oraparam.ini,加入6.1,Windows=5.0,5.1,5.2,6.0,6.1
4.如果網卡IP是動態分配的,安裝時會有警告,可以忽略,如果覺得不舒服解決方法如下:
添加Microsoft Loopback Adapter
打開“設備管理器”右鍵單擊設備管理器窗口的計算機名->添加過時硬件->
安裝我手動從列表選擇的硬件->選擇“網絡適配器”->
選擇Microsoft公司下的Microsoft Loopback Adapter,就完成了添加。
修改為固定IP,隨意設置,如192.168.1.6
5.順利安裝
二、PL/SQL Developer 安裝
1.下載安裝
http://allroundautomations.swmirror.com/plsqldev802.exe
注冊碼自己搜,很多有注冊機
注意:不要安裝在默認的C:\Program Files (x86)目錄下,否則會報錯,原因是不能解析這個帶()的路徑
2.啟動PL/SQL Developer 報以下錯誤

原因是oci.dll是64位的,32位應用程序PLSQL Developer無法加載,在網上搜了搜解決方法:可以裝個32位的Oracle Client來解決,Client的功能我一般用不到,太大了不想裝。后來參考了這篇文章免安裝Oracle客戶端軟件-使用pl/sql配置登陸。
3.下載Oracle Client Package http://www.oracle.com/technology/software/tech/oci/instantclient/htdocs/winsoft.html
我下載的是下載instantclient-basic-win32-10.2.0.4.zip。
4.解壓到C:\oracle_client下,oci所在目錄為C:\oracle_client\instantclient_10_2。
5.啟動PL/SQL Developer ,點擊取消不要登錄,在Tools\Perferences 下的Connection 配置Oracle_Home和OCI Library,如下

OracleHome:OraDb10g_home1
OCI library:C:\oracle_client\instantclient_10_2\oci.dll
6.設置系統環境變量
TNS_ADMIN=C:\oracle\product\10.2.0\db_1\NETWORK\ADMIN
NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
注:NLS_LANG前半部分必須是AMERICAN_AMERICA,因為instant client不支持其他語言;而后半部分可以根據你數據庫的字符集調整,如果數據庫采用AL32UTF8,則可以設置AL32UTF8
7.啟動PL/SQL Developer ,OK沒問題了。
轉載于 http://wlwolf.iteye.com/blog/618950