2012年9月3日

          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 魯勝迪 閱讀(341) | 評(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

          必須要分行寫(xiě)。

          最終效果如下:

          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;    
              
          //寫(xiě)入點(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 魯勝迪 閱讀(435) | 評(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盤(pán)根目錄即可
              下載地址 :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ū)寫(xiě)三五行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 魯勝迪 閱讀(2620) | 評(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)編輯 收藏

          <2012年9月>
          2627282930311
          2345678
          9101112131415
          16171819202122
          23242526272829
          30123456

          導(dǎo)航

          統(tǒng)計(jì)

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章分類

          新聞分類

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 定边县| 大洼县| 临高县| 清涧县| 当阳市| 永丰县| 交城县| 漯河市| 疏附县| 丰宁| 沈阳市| 登封市| 申扎县| 新和县| 霍林郭勒市| 平江县| 当阳市| 紫金县| 即墨市| 庄河市| 丹凤县| 东兰县| 兴化市| 仙游县| 施甸县| 上饶县| 神木县| 长兴县| 沾益县| 荃湾区| 蕉岭县| 山阴县| 通许县| 江孜县| 潞城市| 阜新市| 分宜县| 新余市| 宝丰县| 周口市| 弋阳县|