2012年2月10日

          JAVA使用POI讀取EXCEL文件的簡(jiǎn)單model

           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             //根據(jù)文件格式(2003或者2007)來(lái)初始化
          28             if(isE2007)
          29                 wb = new XSSFWorkbook(input);
          30             else
          31                 wb = new HSSFWorkbook(input);
          32             Sheet sheet = wb.getSheetAt(0);        //獲得第一個(gè)表單
          33             Iterator<Row> rows = sheet.rowIterator();    //獲得第一個(gè)表單的迭代器
          34             while (rows.hasNext()) {
          35                 Row row = rows.next();    //獲得行數(shù)據(jù)
          36                 System.out.println("Row #" + row.getRowNum());    //獲得行號(hào)從0開(kāi)始
          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()) {    //根據(jù)cell中的類型來(lái)輸出數(shù)據(jù)
          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 }

          posted @ 2015-01-13 09:57 魯勝迪 閱讀(342) | 評(píng)論 (0)編輯 收藏

          安裝版的tomcat設(shè)置JAVA_OPTS="-Xms128M -Xmx512M -XX:PermSize=128M -XX:MaxPermSize=512M"

          tomcat如果是通過(guò)windows服務(wù)啟動(dòng),執(zhí)行的是bin\tomcat.exe.他讀取注冊(cè)表中的值,而不是catalina.bat的設(shè)置.
          解決辦法:
          修改注冊(cè)表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

          必須要分行寫。

          最終效果如下:

          posted @ 2014-11-07 10:29 魯勝迪 閱讀(2392) | 評(píng)論 (0)編輯 收藏

          ORA-1653報(bào)錯(cuò) 調(diào)整oracle數(shù)據(jù)表的最大值

          當(dāng)一個(gè)數(shù)據(jù)庫(kù)的數(shù)據(jù)文件達(dá)到表空間的最大值時(shí),報(bào)ORA-1653:的錯(cuò)誤。如下:

          ORA-1653: unable to extend table TEST.COMM_DTTR_SVR_LOG by64 in tablespace TEST_SPACE

          解決:

          可以在該表空間中增加一個(gè)數(shù)據(jù)文件,增加的數(shù)據(jù)文件為自動(dòng)擴(kuò)展,無(wú)限擴(kuò)大。

          查看數(shù)據(jù)文件的大小和最大的值,可以查詢dba_data_files;

          Sql>

          alter tablespace  TEST_SPACE
          adddatafile'/Oracle/oms/oradata/pub/Norm_data001.dbf'
          size  10M   autoextend  on  MAXSIZE  UNLIMITED;

          或者把該表空間所在的數(shù)據(jù)文件設(shè)置成自動(dòng)擴(kuò)張,設(shè)置該maxsize更大,unlimited表示沒(méi)有限制。

          SQL>

          alter  database
          datafile   '/oracle/oms/oradata/pub/Pub_Norm_data001.dbf'
          autoextend   on   maxsize    unlimited;

          posted @ 2013-11-06 12:40 魯勝迪 閱讀(980) | 評(píng)論 (0)編輯 收藏

          js記住用戶名密碼

          共計(jì)以下4個(gè)文件  點(diǎn)擊“下載”
              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>
          <href="login.html">點(diǎn)擊返回登陸框</a>
          </body>
          </html>


          cookie.js

          //新建cookie。
          //
          hours為空字符串時(shí),cookie的生存期至瀏覽器會(huì)話結(jié)束。hours為數(shù)字0時(shí),建立的是一個(gè)失效的cookie,這個(gè)cookie會(huì)覆蓋已經(jīng)建立過(guò)的同名、同path的cookie(如果這個(gè)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的開(kāi)始位置
               name += "=";
              
          var pos = allcookies.indexOf(name);    
              
          //如果找到了具有該名字的cookie,那么提取并使用它的值
              if (pos != -1){                                             //如果pos值為-1則說(shuō)明搜索"version="失敗
                  var start = pos + name.length;                  //cookie值開(kāi)始的位置
                  var end = allcookies.indexOf(";",start);        //從cookie值開(kāi)始的位置起搜索第一個(gè)";"的位置,即cookie值結(jié)尾的位置
                  if (end == -1) end = allcookies.length;        //如果end值為-1說(shuō)明cookie列表里只有一個(gè)cookie
                  var value = allcookies.substring(start,end); //提取cookie的值
                  return (value);                           //對(duì)它解碼      
                   }   
              
          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;    
              
          //寫入點(diǎn)擊事件
               $("submit").onclick = function()
               {
                  
          var userNameValue = $("userName").value;
                  
          var passwordValue = $("password").value;
                  
          //服務(wù)器驗(yàn)證(模擬)    
                  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("用戶名或密碼錯(cuò)誤,請(qǐng)重新輸入!");    
               }
          }

          posted @ 2013-07-26 17:39 魯勝迪 閱讀(308) | 評(píng)論 (0)編輯 收藏

          Oracle提示錯(cuò)誤消息ORA-28001: the password has expired

          Oracle提示錯(cuò)誤消息ORA-28001: the password has expired

          Oracle提示錯(cuò)誤消息ORA-28001: the password has expired,

          經(jīng)調(diào)查是由于Oracle11G的新特性所致, Oracle11G創(chuàng)建用戶時(shí)缺省密碼過(guò)期限制是180天, 如果超過(guò)180天用戶密碼未做修改則該用戶無(wú)法登錄。 
          可通過(guò)

          SELECT * FROM dba_profiles WHERE profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME'

          語(yǔ)句查詢密碼的有效期設(shè)置,

          LIMIT字段是密碼有效天數(shù)。在密碼將要過(guò)期或已經(jīng)過(guò)期時(shí)可通過(guò)

          ALTER USER 用戶名 IDENTIFIED BY 密碼 ;

          語(yǔ)句進(jìn)行修改密碼,密碼修改后該用戶可正常連接數(shù)據(jù)庫(kù)。

          長(zhǎng)久對(duì)應(yīng)可通過(guò)

          ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED

          語(yǔ)句將口令有效期默認(rèn)值180天修改成“無(wú)限制”。出于數(shù)據(jù)庫(kù)安全性考慮,不建議將PASSWORD_LIFE_TIME值設(shè)置成UNLIMITED,

          建議客戶定期修改數(shù)據(jù)庫(kù)用戶口令。


          轉(zhuǎn)載于 http://hi.baidu.com/yuelsygfixbqsuq/item/ddfc8e4b4888ae1e896d10c0

          posted @ 2013-02-25 09:42 魯勝迪 閱讀(436) | 評(píng)論 (0)編輯 收藏

          jrebel(破解版)+eclipse +jetty/tomcat 配置,實(shí)現(xiàn)熱部署

          1、安裝eclipse的jrebel插件

          Help » Install New Software

          然后通過(guò) 如下 URL  http://www.zeroturnaround.com/update-site/
          如果要離線下載的話,可以通過(guò)下載離線包的方式進(jìn)行 http://www.zeroturnaround.com/update-site/update-site.zip

          JRebel安裝使用說(shuō)明


          2、下載jrebel5破解版
              下載jrebel5破解版以后解壓到D盤根目錄即可
              下載地址 :http://download.csdn.net/detail/lushengdi/5080360

              配置jrebel破解版JAR包的路徑 :

           

           

          3、配置jetty實(shí)現(xiàn)熱部署

              這是為jetty加載jrebel的關(guān)鍵。

              項(xiàng)目右鍵 》 run as 》 run configuation.. 》 點(diǎn)擊jetty項(xiàng)目

              在mvn jetty:run的JRE管理選項(xiàng)卡中的VM參數(shù)中加入

                -noverify -javaagent:d:/jrebel/jrebel.jar

                

              現(xiàn)在在eclipse中啟動(dòng)mvn jetty:run,jrebel將被加載,修改java代碼可以不重啟jetty而熱部署生效了,
              修改java文件后自動(dòng)在輸出窗口中顯示重新加載的信息
          2009-07-15_150006


          tomcat 配置 參考

          How to install and use JRebel in Tomcat, JBoss or Jetty with the Eclipse IDE

           http://zeroturnaround.com/jrebel/how-to-install-and-use-jrebel-formerly-javarebel-in-tomcat-with-the-eclipse-ide/

          posted @ 2013-02-22 15:54 魯勝迪 閱讀(12136) | 評(píng)論 (1)編輯 收藏

          [轉(zhuǎn)]jspSmartUpload上傳下載全攻略(2012.8.30最新版)

               摘要: 安裝篇jspSmartUpload是由www.jspsmart.com網(wǎng)站開(kāi)發(fā)的一個(gè)可免費(fèi)使用的全功能的文件上傳下載組件,適于嵌入執(zhí)行上傳下載操作的JSP文件中。該組件有以下幾個(gè)特點(diǎn):1、使用簡(jiǎn)單。在JSP文件中僅僅書(shū)寫三五行JAVA代碼就可以搞定文件的上傳或下載,方便。2、能全程控制上傳。利用jspSmartUpload組件提供的對(duì)象及其操作方法,可以獲得全部上傳文件的信息(包括文件名,大小,類...  閱讀全文

          posted @ 2013-01-05 18:48 魯勝迪 閱讀(900) | 評(píng)論 (0)編輯 收藏

          瀏覽器緩存內(nèi)幕及解決方案

               摘要:   瀏覽器緩存內(nèi)幕及解決方案    在下面三種不同的情況下,瀏覽器的緩存情況不同:   1).Servlet沒(méi)有覆蓋getLastModified方法,響應(yīng)消息中無(wú)LastModified頭字段,在瀏覽器緩存的文檔無(wú)“上次修改時(shí)間”.      2).有g(shù)e...  閱讀全文

          posted @ 2012-09-07 17:27 魯勝迪 閱讀(2622) | 評(píng)論 (0)編輯 收藏

          純js判斷瀏覽器版本

          js的判斷瀏覽器的版本,包括IE(6,7,8),FF,chrome,opera,safari的,很好用,很多地方會(huì)用到,有時(shí)不需要為了一個(gè)效果而導(dǎo)入一個(gè)js庫(kù)來(lái)調(diào)用,用這段代碼就很好。
          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;

                  /*以下進(jìn)行測(cè)試
                  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>

          posted @ 2012-09-03 10:33 魯勝迪 閱讀(453) | 評(píng)論 (0)編輯 收藏

          Oracle11g 賬號(hào)鎖定及密碼有效期問(wèn)題

           

          密碼過(guò)期,需要更換新密碼

               SQL> alter user test identified by [new password];

           

          解鎖
            SQL> alter user test account unlock;
            User altered.

          一般數(shù)據(jù)庫(kù)默認(rèn)是10次嘗試失敗后鎖住用戶
            1、查看FAILED_LOGIN_ATTEMPTS的值
            select * from dba_profiles
            2、修改為30次
            alter profile default limit FAILED_LOGIN_ATTEMPTS 30;
            3、修改為無(wú)限次(為安全起見(jiàn),不建議使用)
            alter profile default limit FAILED_LOGIN_ATTEMPTS unlimited;

          設(shè)置用戶密碼永不過(guò)期

                1 查看用戶概要文件(一般是DEFAULT)

                 select * from dba_users where username=test;

                2 查看指定概要文件(如default)的密碼有效期設(shè)置(默認(rèn)在default概要文件中設(shè)置了 “PASSWORD_LIFE_TIME=180天”):

                SELECT * FROM dba_profiles WHERE profile='DEFAULT' and  resource_name='PASSWORD_LIFE_TIME';

                3 將密碼有效期由默認(rèn)的180天修改成“無(wú)限制”:

          sql>ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;

          修改之后不需要重啟動(dòng)數(shù)據(jù)庫(kù),會(huì)立即生效。

          轉(zhuǎn)載于 http://database.51cto.com/art/201108/280966.htm

          posted @ 2012-08-28 10:13 魯勝迪 閱讀(359) | 評(píng)論 (0)編輯 收藏

          三階魔方復(fù)原步驟

          步驟一--完成一層
          1、第一層十字,可能出現(xiàn)兩種情況,可用以下公式還原
          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)

          posted @ 2012-08-06 14:10 魯勝迪 閱讀(329) | 評(píng)論 (0)編輯 收藏

          ORACLE JOB間隔時(shí)間參考

          假設(shè)你的存儲(chǔ)過(guò)程名為PROC_RAIN_JM 
          再寫一個(gè)存儲(chǔ)過(guò)程名為PROC_JOB_RAIN_JM 
          內(nèi)容是: 
          Java代碼  收藏代碼
          1. Create Or Replace Procedure PROC_JOB_RAIN_JM  
          2. Is  
          3. li_jobno         Number;  
          4.   
          5. Begin  
          6. DBMS_JOB.SUBMIT(li_jobno,'PROC_RAIN_JM;',SYSDATE,'TRUNC(SYSDATE + 1)');   
          7. End;  

          提交job語(yǔ)法: 
          Java代碼  收藏代碼
          1. begin  
          2. sys.dbms_job.submit(job => :job,  
          3.                       what => 'P_CLEAR_PACKBAL;',  
          4.                       next_date => to_date('04-08-2008 05:44:09', 'dd-mm-yyyy hh24:mi:ss'),  
          5.                       interval => 'sysdate+ 1/360');  
          6. commit;  
          7. end;  

          ------------------------- 
          創(chuàng)建JOB 
          Java代碼  收藏代碼
          1. variable jobno number;  
          2. begin  
          3. dbms_job.submit(:jobno, 'P_CRED_PLAN;',SYSDATE,'SYSDATE+1/2880',TRUE);  
          4. commit;  

          運(yùn)行JOB 
          Java代碼  收藏代碼
          1. begin  
          2.     dbms_job.run(:job1);  
          3. end;  

          刪除JOB 
          Java代碼  收藏代碼
          1. begin  
          2.     dbms_job.remove(:job1);  
          3. end;  

          DBA_JOBS 
          ========================================= 
          字段(列)          類型                 描述 
          JOB                NUMBER          任務(wù)的唯一標(biāo)示號(hào) 
          LOG_USER           VARCHAR2(30)    提交任務(wù)的用戶 
          PRIV_USER          VARCHAR2(30)    賦予任務(wù)權(quán)限的用戶 
          SCHEMA_USER        VARCHAR2(30)    對(duì)任務(wù)作語(yǔ)法分析的用戶模式 
          LAST_DATE          DATE            最后一次成功運(yùn)行任務(wù)的時(shí)間 
          LAST_SEC           VARCHAR2(8)     如HH24:MM:SS格式的last_date日期的小時(shí),分鐘和秒 
          THIS_DATE     DATE            正在運(yùn)行任務(wù)的開(kāi)始時(shí)間,如果沒(méi)有運(yùn)行任務(wù)則為null 
          THIS_SEC     VARCHAR2(8)     如HH24:MM:SS格式的this_date日期的小時(shí),分鐘和秒 
          NEXT_DATE          DATE            下一次定時(shí)運(yùn)行任務(wù)的時(shí)間 
          NEXT_SEC           VARCHAR2(8)     如HH24:MM:SS格式的next_date日期的小時(shí),分鐘和秒 
          TOTAL_TIME         NUMBER          該任務(wù)運(yùn)行所需要的總時(shí)間,單位為秒 
          BROKEN             VARCHAR2(1)     標(biāo)志參數(shù),Y標(biāo)示任務(wù)中斷,以后不會(huì)運(yùn)行 
          INTERVAL           VARCHAR2(200)   用于計(jì)算下一運(yùn)行時(shí)間的表達(dá)式 
          FAILURES    NUMBER     任務(wù)運(yùn)行連續(xù)沒(méi)有成功的次數(shù) 
          WHAT               VARCHAR2(2000) 執(zhí)行任務(wù)的PL/SQL塊 
          CURRENT_SESSION_LABEL RAW          MLSLABEL 該任務(wù)的信任Oracle會(huì)話符 
          CLEARANCE_HI      RAW MLSLABEL     該任務(wù)可信任的Oracle最大間隙 
          CLEARANCE_LO      RAW              MLSLABEL 該任務(wù)可信任的Oracle最小間隙 
          NLS_ENV           VARCHAR2(2000)   任務(wù)運(yùn)行的NLS會(huì)話設(shè)置 
          MISC_ENV          RAW(32)          任務(wù)運(yùn)行的其他一些會(huì)話參數(shù) 
          -------------------------- 
          描述                    INTERVAL參數(shù)值 
          每天午夜12點(diǎn)            'TRUNC(SYSDATE + 1)' 
          每天早上8點(diǎn)30分         'TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)' 
          每星期二中午12點(diǎn)         'NEXT_DAY(TRUNC(SYSDATE ), ''TUESDAY'' ) + 12/24' 
          每個(gè)月第一天的午夜12點(diǎn)    'TRUNC(LAST_DAY(SYSDATE ) + 1)' 
          每個(gè)季度最后一天的晚上11點(diǎn) 'TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), 'Q' ) -1/24' 
          每星期六和日早上6點(diǎn)10分    'TRUNC(LEAST(NEXT_DAY(SYSDATE, ''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)' 
          -------------------------- 
          1:每分鐘執(zhí)行 
          Interval => TRUNC(sysdate,'mi') + 1/ (24*60) 
          2:每天定時(shí)執(zhí)行 
          例如:每天的凌晨1點(diǎn)執(zhí)行 
          Interval => TRUNC(sysdate) + 1 +1/ (24) 
          3:每周定時(shí)執(zhí)行 
          例如:每周一凌晨1點(diǎn)執(zhí)行 
          Interval => TRUNC(next_day(sysdate,'星期一'))+1/24 
          4:每月定時(shí)執(zhí)行 
          例如:每月1日凌晨1點(diǎn)執(zhí)行 
          Interval =>TRUNC(LAST_DAY(SYSDATE))+1+1/24 
          5:每季度定時(shí)執(zhí)行 
          例如每季度的第一天凌晨1點(diǎn)執(zhí)行 
          Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 1/24 
          6:每半年定時(shí)執(zhí)行 
          例如:每年7月1日和1月1日凌晨1點(diǎn) 
          Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24 
          7:每年定時(shí)執(zhí)行 
          例如:每年1月1日凌晨1點(diǎn)執(zhí)行 
          Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24 

          TRUNC()函數(shù)分兩種 
          trunc實(shí)際上是truncate函數(shù),字面意思是截?cái)啵匚病?nbsp;
          1.TRUNC(for dates) 
          TRUNC函數(shù)為指定元素而截去的日期值。截尾后返回最近日期 
          其具體的語(yǔ)法格式如下: 
          TRUNC(date[,fmt]) 
          date 一個(gè)日期值 
          fmt 日期格式,該日期將由指定的元素格式所截去。忽略它則由最近的日期截去 
          下面是該函數(shù)的使用情況: 
          select   trunc(sysdate,'mm')   from   dual=2009-1-1 
           
          2.TRUNC(for number) 
          TRUNC函數(shù)的功能是將數(shù)字進(jìn)行截?cái)?對(duì)所截取的結(jié)果并不四舍五入。   
          其具體的語(yǔ)法格式如下 
          TRUNC(number[,decimals]) 
          number 待做截取處理的數(shù)值 
          decimals 指明需保留小數(shù)點(diǎn)后面的位數(shù)。可選項(xiàng),忽略它則截去所有的小數(shù)部分 
          下面是該函數(shù)的使用情況: 
          TRUNC(89.985,2)=89.98 
          TRUNC(89.985)=89 
          TRUNC(89.985,-1)=80 
            注意:第二個(gè)參數(shù)可以為負(fù)數(shù),表示為小數(shù)點(diǎn)左邊指定位數(shù)后面的部分截去,即均以0記。 


          轉(zhuǎn)載于 http://virgoooos.iteye.com/blog/342421 

          posted @ 2012-05-18 12:24 魯勝迪 閱讀(1314) | 評(píng)論 (0)編輯 收藏

          輕松解決 Eclipse Indigo 3.7 中文字體偏小,完美 Consolas 微軟雅黑混合字體!

          Eclipse是著名的跨平臺(tái)的自由集成開(kāi)發(fā)環(huán)境(IDE)。6月22日Eclipse 3.7 正式發(fā)布,代號(hào)是 Indigo 。

          在 Windows 7 下初始后化,發(fā)現(xiàn)界面變化不大,但中文字體卻面目全非,小得根本看不見(jiàn),而且也看起來(lái)很不爽。其實(shí)這是 Eclipse 的默認(rèn)字體換了,以前的一直是 Courier New ,這次eclipse用的字體是 Consolas ,這是一個(gè)很好的編程字體了,無(wú)奈就是中文默認(rèn)太小了。

          于是上網(wǎng)找了 Consolas 和微軟雅黑混合字體,完美解決了中文字體小的問(wèn)題,同時(shí)保持了Consolas字體的優(yōu)雅,效果如下圖:

          是不是比較滿意?哈哈,那就趕緊下載這個(gè)混合字體吧。

          下載地址:
          http://files.xiaogui.org/eclipse-indigo/YaHei.Consolas.1.12.rar

          下載好后把 YaHei.Consolas.1.12.ttfw 文件復(fù)制到 C:\Windows\Fonts 目錄下,這樣字體就安裝完成,

          然后打開(kāi) eclipse 的 “preferences” , “General” -> “Appearance” -> “Colors and Fonts” ,打開(kāi) “basic” ,雙擊 “Text Font” ,然后選擇字體:”YaHei Consolas Hybrid” ,確定即可。

          操作可參考下圖:

          備注:在上圖此處選字體的時(shí)候,只需在字體框里面輸入字母 “Y”, Eclipse 就會(huì)智能的跳轉(zhuǎn)至 “YaHei Consolas Hybrid” 字體。

          轉(zhuǎn)載于 http://xiaogui.org/eclipse-indigo-3-7-font.html

          posted @ 2012-05-16 10:02 魯勝迪 閱讀(319) | 評(píng)論 (0)編輯 收藏

          三種簡(jiǎn)單的Tab選項(xiàng)卡效果

          <!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>簡(jiǎn)潔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";
           }
          }
          /*第三種形式 利用一個(gè)背景層定位*/
          var m3={0:"",1:"評(píng)論內(nèi)容",2:"技術(shù)內(nèi)容",3:"點(diǎn)評(píng)內(nèi)容"}
          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)">評(píng)論</li>
            <li onclick="setTab(0,2)">技術(shù)</li>
            <li onclick="setTab(0,3)">點(diǎn)評(píng)</li>
           </ul>
           <div class="main" id="main0">
            <ul class="block"><li>新聞列表</li></ul>
            <ul><li>評(píng)論列表</li></ul>
            <ul><li>技術(shù)列表</li></ul>
            <ul><li>點(diǎn)評(píng)列表</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="#">評(píng)論</a></li>
             <li onmouseover="setTab(1,2)"><a href="#">技術(shù)</a></li>
             <li onmouseover="setTab(1,3)"><a href="#">點(diǎn)評(píng)</a></li>
            </ul>
           </div>
           <div class="main1box">
            <div class="main" id="main1">
             <ul class="block"><li>新聞列表</li></ul>
             <ul><li>評(píng)論列表</li></ul>
             <ul><li>技術(shù)列表</li></ul>
             <ul><li>點(diǎn)評(píng)列表</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="#">評(píng)論</a></li>
             <li onmouseover="nowtab(2,2)"><a href="#">技術(shù)</a></li>
             <li onmouseover="nowtab(2,3)"><a href="#">點(diǎn)評(píng)</a></li>
            </ul>
           </div>
            <div class="main" id="main2">
          新聞內(nèi)容
           </div>
          </div>
          <br />
          <br />
          <br />
          <br />
          <br />
          <br />
          <br />
          <br />
          </body>
          </html>

          posted @ 2012-04-29 21:29 魯勝迪 閱讀(328) | 評(píng)論 (0)編輯 收藏

          Play Framework 使用Eclipse開(kāi)發(fā)和調(diào)試

          轉(zhuǎn)換成Eclipse項(xiàng)目

          1. 啟動(dòng)命令行,輸入play new <項(xiàng)目名>,Play會(huì)在當(dāng)前路徑下創(chuàng)建項(xiàng)目。
          2. 輸入play eclipsify <項(xiàng)目名>,Play會(huì)在項(xiàng)目目錄中創(chuàng)建eclipse需要的配置文件,將其轉(zhuǎn)換成eclipse項(xiàng)目。
          3. 在eclipse中導(dǎo)入創(chuàng)建的項(xiàng)目。

          image

           

          調(diào)試

          Play轉(zhuǎn)換eclipse項(xiàng)目時(shí),在eclipse目錄中生成了三個(gè)啟動(dòng)配置:

          1. JPDA:連接到已經(jīng)啟動(dòng)的Play Server,實(shí)現(xiàn)alive調(diào)試
          2. helloworld:本地運(yùn)行
          3. Test:測(cè)試

          選中它們,右鍵執(zhí)行Run As,即可完成相應(yīng)的任務(wù)。

          本地調(diào)試

          直接Debug As 執(zhí)行helloworld會(huì)報(bào)錯(cuò):

          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.

          需要:

          打開(kāi)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,即可成功啟動(dòng)調(diào)試。附加Play源碼后,即可調(diào)試Play本身。


          轉(zhuǎn)載于 http://www.cnblogs.com/Chaos/archive/2011/04/16/2018444.html

          posted @ 2012-03-22 11:54 魯勝迪 閱讀(2163) | 評(píng)論 (0)編輯 收藏

          win7下用批處理文件進(jìn)行IP地址切換


          假如你的筆記本需要在家里和公司頻繁地進(jìn)行IP地址切換,是不是很煩?而網(wǎng)上大量的切換工具對(duì)Win7均無(wú)效,怎么辦?請(qǐng)不要擔(dān)心,自己DIY一個(gè)批處理文件就行了。

          注意,以下是針對(duì)IPv4進(jìn)行的修改。

          另外,安裝了360可能會(huì)有風(fēng)險(xiǎn)提醒,請(qǐng)大家不要擔(dān)心,放心點(diǎn)擊通過(guò),此代碼毫無(wú)風(fēng)險(xiǎn),童叟無(wú)欺,盡可安全使用。

          首先,打開(kāi)記事本,新建一個(gè)"IP切換.txt",內(nèi)容如下, 最后,把文件名改為"IP切換.bat"就大功告成了。 
          @echo off
          rem //設(shè)置變量本地連接, 根據(jù)你的需要更改 
          set Nic="本地連接 3" 
          rem //可以根據(jù)你的需要更改
          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 //以上對(duì)應(yīng)分別是IP地址、子網(wǎng)掩碼、網(wǎng)關(guān)、首選DNS、備用DNS ,自己根據(jù)情況修改
          rem //家里的DNS和公司一樣則可以用以上代碼,不一樣可能需要稍作修改
          echo ↗Design by 魯勝迪,龍騰虎躍↖
          echo ★ 1 設(shè)置為公司IP ★ 
          echo ★ 2 設(shè)置為***綜合樓IP★ 
          echo ★ 3 設(shè)置為動(dòng)態(tài)IP ★ 
          echo ★ 4 退出          ★ 
          echo ●●●請(qǐng)選擇項(xiàng)目回車●●●
          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 正在進(jìn)行靜態(tài)公司IP 設(shè)置,請(qǐng)稍等...   
          rem //可以根據(jù)你的需要更改   
          echo. I P 地址 = %Addr%   
          echo. 子網(wǎng)掩碼 = %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 全部設(shè)置完成! 
          pause   
          goto end   
          :2 
          echo 正在進(jìn)行靜態(tài)蕭山區(qū)政府綜合樓IP設(shè)置,請(qǐng)稍等...   
          rem //可以根據(jù)你的需要更改   
          echo. I P 地址 = %addr2%   
          echo. 子網(wǎng)掩碼 = %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 全部設(shè)置完成! 
          pause   
          goto end 
          :3   
          echo 正在進(jìn)行動(dòng)態(tài)IP設(shè)置,請(qǐng)稍等...   
          echo. IP 地址正在從DHCP自動(dòng)獲取...   
          netsh interface ip set address %Nic% dhcp   
          echo. DNS地址正在從DHCP自動(dòng)獲取...   
          netsh interface ip set dns %Nic% dhcp   
          echo ----   
          echo 全部設(shè)置完成!   
          pause   
          :4 
          echo bye!   
          goto end   
          rem pause >null




          參考地址 http://hi.baidu.com/coldwindsnow/blog/item/142a0df25b5bdb1eb07ec5a6.html  





          posted @ 2012-03-20 16:03 魯勝迪 閱讀(3073) | 評(píng)論 (1)編輯 收藏

          快速架設(shè)基于寬帶的服務(wù)器

          前言:架設(shè)基于寬帶服務(wù)器要解決的幾個(gè)問(wèn)題

          ***第一個(gè)問(wèn)題是:如何解決動(dòng)態(tài)IP地址映射成局域網(wǎng)的靜態(tài)IP地址

          ***第二個(gè)問(wèn)題是:如何架設(shè)WEB服務(wù)器

          ***第三個(gè)問(wèn)題是:如何架設(shè)FTP服務(wù)器

            下面就這三個(gè)問(wèn)題,提供如下的解決方案。

          一.動(dòng)態(tài)IP地址映射成靜態(tài)IP地址

            現(xiàn)在聯(lián)接Internet的寬帶用戶,方式很多,如有線通、ADSL、 FTTB,但這些方式獲得的因特網(wǎng)的IP地址是動(dòng)態(tài)的(當(dāng)然也可以到電信申請(qǐng)一個(gè)固定的IP地址,但這樣的月租費(fèi)特別貴,一個(gè)月可能要一千多元,而家庭動(dòng)態(tài)IP用戶,月租可能50-100元。當(dāng)然靜態(tài)IP用戶可以跳過(guò)第一個(gè)問(wèn)題)。如果家里有幾臺(tái)電腦,共享上網(wǎng),設(shè)置的IP地址是局域網(wǎng)的IP地址,不能直接路由到因特網(wǎng),所以必須找一個(gè)第三方軟件作因特網(wǎng)動(dòng)態(tài)IP地址和局域網(wǎng)的靜態(tài)IP地址的映射。這方面的軟件很多,比較優(yōu)秀的軟件是花生殼。

            下面是花生殼軟件的介紹:

             花生殼是一套完全免費(fèi)的動(dòng)態(tài)域名解析服務(wù)客戶端軟件。當(dāng)您安裝并注冊(cè)該項(xiàng)服務(wù),無(wú)論您在任何地點(diǎn)、任何時(shí)間、使用任何線路,均可利用這一服務(wù)建立擁有固定域名和最大自主權(quán)的互聯(lián)網(wǎng)主機(jī)。“花生殼”支持的線路包括普通電話線、ISDN、ADSL、有線電視網(wǎng)絡(luò)、雙絞線到戶的寬帶網(wǎng)和其它任何能夠提供互聯(lián)網(wǎng)真實(shí)IP的接入服務(wù)線路,而無(wú)論連接獲得的IP屬于動(dòng)態(tài)還是靜態(tài)。

            花生殼3系列版本從2005年4月份發(fā)布3.0版本,已有1年多的時(shí)間,并完全替代了花生殼1.0和2.x,3.9版將是花生殼3系列的最后一個(gè)版本發(fā)布,2006年底花生殼將推出全新內(nèi)核和界面的新版本。

            Oray九月推出瘋狂的CN,免費(fèi)送CN域名,還同時(shí)免費(fèi)贈(zèng)送橄欖郵局系統(tǒng)。
            活動(dòng)主題頁(yè)面:http://www.oray.net/Activity/0609/

            花生殼3.9版新特征描述:
            1、該版本增加了對(duì)英文操作系統(tǒng)的完全支持;
            2、去除原有“花生吧”功能,降低前臺(tái)程序內(nèi)存占用;
            3、修改了一些界面處理bug;
            4、完善WebService獲取信息部分,比以前登陸速度更快;
            5、完善針對(duì)中文域名處理部分,對(duì)中文域名的支持更加完美;

            Oray于2006年8月1日永久停止花生殼1.0、2.1版客戶端服務(wù)通告
            https://www.oray.net/News/News_Details.asp?ID=101

            下面介紹具體的操作步驟:

          1.下載花生殼客戶端:下載地址1  下載地址2

          2.安裝花生殼,一般直接點(diǎn)“下一步”就可以安裝完成(安裝過(guò)程類似安裝QQ軟件)。

            花生殼客戶端安裝后,它會(huì)隨系統(tǒng)一起啟動(dòng)。在默認(rèn)設(shè)置下,它會(huì)啟動(dòng)前臺(tái)控制和后臺(tái)服務(wù),并在系統(tǒng)的通知區(qū)域顯示為一個(gè)小盒子,當(dāng)網(wǎng)絡(luò)連通且登錄到花生殼服務(wù)器時(shí),它會(huì)是彩色的,我們現(xiàn)在還沒(méi)連接到花生殼服務(wù)器,所以它是灰色的。

          3.申請(qǐng)一個(gè)網(wǎng)域護(hù)照 ( 賬戶 ),才能連接到花生殼服務(wù)器(申請(qǐng)過(guò)程類似申請(qǐng)QQ號(hào)碼)

            登錄到 http://www.oray.net/ ,在最左邊點(diǎn)擊“免費(fèi)注冊(cè)oray護(hù)照”,或直接在花生殼客戶端“狀態(tài)”選項(xiàng)卡上左鍵單擊“申請(qǐng)網(wǎng)域護(hù)照”,進(jìn)入網(wǎng)域護(hù)照的申請(qǐng)網(wǎng)頁(yè),在那里簽署用戶協(xié)議、填寫護(hù)照基本信息、設(shè)置密碼提示問(wèn)題后,就會(huì)得到一個(gè)網(wǎng)域護(hù)照。
            如下圖所示:

          4.在網(wǎng)域申請(qǐng)一個(gè)免費(fèi)的域名。

            登錄網(wǎng)域后,點(diǎn)“申請(qǐng)免費(fèi)域名”,如下圖所示:

            在彈出的頁(yè)面,點(diǎn)“免費(fèi)域名”,如下圖所示:

            在彈出的頁(yè)面,輸入您喜歡的域名,如我的網(wǎng)站jsjzx.xicp.cn,在文本框里面輸入jsjzx,再在下面您要的后綴前面打鉤,再點(diǎn)“查詢域名”,通過(guò)查看“搜索結(jié)果”,此域名已經(jīng)被注冊(cè),如下圖所示:

            重新輸入jsjzxnet,選擇.xicp.net,再點(diǎn)“查詢域名”,可以知道,此域名沒(méi)有被注冊(cè),在“jsjzxnet.xicp.net”前面點(diǎn)一下,再點(diǎn)“注冊(cè)選定免費(fèi)域名”,如下圖所示:

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

            再點(diǎn)“申請(qǐng)免費(fèi)域名”,下面彈出的頁(yè)面步驟和上面一樣,如下圖所示:

            在彈出的頁(yè)面,點(diǎn)“確認(rèn)申請(qǐng)”,如下圖所示:

            在彈出的頁(yè)面,選擇“是”,再點(diǎn)“下一步”,如下圖所示:

            在彈出的頁(yè)面中,輸入網(wǎng)站的一些信息,然后點(diǎn)“同意以下條款,提交信息”,如下圖所示:

            于是,二級(jí)免費(fèi)域名jsjzxnet.xicp.net申請(qǐng)成功,如果WEB服務(wù)器設(shè)置好后,網(wǎng)友就可以輸入http://jsjzxnet.xicp.net訪問(wèn)您的網(wǎng)站了(當(dāng)然,還要做一些設(shè)置才可以,下面會(huì)具體介紹),如下圖所示:

          5.登錄花生殼(登錄過(guò)程類似登錄QQ軟件)

            用自己申請(qǐng)的護(hù)照名和密碼,登錄花生殼服務(wù)器,如下圖所示:(友情提示:最好把“自動(dòng)登錄,忘記密碼”打上鉤,這樣系統(tǒng)開(kāi)機(jī)自動(dòng)就登錄,花生殼服務(wù)就開(kāi)啟了)

            點(diǎn)“免費(fèi)域名”,如果能看到“jsjzx.xicp.net”(注意:這是我網(wǎng)站的二級(jí)域名,不是用上面的號(hào)碼登錄,而是用的另一個(gè)號(hào)碼登錄)就說(shuō)明服務(wù)開(kāi)啟成功,如下圖所示:

          6.解決局域網(wǎng)的端口映射:

            如果是幾臺(tái)電腦共享上網(wǎng),必須作端口映射,才可以做服務(wù)器(如果是一臺(tái)電腦,可以跳過(guò)這步)。

            打開(kāi)IE瀏覽器,輸入192.168.1.1,敲回車(注意,不同的ADSL貓,IP地址不同,有的是192.168.1.254,這個(gè)IP地址,可以看您的路由器說(shuō)明書(shū),或者ADSL貓說(shuō)明書(shū),上面有說(shuō)明,當(dāng)然在百度也可以查到),如下圖所示:

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

            在彈出的窗口中,點(diǎn)“轉(zhuǎn)發(fā)規(guī)則”,在“服務(wù)端口”中輸入80,在“IP地址”中輸入192.168.1.8(這是我電腦的IP地址,您也可以設(shè)置其它IP地址),在協(xié)議中選擇ALL,在啟用中“打鉤”。按照同樣的方法,輸入端口號(hào)21。如下圖所示:

            友情提示:設(shè)置80端口,是為了做WEB服務(wù)器,輸入21端口,是為了做FTP服務(wù)器。另外,教大家一招提高BT下載速度的方法,在“服務(wù)端口”輸入22557,再打開(kāi)BT軟件,點(diǎn)工具欄上的“選項(xiàng)”-“選項(xiàng)”,在彈出的窗口中的“監(jiān)聽(tīng)端口”輸入 22557,再點(diǎn)“確定”就可以了。另外,根據(jù)我的經(jīng)驗(yàn),在“全局最大上傳速率”設(shè)置成30kB/s,下載速度最快,當(dāng)然您也可以根據(jù)自己的網(wǎng)絡(luò)去設(shè)置成一個(gè)合理的值。

            

           

          二.架設(shè)WEB服務(wù)器

            關(guān)于WEB服務(wù)器的更多詳細(xì)信息見(jiàn)計(jì)算機(jī)網(wǎng)絡(luò)實(shí)驗(yàn)三。下面只介紹我自己電腦作WEB服務(wù)器的設(shè)置。

            做WEB服務(wù)器,可以用IIS,它比較簡(jiǎn)單和方便,但它有人數(shù)限制,好象同一時(shí)刻只能連接100人,所以推薦大家用 Apache。

          1.下載 Apache:下載地址

          2.安裝Apache:基本上點(diǎn)“下一步”就可以。

            安裝好后,測(cè)試一下按默認(rèn)配置運(yùn)行的網(wǎng)站界面,在 IE 地址欄打 “http://127.0.0.1” ,點(diǎn) “ 轉(zhuǎn)到 ” ,如果出現(xiàn)配置成功,表示 Apache 服務(wù)器已安裝成功。

            友情提示:如果 IIS 打開(kāi)了,要停止它(開(kāi)始-控制面板-管理工具-服務(wù)-IIS Admin禁止),否則 apache 不能啟動(dòng)!

          3.設(shè)置Apache:

            “ 開(kāi)始 ”- “ 所有程序 ”- “Apache HTTP Server 2.0.55”- “Configure Apache Server”- “Edit the Apache httpd conf Configuration file” ,點(diǎn)擊打開(kāi)。

            友情提示:每次配置文件的改變,保存后, 必須在 Apache 服務(wù)器重啟動(dòng)后生效 ,可以用前面講的小圖標(biāo)方便的控制服務(wù)器隨時(shí) “ 重啟動(dòng) ” 。

            查找關(guān)鍵字 “DocumentRoot” (也就是網(wǎng)站根目錄),找到如下圖所示地方,然后將 "" 內(nèi)的地址改成你的網(wǎng)站根目錄,地址格式請(qǐng)照?qǐng)D上的寫 ,主要是一般文件地址的 “\” 在 Apache 里要改成 “/” 。 比如我的網(wǎng)站就是: DocumentRoot "f:/web" 。

            查找 “<Directory” 來(lái)定位,將 "" 內(nèi)的地址改成跟 DocumentRoot 的一樣。 比如我的網(wǎng)站: <Directory "f:/web"> 。

            查找“DirectoryIndex” (目錄索引,也就是在僅指定目錄的情況下,默認(rèn)顯示的文件名),可以添加很多,系統(tǒng)會(huì)根據(jù)從左至右的順序來(lái)優(yōu)先顯示,以單個(gè)半角空格隔開(kāi),比如有些網(wǎng)站的首頁(yè)是 index.htm ,就在光標(biāo)那里加上 “index.htm ” 文件名是任意的,不一定非得 “index.html” ,比如 “test.php” 等,都可以。 比如我的網(wǎng)站: DirectoryIndex index.html 。

            好了,簡(jiǎn)單的 Apache 配置就到此結(jié)束了,現(xiàn)在利用先前的小圖標(biāo)重啟動(dòng),所有的配置就生效了,你的網(wǎng)站就成了一個(gè)網(wǎng)站服務(wù)器,如果你加載了防火墻,請(qǐng)打開(kāi) 80 或 8080 端口,或者允許 Apache 程序訪問(wèn)網(wǎng)絡(luò),否則別人不能訪問(wèn)。然后告訴您朋友二級(jí)域名,他們就可以訪問(wèn)了,如我網(wǎng)站的新服務(wù)器地址:http://jsjzx.xicp.net

          三.架設(shè)FTP服務(wù)器

            關(guān)于FTP服務(wù)器的更多詳細(xì)信息見(jiàn)計(jì)算機(jī)網(wǎng)絡(luò)實(shí)驗(yàn)四。下面只介紹我自己電腦作FTP服務(wù)器的設(shè)置。

            做FTP服務(wù)器,可以用IIS,它比較簡(jiǎn)單,但管理不方便,所以推薦大家用 serv-u 。

          1.下載 serv-u:下載地址

          2.安裝 serv-u:基本上點(diǎn)下一步就可以了。

          3.配置serv-u:具體操作步驟點(diǎn)這里

            通過(guò)這三步設(shè)置,您的電腦就可以作FTP服務(wù)器和WEB服務(wù)器了,如果有任何問(wèn)題和建議,請(qǐng)與站長(zhǎng)QQ317154001聯(lián)系。

          轉(zhuǎn)載于 http://cs.ecust.edu.cn/snwei/studypc/networks/server.htm

          posted @ 2012-02-17 14:57 魯勝迪 閱讀(1772) | 評(píng)論 (1)編輯 收藏

          win7 x64 安裝oracle10g x64 和 PL/SQL Developer 8.02

          一、oracle10g安裝,比較簡(jiǎn)單

              1.去Oracle網(wǎng)站下載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.修改驗(yàn)證文件來(lái)支持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.如果網(wǎng)卡IP是動(dòng)態(tài)分配的,安裝時(shí)會(huì)有警告,可以忽略,如果覺(jué)得不舒服解決方法如下:

                  添加Microsoft Loopback Adapter
                   打開(kāi)“設(shè)備管理器”右鍵單擊設(shè)備管理器窗口的計(jì)算機(jī)名->添加過(guò)時(shí)硬件->
                   安裝我手動(dòng)從列表選擇的硬件->選擇“網(wǎng)絡(luò)適配器”->
                   選擇Microsoft公司下的Microsoft Loopback Adapter,就完成了添加。
                   修改為固定IP,隨意設(shè)置,如192.168.1.6

              5.順利安裝

           

          二、PL/SQL Developer 安裝

              1.下載安裝

                  http://allroundautomations.swmirror.com/plsqldev802.exe

                  注冊(cè)碼自己搜,很多有注冊(cè)機(jī)

                  注意:不要安裝在默認(rèn)的C:\Program Files (x86)目錄下,否則會(huì)報(bào)錯(cuò),原因是不能解析這個(gè)帶()的路徑

              2.啟動(dòng)PL/SQL Developer 報(bào)以下錯(cuò)誤

           



           

           

              原因是oci.dll是64位的,32位應(yīng)用程序PLSQL Developer無(wú)法加載,在網(wǎng)上搜了搜解決方法:可以裝個(gè)32位的Oracle Client來(lái)解決,Client的功能我一般用不到,太大了不想裝。后來(lái)參考了這篇文章免安裝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.啟動(dòng)PL/SQL Developer ,點(diǎn)擊取消不要登錄,在Tools\Perferences 下的Connection 配置Oracle_Home和OCI Library,如下

           



           

                  OracleHome:OraDb10g_home1

                  OCI library:C:\oracle_client\instantclient_10_2\oci.dll

              6.設(shè)置系統(tǒng)環(huán)境變量

                  TNS_ADMIN=C:\oracle\product\10.2.0\db_1\NETWORK\ADMIN

                  NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

                  注:NLS_LANG前半部分必須是AMERICAN_AMERICA,因?yàn)閕nstant client不支持其他語(yǔ)言;而后半部分可以根據(jù)你數(shù)據(jù)庫(kù)的字符集調(diào)整,如果數(shù)據(jù)庫(kù)采用AL32UTF8,則可以設(shè)置AL32UTF8

              7.啟動(dòng)PL/SQL Developer ,OK沒(méi)問(wèn)題了。


          轉(zhuǎn)載于 http://wlwolf.iteye.com/blog/618950

          posted @ 2012-02-10 10:20 魯勝迪 閱讀(272) | 評(píng)論 (0)編輯 收藏

          <2012年2月>
          2930311234
          567891011
          12131415161718
          19202122232425
          26272829123
          45678910

          導(dǎo)航

          統(tǒng)計(jì)

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章分類

          新聞分類

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 普安县| 兖州市| 临夏市| 江永县| 桐梓县| 金山区| 波密县| 准格尔旗| 吴川市| 江城| 抚松县| 通榆县| 桐城市| 徐闻县| 商城县| 婺源县| 桦南县| 高碑店市| 神木县| 仁布县| 芦山县| 宜都市| 南乐县| 葵青区| 成武县| 康保县| 九寨沟县| 嘉善县| 桑日县| 太仓市| 垫江县| 东港市| 长顺县| 壶关县| 仙游县| 钦州市| 贡嘎县| 湾仔区| 阿图什市| 固阳县| 汉沽区|