當(dāng)幸福來敲門

          我就會牢牢抓住!
          隨筆 - 50, 文章 - 3, 評論 - 8, 引用 - 0
          數(shù)據(jù)加載中……

          2011年12月20日

          需求工程師的工作內(nèi)容

          1.和業(yè)務(wù)部門 、客戶溝通(溝通是整個需求設(shè)計到開發(fā)使用為止);
          2.學(xué)習(xí)業(yè)務(wù);
          3.有意識聽速求(客戶最急需的),也就是優(yōu)先級問題;
          4.搜集需求,整合,提煉,完成分析;(考慮周全找關(guān)聯(lián) 找核心)
          5.編寫需求產(chǎn)品文檔(文字和圖列、流程圖等相結(jié)合)
          6.掌握相關(guān)工具;(比如visio/axure)
          7.文檔系統(tǒng)講解(講解對象:開發(fā)和測試)
          8.驗證開發(fā)完后的產(chǎn)品(驗證結(jié)束后再測試);
          9.用戶培訓(xùn)(需求工程師主持);
          10.了解相關(guān)系統(tǒng)(了解整個業(yè)務(wù)面 而不是 內(nèi)部的功能點);

          注意:數(shù)據(jù)表設(shè)計中盡量存可分析的信息代碼;

          posted @ 2014-03-05 15:23 wyx 閱讀(208) | 評論 (0)編輯 收藏

          面試題積累

          1. struts1和struts2的區(qū)別
          2. hibernate和ibatis的區(qū)別
          3. json和xml的區(qū)別
          4. ajax的原理
          5. ajax和iframe嵌套有什么區(qū)別
          6. gbk utf8 iso-8859-1都是多少字節(jié)
          7. extjs和jquery的區(qū)別
          8. js從前端如何解決跨域問題
          9. 單例模式的優(yōu)點,工廠模式的原理
          10. spring的mvc模式
          11. jdk1.7新功能
          12. 為什么會出現(xiàn)亂碼

          posted @ 2014-03-04 15:35 wyx 閱讀(236) | 評論 (0)編輯 收藏

          Hibernate 查詢有關(guān)in的查詢

          http://www.iteye.com/problems/74892

          List<Integer> ids = new ArrayList<Integer>();
          ids.add(3);
          ids.add(4);
          ids.add(5);
          Query query=session.createQuery(from document where id in (:ids)); 
          query.setParameterList("ids", ids);
          query.list();

          posted @ 2013-11-18 17:42 wyx 閱讀(634) | 評論 (0)編輯 收藏

          用hibernate插入數(shù)據(jù)保證插入數(shù)據(jù)ID同步 ,插入之后返回對象

          public FDataReport addFDataReport(FDataReport datareport);//數(shù)據(jù)新錄入返回對象,對應(yīng)的就會把ID也返回

          posted @ 2013-11-04 17:43 wyx 閱讀(259) | 評論 (0)編輯 收藏

          關(guān)于登錄界面 記住用戶名和密碼的一段代碼

          Cookie cookies[]=request.getCookies();
              Cookie stCookie=null;
              String password=null;
              String passwordvalue=null;
              String usernamevalue=null;
              String cookiename = null;
              String nameandpassword[]=new String[3];
              if (cookies != null) {
             for (int i = 0; i < cookies.length; i++) {
              stCookie = cookies[i];
              cookiename = stCookie.getName();
              if (cookiename!=null && cookiename.equalsIgnoreCase("db_password")) {
               passwordvalue = stCookie.getValue();
               password = passwordvalue;//.substring(8, passwordvalue.length()-3);
               nameandpassword[1] = password.trim();
              }
              if (cookiename!=null && cookiename.equalsIgnoreCase("db_username")) {
               usernamevalue = stCookie.getValue();
               nameandpassword[0] = usernamevalue.trim();
              }
              }
           }





          <body>
          <p>
                 <label for="LoginName">
                  用戶名 / 郵箱:
                 </label>
                 <input class="text" type="text" id="LoginName" name="LoginName"
                  value="<%=nameandpassword[0]==null?"":nameandpassword[0] %>" />
                </p>
                <p>
                 <label for="Password">
                  密碼:
                 </label>
                 <input class="text" type="password" value="<%=nameandpassword[1]==null?"":nameandpassword[1] %>" name="Password" id="Password" />
                </p>


          </body>

          posted @ 2013-11-01 15:08 wyx 閱讀(318) | 評論 (0)編輯 收藏

          form表單提交兩次原因

          昨天做用戶注冊,添加用戶時候總是提交兩次
          最后才找到原因 提交表單的按鈕就是設(shè)置成button的了 但是名稱是submitButton也不可以 所以修改下按鈕名稱就可以了!!!
          ⊙﹏⊙b汗

          posted @ 2013-10-18 09:21 wyx 閱讀(431) | 評論 (0)編輯 收藏

          關(guān)于安全問題——用戶中心

          1.當(dāng)用戶操作用戶中心的信息,編碼獲取用戶對象應(yīng)該是通過該用戶登錄保存的session或者cookie獲得,
          而不是通過用戶ID獲得(否則當(dāng)有人知道通過ID傳值,容易輕易修改掉其他用戶的信息)

          2.前臺下載也需要通過后臺處理 放置業(yè)內(nèi)人士知道下載文件真實地址,獲得大量數(shù)據(jù)信息

          posted @ 2013-09-04 17:13 wyx 閱讀(213) | 評論 (0)編輯 收藏

          FCKeditor 取值

          《轉(zhuǎn)自http://blog.sina.com.cn/s/blog_5f66526e0100kf6b.html

          主要步驟:

          第一步:導(dǎo)入需要的js文件(根據(jù)實際情況修改相應(yīng)路徑)
          <script src="js/jquery.js" type=text/javascript></script>   
          <script src="fckeditor/fckeditor.js" type="text/javascript"></script>
          第二步:初始化(根據(jù)實際情況修改相應(yīng)路徑)   

          sBasePath    = '/duotunkf/fckeditor/' ;#編輯器所在文件夾;
          oFCKeditor    = new FCKeditor('content') ;
          oFCKeditor.BasePath = sBasePath ;
          oFCKeditor.Value = 'test' ;
          oFCKeditor.ToolbarSet = 'Basic' ;
          oFCKeditor.Create() ;

          其中content為頁面你所綁定的textArea的id或name

          第三步:取值

          var oEditor = FCKeditorAPI.GetInstance('content');  
          editorValue = oEditor.GetHTML();  
          第四步:賦值(更新的時候先把原有的值賦給textarea)

          var oEditor = FCKeditorAPI.GetInstance('content');  
          oEditor.SetHTML("value"); 

           

          下面是本人寫的一個賦值測試程序,供大家參考。源碼如下:

          <html>
           <head>

               <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
                  <script src="js/jquery-1.3.2.min.js"></script>
                  <script src="fckeditor/fckeditor.js"></script>
                  <script>
                  $(document).ready(function(){
                    $("#test").click(function(){
              var oEditor = FCKeditorAPI.GetInstance('content');  
              oEditor.SetHTML($("#test option:selected" ).text());
              });
            });
                  </script>
           </head>
           <body>
            
            <form action="" method="post">
                  <script>
                      sBasePath    = '/duotunkf/fckeditor/' ;#編輯器所在文件夾;
                      oFCKeditor   = new FCKeditor('content') ;
                      oFCKeditor.BasePath = sBasePath ;
                      oFCKeditor.Value = 'test' ;
                      oFCKeditor.ToolbarSet = 'Basic' ;
                      oFCKeditor.Create() ;
            </script>
             <br>
                      <label for="test">
                <select name="test" size="4" id="test">
                  <option value="1">i.點擊這里改變編輯器的值</option>
                  <option value="2">ii.點擊這里改變編輯器的值</option>
                  <option value="3">iii.點擊這里改變編輯器的值</option>
                     </select>
                    </label>
            </form>
           </body>
          </html>


          posted @ 2013-07-31 14:19 wyx 閱讀(189) | 評論 (0)編輯 收藏

          關(guān)于數(shù)據(jù)表建設(shè)的int 和 number varchar和nvarchar的區(qū)別


          提交了,剛才修正了一些問題;一主鍵需要設(shè)置number類型同時告訴擴(kuò)充到10
          管華(管華) 10:44:15
          你剛才是int類型,,int最大是到6萬多吧,,如果你設(shè)置這個,意味著到時你到6萬多的會員后,系統(tǒng)出問題,插入不進(jìn)去了,到時你還得改;
          管華(管華) 10:45:46
          第二,你用的是字符VARCHAR2類型,這個;類型在oracle里不太好,會持久化占用一部分空間,比如你設(shè)置的VARCHAR2(1000),他不管你里面有沒有數(shù)據(jù),都會占用這1000個字符的空間;因此需要改為NVARCHAR2 ,他是自適應(yīng),當(dāng)你沒存儲值,他不占據(jù)空間


          另外根據(jù)有些字段,比如人名  name  NVARCHAR2(20)分配20個字符就可了,分配500個,會浪費(fèi)多余的空間同時使得系統(tǒng)慢碎片多;因此根據(jù)實際情況,酌情分配

          posted @ 2013-07-12 10:49 wyx 閱讀(342) | 評論 (0)編輯 收藏

          sql語句特殊字符處理

          update tc_report t set xlsfile='ChinaLivestock'||chr(38)||'FeedWeeklyMarketReport20130703.doc' where t.xlsfile like 'China Livestock & Feed Weekly Market Report 20130703%'

          posted @ 2013-07-04 10:36 wyx 閱讀(275) | 評論 (0)編輯 收藏

          Tomcat修改文件重啟問題

          將tomcat下的bin\startup.bat下的文件打開后,最下面有一句話  call "%EXECUTABLE%" jpda start %CMD_LINE_ARGS%,,復(fù)制我這個替換你那個,保存后,即可實現(xiàn)不重啟就編譯java

          posted @ 2013-07-01 11:32 wyx 閱讀(181) | 評論 (0)編輯 收藏

          JavaBean中打印信息到JSP頁面

          http://blog.csdn.net/sclxf/article/details/4654080

          posted @ 2013-05-16 17:47 wyx 閱讀(169) | 評論 (0)編輯 收藏

          JS 獲得系統(tǒng)當(dāng)前時間和未來一周時間

          例子:

          function getDate(day){
             var zdate=new Date();
             var sdate=zdate.getTime()-(1*24*60*60*1000);
             var edate=new Date(sdate-(day*24*60*60*1000)).format("yyyy-MM-dd");
             return edate;
          }

           function changevalue(obj){
                 alert(obj);
                 var a = getDate(+7);
                 var b = getDate(+31);
                 if(obj=="8"){
                 document.getElementById("enddate").value=b;
                 }else{
                 document.getElementById("enddate").value=a;
                 }
           }

          posted @ 2013-05-08 15:54 wyx 閱讀(386) | 評論 (0)編輯 收藏

          轉(zhuǎn)換PDF遇到的問題java.lang.UnsatisfiedLinkError: no jcom in java.library.path

          java.lang.UnsatisfiedLinkError: no jcom in java.library.path
          將 jcom.dll 文件放在  C:\WINDOWS\system32 和jdk的bin   目錄下

          posted @ 2013-04-10 16:14 wyx 閱讀(428) | 評論 (0)編輯 收藏

          BUG 調(diào)試 加入斷點但是跳轉(zhuǎn)時候沒有走

          設(shè)置問題  Debug model選中

          posted @ 2013-04-03 15:34 wyx 閱讀(206) | 評論 (0)編輯 收藏

          投研項目 文檔 總結(jié)

          1.下載模塊:年鑒、研究報告、企業(yè)榜單和行業(yè)數(shù)據(jù)(需要權(quán)限控制)
          2.FTP使用:

          posted @ 2013-03-27 11:09 wyx 閱讀(274) | 評論 (0)編輯 收藏

          2013-03-13 項目開發(fā) 總結(jié) 連載記錄

          1.針對不同類型跳轉(zhuǎn)不同的action方法 除了使用JS以外  還可以 使用參數(shù)獲得參數(shù)例如method=....不同值來跳轉(zhuǎn)像不同的方法
          例子:分國別 (method="showCountryList")  分地區(qū)(method="showAreaList")  
                  后臺 String method = request.getParameter("method");
                       request.setAttribute("method", method);
              if (method != null && method.equals("showCountryList")) {
               return showCountryList(map, form, request, response);//分國別
             } else if (method != null && method.equals("showAreaList")) {
               return showAreaList(map, form, request, response);//分地區(qū)
             }
          2.Jsp........記得使用IFram嵌套
          <iframe width="100%" height="800" class="share_self"  frameborder="0" scrolling="no" src="/tyreportAction.do?method=lookReportInfo&bid=${record.bid } "></iframe>
           總結(jié):思維要活躍些  往往一個問題有很多種解決方法的

          posted @ 2013-03-13 09:38 wyx 閱讀(182) | 評論 (0)編輯 收藏

          大文本值CLOB取值 和 存值

          存值
           Clob  organdetail =Hibernate.createClob(request.getParameter("organdetail").equals("")?"":request.getParameter("organdetail").trim());// 機(jī)構(gòu)簡介
             取值 顯示JSP
          <%=ToolsCommon.Clob2String(institutions.getOrgandetail())==null?"":ToolsCommon.Clob2String(institutions.getOrgandetail())%>


           public static String Clob2String(java.sql.Clob clob) {
            String s1 = "";
            char ac[] = new char[200];

            if (clob == null)
             return null;
            java.io.Reader reader = null;
            int i;
            try {
             reader = clob.getCharacterStream();
             while ((i = reader.read(ac, 0, 200)) != -1)
              s1 = s1 + new String(ac, 0, i);
            } catch (Exception exception1) {
             // throw new java.sql.SQLException(exception1.getMessage());
             System.out.println(exception1.toString());
            }

            finally {
             try {
              reader.close();
             } catch (Exception _ex) {
             }
            }
            return s1;

           }

          posted @ 2013-02-28 10:20 wyx 閱讀(365) | 評論 (0)編輯 收藏

          Java 刪除文件夾 和 文件 集合

          《此文拷貝自http://kxjhlele.iteye.com/blog/323657

          1,驗證傳入路徑是否為正確的路徑名(Windows系統(tǒng),其他系統(tǒng)未使用)


          // 驗證字符串是否為正確路徑名的正則表達(dá)式
          private static String matches = "[A-Za-z]:\\\\[^:?\"><*]*";
          // 通過 sPath.matches(matches) 方法的返回值判斷是否正確
          // sPath 為路徑字符串

          2,通用的文件夾或文件刪除方法,直接調(diào)用此方法,即可實現(xiàn)刪除文件夾或文件,包括文件夾下的所有文件


              /**
               *  根據(jù)路徑刪除指定的目錄或文件,無論存在與否
               *@param sPath  要刪除的目錄或文件
               *@return 刪除成功返回 true,否則返回 false。
               */
              public boolean DeleteFolder(String sPath) {
                  flag = false;
                  file = new File(sPath);
                  // 判斷目錄或文件是否存在
                  if (!file.exists()) {  // 不存在返回 false
                      return flag;
                  } else {
                      // 判斷是否為文件
                      if (file.isFile()) {  // 為文件時調(diào)用刪除文件方法
                          return deleteFile(sPath);
                      } else {  // 為目錄時調(diào)用刪除目錄方法
                          return deleteDirectory(sPath);
                      }
                  }
              }

          3,實現(xiàn)刪除文件的方法,

              /**
               * 刪除單個文件
               * @param   sPath    被刪除文件的文件名
               * @return 單個文件刪除成功返回true,否則返回false
               */
              public boolean deleteFile(String sPath) {
                  flag = false;
                  file = new File(sPath);
                  // 路徑為文件且不為空則進(jìn)行刪除
                  if (file.isFile() && file.exists()) {
                      file.delete();
                      flag = true;
                  }
                  return flag;
              }

          4,實現(xiàn)刪除文件夾的方法,

              /**
               * 刪除目錄(文件夾)以及目錄下的文件
               * @param   sPath 被刪除目錄的文件路徑
               * @return  目錄刪除成功返回true,否則返回false
               */
              public boolean deleteDirectory(String sPath) {
                  //如果sPath不以文件分隔符結(jié)尾,自動添加文件分隔符
                  if (!sPath.endsWith(File.separator)) {
                      sPath = sPath + File.separator;
                  }
                  File dirFile = new File(sPath);
                  //如果dir對應(yīng)的文件不存在,或者不是一個目錄,則退出
                  if (!dirFile.exists() || !dirFile.isDirectory()) {
                      return false;
                  }
                  flag = true;
                  //刪除文件夾下的所有文件(包括子目錄)
                  File[] files = dirFile.listFiles();
                  for (int i = 0; i < files.length; i++) {
                      //刪除子文件
                      if (files[i].isFile()) {
                          flag = deleteFile(files[i].getAbsolutePath());
                          if (!flag) break;
                      } //刪除子目錄
                      else {
                          flag = deleteDirectory(files[i].getAbsolutePath());
                          if (!flag) break;
                      }
                  }
                  if (!flag) return false;
                  //刪除當(dāng)前目錄
                  if (dirFile.delete()) {
                      return true;
                  } else {
                      return false;
                  }
              }

          5,main() 方法


              public static void main(String[] args) {

                  HandleFileClass hfc = new HandleFileClass();
                  String path = "D:\\Abc\\123\\Ab1";
                  boolean result = hfc.CreateFolder(path);
                  System.out.println(result);
                  path = "D:\\Abc\\124";
                  result = hfc.DeleteFolder(path);
                  System.out.println(result);

              }


          main() 方法只是做了一個簡單的測試,建立文件夾和文件都是本地建立,情況考慮的應(yīng)該很全面了,包括文件夾包含文件夾、文件。文件的不同情況…………

           

          實現(xiàn)沒有問題,可以正確刪除文件夾和文件。

           

          對于其他類型文件的操作繼續(xù)學(xué)習(xí)…………




          posted @ 2013-01-18 15:58 wyx 閱讀(304) | 評論 (0)編輯 收藏

          JFreechar

          http://www.aygfsteel.com/amigoxie/archive/2007/09/30/149765.html

          posted @ 2012-12-26 15:51 wyx 閱讀(194) | 評論 (0)編輯 收藏

          orcle修改屬性字段 并且保留原有值

          1.原字段類型是字符串 使用“||”連接
          update table1 set num = substr(num,0,instr(num,'-'))||(substr(num,instr(num,'-')+1) +9) 
          2.原字段是數(shù)字 使用+連接
          UPDATE table1SET num = num+10 
          3.截取 update tc_report t set xlsfile=substr(xlsfile,6) where xlsfile like '%uku\%'

          posted @ 2012-11-12 10:20 wyx 閱讀(337) | 評論 (0)編輯 收藏

          form表單 修改 多選框默認(rèn)選中

          1.放到HashMap中
            String varsort=exp.getVarsort();
             String vars[]=null;
             HashSet setvar = new HashSet();
             if(varsort!=null&&!varsort.trim().equals("")){
              vars=varsort.substring(0,varsort.length()-1).split(",");
              for(int i=0;i<vars.length;i++){
               setvar.add(vars[i].trim());
              }
             }
          2. contains比較是否包含
          <% if(varsorts!=null&&varsorts.size()>0){
                     for(int j=0;j<varsorts.size();j++){
                      TDictionarys td=varsorts.get(j);
                      %>
                   <input type="checkbox" value="<%=td.getDataid() %>" <%if(setvar.contains(String.valueOf(td.getDataid()).trim())){out.print("checked");} %> onclick="getBreeds()" name="varsort" id="varsort" />
                   <label for="checkbox" class="font12">
                   <%=td.getName() %>
                      </label>
                      <%
                     }
                    }
                   %>
                  

          posted @ 2012-09-21 18:03 wyx 閱讀(1330) | 評論 (1)編輯 收藏

          頁面級緩存處理

          前提  列表走了數(shù)據(jù)庫查詢
          1.引入架包  <%@ taglib uri="oscache" prefix="cache"%>
          2.包含要緩存的部分
          <cache:cache key="dbnewscache" time="3600">  
                  <%List<Article> list=new CmsByMysql().getNews(); %>
                    <c:forEach var="cu" items="<%=list%>">
                         <li>
                    <a href="${cu.url}">${cu.titleContent} </a>
                      </li>
                    </c:forEach>
          </cache:cache>

          posted @ 2012-09-21 17:25 wyx 閱讀(229) | 評論 (0)編輯 收藏

          Ifram 父子頁面 JS調(diào)用

          <iframe marginwidth="0" framespacing="0" marginheight="0" frameborder="0"
          name="uploadframe" id="uploadframe" src="c.html" scrolling="no" width="100" height="100" ></iframe>
          如想在c.html 中寫一些代碼去改變parent.html 中的一些內(nèi)容,以下代碼可作為參考:

          1、parent.window.frames 可返回parent.html 中所有的iframe;返回結(jié)果應(yīng)該是一個數(shù)組,用parent.window.frames[iframeId]可得到iframeId;

          2、用parent.document.getElementById('xxxx')可得到父里的xxxx,并改變相應(yīng)的值,例如:parent.document.getElementById('xxxx').className = 'test';

          3、如果我想在父中再創(chuàng)建一個元素,直接用parent.appendChild(yyyy)在firefox中是可以的,但在IE(最起碼IE6)是不行的; 所以,要把創(chuàng)建這個動作放在父中來完成,在子中調(diào)用;

           parent.document.getElementById("pinming").innerHTML = retText2;

          posted @ 2012-07-24 15:29 wyx 閱讀(717) | 評論 (0)編輯 收藏

          jquery目錄樹 js實現(xiàn) 目錄數(shù)插件

          2011-07-13 10:07

          jQuery 目錄樹插件介紹——ligerTree

           

           

          一,簡介 

          ligerTree的功能列表:

          1,支持本地數(shù)據(jù)和服務(wù)器數(shù)據(jù)(配置data或者url)

          2,支持原生html生成Tree

          3,支持動態(tài)獲取增加/修改/刪除節(jié)點

          4,支持大部分常見的事件

          5,支持獲取選中行等常見的接口方法

           

          二,第一個例子

          引入庫文件

          遵循LigerUI系列插件的設(shè)計原則(插件盡量單獨(dú)),ligerTree是一個單獨(dú)的插件,也就是說只需要引入plugins/ligerTree.js和樣式css文件就可以使用(當(dāng)然必須先引入jQuery),在這個例子中,我把tree用到的樣式和圖片分離了出來,有興趣的朋友可以下載來看看

            

          <script src="lib/jquery/jquery-1.3.2.min.js" type="text/javascript"></script>
          <link href="lib/ligerUI/skins/Aqua/css/ligerui-tree.css" rel="stylesheet" type="text/css"/>
          <script src="lib/ligerUI/js/plugins/ligerTree.js" type="text/javascript"></script>

          加入HTML

            

          <ul id="tree1">
          <li>
          <span>節(jié)點1</span>
          <ul>
          <li>
          <span>節(jié)點1.1</span>
          <ul>
          <li><span>節(jié)點1.1.1</span></li>
          <li><span>節(jié)點1.1.2</span></li>
          </ul>
          </li>
          <li><span>節(jié)點1.2</span></li>
          </ul>
          </li>
          </ul>

          調(diào)用ligerTree

          <table style="margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; margin-left: 0px !important; padding-top: 0px !important; padding-right: 0px !important; padding-bottom: 0px !important; padding-left: 0px !important; border-top-width: 0px !important; border-right-width: 0px !important; border-bottom-width: 0px !important; border-left-width: 0px !important; border-style: initial !important; border-color: initial !important; outline-width: 0px !important; outline-style: initial !important; outline-color: initial !important; background-image: none !important; background-attachment: initial !important; background-origin: initial !important; background-clip: initial !important; background-color: initial !important; text-align: left !important; float: none !important; vertical-align: baseline !important; position: static !important; left: auto !important; top: auto !important; right: auto !important; bottom: auto !important; height: auto !important; width: auto !important; font-family: Consolas, 'Bitstream Vera Sans Mono', 'Courier New', Courier, monospace !important; font-weight: normal !important; font-style: normal !important; font-size: 1em !important; min-height: inherit !important; border-collapse: collapse !important; background-position: initial initial !important; background-repeat: initial initial !important; "><td style="font-size: 1em !important; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 0px !important; margin-left: 0px !important; padding-top: 0px !important; padding-right: 0px !important; padding-bottom: 0px !important; padding-left: 0.5em !important; border-top-width: 0px !important; border-right-width: 0px !important; border-bottom-width: 0px !important; border-left-width: initial !important; border-style: initial !important; border-color: initial !important; outline-width: 0px !important; outline-style: initial !important; outline-color: initial !important; background-image: none !important; background-attachment: initial !important; background-origin: initial !important; background-clip: initial !important; background-color: initial !important; text-align: left !important; float: none !important; vertical-align: top !important; position: static !important; left: auto !important; top: auto !important; right: auto !important; bottom: auto !important; height: auto !important; width: auto !important; font-family: Consolas, 'Bitstream Vera Sans Mono', 'Courier New', Courier, monospace !important; font-weight: normal !important; font-style: normal !important; min-height: inherit !important; border-left-style: none !important; border-left-color: initial !important; color: rgb(0, 0, 0) !important; background-position: initial initial !important; background-repeat: initial initial !important; ">$("#tree1").ligerTree();

          效果圖

          三,常用場景

          場景一:不使用復(fù)選框: 

          $("#tree2").ligerTree({ checkbox: false });

          場景二:不使用復(fù)習(xí)框和圖標(biāo): 

          $("#tree3").ligerTree({ checkbox: false, parentIcon: null, childIcon: null });

          效果如圖:

          ?

          append(parentNode, newdata)增加節(jié)點集合clear()清空collapseAll()全部節(jié)點都折疊demotion(treenode)降級為葉節(jié)點級別expandAll()全部節(jié)點都展開getChecked()獲取選擇的行(復(fù)選框)getData()獲取樹的數(shù)據(jù)源getParentTreeItem(treenode, level)獲取父節(jié)點getSelected()獲取選擇的行hasChildren(treenode)是否包含子節(jié)點 loadData(node, url, param)加載數(shù)據(jù)remove(node)刪除節(jié)點upgrade(treenode)升級為父節(jié)點級別

          posted @ 2012-07-04 16:59 wyx 閱讀(2100) | 評論 (1)編輯 收藏

          讀取 文本 文件內(nèi)容 FileInputStream 亂碼處理

            StringBuffer content = new StringBuffer();
          //  FileInputStream fis = null;
          //  byte[] b = new byte[2048];
          //  try {
          //    if(lang!=null&&lang.trim().equals("10")){
          //     fis = new FileInputStream(passwordTemplatePath);
          //     }else if(lang!=null&&lang.trim().equals("20")){
          //      fis = new FileInputStream(passwordTemplateEnPath);
          //     }else if(lang!=null&&lang.trim().equals("30")){
          //      fis = new FileInputStream(passwordTemplateChinaEnPath);
          //     }
          //     int m = 0;
          //   while ((m = fis.read(b)) != -1) {
          //    content.append(new String(b, 0, m));
          //   }
          //passwordTemplatePath 文本 文件地址
            BufferedReader br = null;
            try {
              if(lang!=null&&lang.trim().equals("10")){
                   br =  new BufferedReader(new InputStreamReader(new FileInputStream(passwordTemplatePath), "utf-8"));
                }else if(lang!=null&&lang.trim().equals("20")){
                 br =  new BufferedReader(new InputStreamReader(new FileInputStream(passwordTemplateEnPath), "utf-8"));
               }else if(lang!=null&&lang.trim().equals("30")){
                  br =  new BufferedReader(new InputStreamReader(new FileInputStream(passwordTemplateChinaEnPath), "utf-8"));
                }
              String s = null;
              while ((s = br.readLine()) != null) {
              content.append(s);
             }
            } catch (Exception e) {
             e.printStackTrace();
            } finally {
             try {
              br.close();
             } catch (IOException e) {
              e.printStackTrace();
             }
            }

          posted @ 2012-06-26 17:15 wyx 閱讀(2123) | 評論 (2)編輯 收藏

          線程等待問題處理

          class MyThread implements Runnable {
          @Override
          public void run() {
            System.out.println("1、進(jìn)入run()方法休眠");
            try {
             System.out.println("2、線程休眠20秒");
             Thread.sleep(20000);//這里休眠20秒
             System.out.println("3、線程正常休眠完畢");
            } catch (InterruptedException e) {
             System.out.println("4、線程發(fā)生異常休眠被中斷");
             return;//返回方法調(diào)用處
            }
            System.out.println("5、線程正常結(jié)束run()方法體");
          }
          }
          public class InterruptDemo {

          public static void main(String[] args) {
            MyThread mt = new MyThread();
            Thread t = new Thread(mt,"線程A");
            t.start();//啟動線程
          //========================================================
            try {
             Thread.sleep(2000);  //保證線程至少執(zhí)行2秒
            } catch (InterruptedException e) {
             e.printStackTrace();
            }
          //========================================================
            t.interrupt();//中斷線程
          }
          }

          posted @ 2012-06-21 15:21 wyx 閱讀(207) | 評論 (0)編輯 收藏

          "Mon Dec 28 00:00:00 CST 2008"的格式字符串轉(zhuǎn)換 yyyy-MM-dd 格式

          public static void main(String[] args)
           {
             try {
                java.util.Date date;
                // 首先設(shè)置"Mon Dec 28 00:00:00 CST 2008"的格式,用來將其轉(zhuǎn)化為Date對象
                DateFormat df = new SimpleDateFormat("EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);

                //將已有的時間字符串轉(zhuǎn)化為Date對象
                date = df.parse("Tue Jun 19 00:00:00 CST 2012");// 那天是周一
                // 創(chuàng)建所需的格式
                df = new SimpleDateFormat("yyyy-MM-dd");
                String str = df.format(date);// 獲得格式化后的日期字符串
                System.err.println(str);// 打印最終結(jié)果
               } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
               }


           }

          posted @ 2012-06-19 16:12 wyx 閱讀(6996) | 評論 (1)編輯 收藏

          JAVA開發(fā)者最常去的25個英文網(wǎng)站 (轉(zhuǎn)載http://handawei.iteye.com/blog/675034)

        1. http://www.infoq.com/ - Info IT新聞
        2. http://www.apache.org/ - Apache基金會
        3. http://www.springsource.org/ - 廣大Java開發(fā)者喜愛的Spring
        4. http://www.hibernate.org/ - 開源ORM框架
        5. http://sourceforge.net/ - 開源技術(shù)的集結(jié)地
        6. http://www.javaalmanac.com – Java開發(fā)者年鑒一書的在線版本. 要想快速查到某種Java技巧的用法及示例代碼, 這是一個不錯的去處.
        7. http://www.onjava.com – O’Reilly的Java網(wǎng)站. 每周都有新文章.
        8. http://java.sun.com – 官方的Java開發(fā)者網(wǎng)站 – 每周都有新文章發(fā)表.
        9. http://www.developer.com/java – 由Gamelan.com 維護(hù)的Java技術(shù)文章網(wǎng)站.
        10. http://www.java.net – Sun公司維護(hù)的一個Java社區(qū)網(wǎng)站.
        11. http://www.builder.com – Cnet的Builder.com網(wǎng)站 – 所有的技術(shù)文章, 以Java為主.
        12. http://www.ibm.com/developerworks/java – IBM的Developerworks技術(shù)網(wǎng)站; 這是其中的Java技術(shù)主頁.
        13. http://www.javaworld.com – 最早的一個Java站點. 每周更新Java技術(shù)文章.
        14. http://www.devx.com/java – DevX維護(hù)的一個Java技術(shù)文章網(wǎng)站.
        15. http://www.fawcette.com/javapro – JavaPro在線雜志網(wǎng)站.
        16. http://www.sys-con.com/java – Java Developers Journal的在線雜志網(wǎng)站.
        17. http://www.javadesktop.org – 位于Java.net的一個Java桌面技術(shù)社區(qū)網(wǎng)站.
        18. http://www.theserverside.com – 這是一個討論所有Java服務(wù)器端技術(shù)的網(wǎng)站.
        19. http://www.jars.com – 提供Java評論服務(wù). 包括各種framework和應(yīng)用程序.
        20. http://www.jguru.com – 一個非常棒的采用Q&A形式的Java技術(shù)資源社區(qū).
        21. http://www.javaranch.com – 一個論壇,得到Java問題答案的地方,初學(xué)者的好去處。
        22. http://www.ibiblio.org/javafaq/javafaq.html – comp.lang.java的FAQ站點 – 收集了來自comp.lang.java新聞組的問題和答案的分類目錄.
        23. http://java.sun.com/docs/books/tutorial/ – 來自SUN公司的官方Java指南 – 對于了解幾乎所有的java技術(shù)特性非常有幫助.
        24. http://www.javablogs.com – 互聯(lián)網(wǎng)上最活躍的一個Java Blog網(wǎng)站.
        25. http://java.about.com/ – 來自About.com的Java新聞和技術(shù)文章網(wǎng)站.
        26. posted @ 2012-06-15 15:44 wyx 閱讀(207) | 評論 (0)編輯 收藏

          EL表達(dá)式處理字符串 是否 包含 某字符串 截取 拆分...............

          JSP頁面頁頭添加
          <%@ taglib uri="/WEB-INF/taglib/c.tld" prefix="c"%>
          <%@ taglib prefix="fn" uri="頁面內(nèi)容如下: 

          <c:if test="${fn:contains(record.name,'樣例')==false}">
                                           <%
                   if ((f != null && f.trim().equals("0"))&&name!=null&&!name.trim().equals("免費(fèi)報告")) {
                  %><a
                   href="javascript:void(0);alert('很抱歉,您無權(quán)訪問!如需訪問請購買產(chǎn)品或聯(lián)系管理員...');">
                   ${record.name} </a>
                  <%
                   } else {
                  %>
                  <a
                   href="/tcreportAction.do?method=lookReportInfo&bid=${record.bid } ">${record.name}</a>
                  <%
                   }
                  %>
                   </c:if>
                     <c:if test="${fn:contains(record.name,'樣例')}">
                                             <a
                   href="/tcreportAction.do?method=lookReportInfo&bid=${record.bid } ">${record.name}</a>
                 
                                           </c:if>



          ${wjcd.lrsj}原來得到的是如2006-11-12 11:22:22.0

          ${fn:substring(wjcd.lrsj, 0, 16)}

          使用functions函數(shù)來獲取list的長度

          ${fn:length(list)}

           

           

           

          1. fn:contains(string, substring)   
          2. 假如參數(shù)string中包含參數(shù)substring,返回true   
          3.   
          4. fn:containsIgnoreCase(string, substring)   
          5. 假如參數(shù)string中包含參數(shù)substring(忽略大小寫),返回true   
          6.   
          7. fn:endsWith(string, suffix)   
          8. 假如參數(shù) string 以參數(shù)suffix結(jié)尾,返回true   
          9.   
          10. fn:escapeXml(string)   
          11. 將有非凡意義的XML (和HTML)轉(zhuǎn)換為對應(yīng)的XML character entity code,并返回   
          12.   
          13. fn:indexOf(string, substring)   
          14. 返回參數(shù)substring在參數(shù)string中第一次出現(xiàn)的位置   
          15.   
          16. fn:join(array, separator)   
          17. 將一個給定的數(shù)組array用給定的間隔符separator串在一起,組成一個新的字符串并返回。   
          18.   
          19. fn:length(item)   
          20. 返回參數(shù)item中包含元素的數(shù)量。參數(shù)Item類型是數(shù)組、collection或者String。假如是String類型,返回值是String中的字符數(shù)。   
          21.   
          22. fn:replace(string, before, after)   
          23. 返回一個String對象。用參數(shù)after字符串替換參數(shù)string中所有出現(xiàn)參數(shù)before字符串的地方,并返回替換后的結(jié)果   
          24.   
          25. fn:split(string, separator)   
          26. 返回一個數(shù)組,以參數(shù)separator 為分割符分割參數(shù)string,分割后的每一部分就是數(shù)組的一個元素   
          27.   
          28. fn:startsWith(string, prefix)   
          29. 假如參數(shù)string以參數(shù)prefix開頭,返回true   
          30.   
          31. fn:substring(string, begin, end)   
          32. 返回參數(shù)string部分字符串, 從參數(shù)begin開始到參數(shù)end位置,包括end位置的字符   
          33.   
          34. fn:substringAfter(string, substring)   
          35. 返回參數(shù)substring在參數(shù)string中后面的那一部分字符串   
          36.   
          37. fn:substringBefore(string, substring)   
          38. 返回參數(shù)substring在參數(shù)string中前面的那一部分字符串   
          39.   
          40. fn:toLowerCase(string)   
          41. 將參數(shù)string所有的字符變?yōu)樾懀⑵浞祷?  
          42.   
          43. fn:toUpperCase(string)   
          44. 將參數(shù)string所有的字符變?yōu)榇髮懀⑵浞祷?  
          45.   
          46. fn:trim(string)   
          47. 去除參數(shù)string 首尾的空格,并將其返回 


          截取字符串!使用!

           
          <c:if test="${fn:length(onebeans.info)>100 }">${ fn:substring( onebeans.info ,0,100)} ...</c:if>
           <c:if test="${fn:length(onebeans.info)<=100 }">${  onebeans.info }</c:if>


          posted @ 2012-06-14 14:38 wyx 閱讀(29481) | 評論 (0)編輯 收藏

          Enter回車 鍵盤事件 終止提交表單方法 終止執(zhí)行submit

          終止執(zhí)行submit
          <form name="myf" action="/....."> 
          <input name="pmcode" id="pmcode" value="<%=pmcode%>"
                      type="text" class="shuihao" onkeydown="if(event.keyCode==13){event.keyCode = 9 ;searchCodes();return false;}" size="20" maxlength="20" />
          </form>
           當(dāng)回車的時候 將鍵盤碼變成別的  例如 If( event.keyCode == 13) event.keyCode = 9 之類。

          posted @ 2012-05-17 11:20 wyx 閱讀(295) | 評論 (0)編輯 收藏

          js傳以 0 開頭的值問題解決

            msg+="<li id=\""+codes[i].value+"\" name=\""+codes[i].value+"\" ><INPUT class=\"ac\" onclick=\"javascript:nextSetcode('"+codes[i].value+"');oper('"+codes[i].value+"');\" type=\"button\" name=\"codes\" value=\""+codes[i].value+"\" /></li>";
          動態(tài)參數(shù)據(jù) JS方法加 單引號  方法如上

          posted @ 2012-05-11 10:37 wyx 閱讀(932) | 評論 (0)編輯 收藏

          JSP中實現(xiàn)添加一行,刪除一行操作

          <%@ page language="java" import="java.util.*" pageEncoding="GBK"%>

          <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
          <SCRIPT type="text/javascript">
          function numberCells()
          {
              var count=0;
              for (i=0; i < document.all.Tab.rows.length; i++)
              {
                  for (j=0; j < document.all.Tab.rows(i).cells.length; j++)
                  {
                      document.all.Tab.rows(i).cells(j).innerText = count;
                      count++;
                  }
              }
          }

          function tb_addnew()
          {
          var ls_t=document.all("Tab")
          maxcell=ls_t.rows(0).cells.length;
          mynewrow = ls_t.insertRow();
              for(i=0;i <maxcell;i++)
              {
          mynewcell=mynewrow.insertCell();
          mynewcell.innerText="a"+i;

              }
          }

          function tb_delete()
          {
          var ls_t=document.all("Tab");

          ls_t.deleteRow() ;
          }

          </SCRIPT>
          <html>
           <head>
           <script type="text/javascript">
            function addRow(TabId){
            //獲取要插入行的表格
            var table = document.getElementByIdx_x(TabId);
             //在最后一行插入一行
             var newRow = table.insertRow(table.rows.length);
              //在該行插入單元格
              var newCel1 = newRow.insertCell(0);
               var newCel2 = newRow.insertCell(1);
               var newCel3 = newRow.insertCell(2);
               newCel1.innerHTML = "第一列";
               newCel2.innerHTML = "第二列";
               newCel3.innerHTML = "第三列";
               }
               </script>
           </head>
           <body>
            <center>
             <table id="Tab" border="1" cellspacing="0" cellpadding="0">
              <tr>
               <td>
                第一列
               </td>
               <td>
                第二列
               </td>
               <td>
                第三列
               </td>
             </table>
             <br>
             <input type="button" onclick="addRow('Tab');" value="插入行"/>
             <input type="button" onclick="tb_delete();" value="刪除行"/>
             <input type="button" onclick="tb_addnew();" value="添加行"/>
             <input type="button" onclick="numberCells();" value="顯示單元個數(shù)"/>
             
            </center>
           </body>
          </html>

          posted @ 2012-03-21 16:52 wyx 閱讀(3079) | 評論 (1)編輯 收藏

          FineReport學(xué)習(xí)(一)

          設(shè)置單元格的顯示格式 :
            單擊單元格右鍵——樣式——自定義 就OK了
          輸出保存各種文件格式:導(dǎo)航欄,文件——輸出
          http://www.finereport.com/knowledge/faq

          posted @ 2012-03-12 16:06 wyx| 編輯 收藏

          A.jsp iframe B.jsp 子頁面調(diào)用父頁面控件

          parent.function()  就可以通過B.jsp去調(diào)用A。jsp的函數(shù)

          在B.jsp中通過javascript代碼中可以通過parent對象來訪問A.jsp中的內(nèi)容。在A.jsp中寫的代碼差不多,只要加上"parent."前綴就可以訪問了。

          posted @ 2012-03-07 11:26 wyx 閱讀(855) | 評論 (1)編輯 收藏

          MyEclipse8.6 編輯JSP頁面卡 優(yōu)化

          步驟:
            1.windows--》preferences
              ——
          2.General——Editors
            ———

          3.File Associations


          將改圖的值設(shè)為默認(rèn)的

          posted @ 2012-03-07 09:49 wyx 閱讀(1509) | 評論 (0)編輯 收藏

          lucenes 查詢

          --分詞收索  
          創(chuàng)建
          String name = rs.getString("name");
              if (name != null && !name.equals(""))
               document.add(new Field("name", name, Field.Store.YES,
                 Field.Index.UN_TOKENIZED));
          檢索
          query = new TermQuery(new Term("name", name));      
            booleanQuery.add(query, BooleanClause.Occur.MUST);

          posted @ 2012-02-22 12:29 wyx 閱讀(204) | 評論 (0)編輯 收藏

          java.util.Date和java.sql.Date 轉(zhuǎn)換問題

          SimpleDateFormat bartDateFormat =   new SimpleDateFormat("yyyy-MM-dd");  
                java.sql.Date btime=null;;
                if(cdata.getBegintime()!=null){
                java.util.Date date = bartDateFormat.parse(cdata.getBegintime().toString()); 
                  btime= new java.sql.Date(date.getTime());
                 
                }else{
                 java.util.Date date = bartDateFormat.parse("1970-01-01");
                 btime= new java.sql.Date(date.getTime());
                }

          posted @ 2012-01-17 10:59 wyx 閱讀(215) | 評論 (0)編輯 收藏

          Mysql插入 關(guān)鍵字 屬性設(shè)置

          insert into v9_dataen_data (content, `from`, gengxin, danwei, btime, etime)values( '碳酸飲料 價格', 'BOABC','3', 'Yuan',1262275200, 1320076800)
          注意from的設(shè)置   `` 符號

          posted @ 2012-01-12 16:58 wyx 閱讀(215) | 評論 (0)編輯 收藏

          Lucene搜集 排序 、過濾、分詞

          2010-03-24 22:05 859人閱讀 評論(0) 收藏 舉報

          1.    排序

          1.1. Sort

          public Sort()

          public Sort(String field)

          public Sort(String field,Boolean reverse) //默認(rèn)為false,降序排序

          public Sort(String[] fields)

          public Sort(SortField field)

          public Sort(SortField[] fields)

          Sort sort=new Sort(bookname);按照“bookname“這個Field值進(jìn)行降序排序

          Sort sort=new Sort(bookname,true) //升序排序

          Sort sort=new Sort(new String[]{bookNumber,bookname,publishdate});按照三個Field進(jìn)行排序,但無法指定升序排序,所以用SortField

          1.2. SortField

          public SortField(String field)

          public SortField(String field,Boolean reverse)

          public SortField(String field,int type) //type表示當(dāng)前Field值的類型

          public SortField(String field,int type,boolean reverse) //默認(rèn)為false,升序

          Field值的類型:SortField.STRINGSortField.INTSortField.FLOAT

          SortField sf1=new SortField(“bookNumber”,SortField.INT,false);

          SortField sf2=new SortField(“bookname”,SortField.STRING,false);

          1.3. 指定排序的法則

          1.3.1.按照文檔的得分降序排序

          Hits hits=searcher.search(query,Sort.RELEVANCE);

          1.3.2.按文檔的內(nèi)部ID升序排序

          Hits hits=searcher.search(query, Sort.INDEXORDER);

          1.3.3.按照一個Field來排序

          Sort sort=new Sort();

          SortField sf=new SortField(“bookNumber”,SortField.INT,false);

          sort.setSort(sf);

          Hits hits=searcher.search(query,sort);

          1.3.4.按照多個Field來排序

          Sort sort=new Sort();

          SortField sf1=new SortField(bookNumber,SortField.INT,false);//升序

          SortField sf2=new SortField(publishdate,SortField.STRING,true);//降序

          sort.setSort(new SortField[]{sf1,sf2});

          Hits hits=searcher.search(query,sort);

          1.3.5.改變SortField中的Locale信息

          String str1=”我”; String str2=”你”;

          Collator co1=Collator.getInstance(Locale.CHINA);

          Collator co2=Collator.getInstance(Locale.JAPAN);

          System.out.println(Locale.CHINA+:+co1.compare(str1str2));

          System.out.println(Locale.JAPAN+”:”+co2.compare(str1,str2));

          輸出結(jié)果為:

          zh_CN:1

          ja_JP:-1

          所以

          public SortField(String field,Locale locale)

          public SortField(String field,Locale locale,boolean reverse)

          2.    過濾器

          使用public Hits search(Query query,Filter filter)

          1)簡單過濾

          Hits hits=searcher.search(query,new AdvancedSecurityFilter());//過濾掉securitylevel0的結(jié)果

          2)范圍過濾—RangeFilter

          只顯示中間的

          RangeFilter filter=new RangeFilter(“publishdate”,”1970-01-01”,”1998-12-31”,true,true”);

          Hits hits=searcher.search(query,filter);

           

          無上邊界

          public static RangeFilter More(String fieldname,String lowerTerm)

           

          無下邊界

          public static RangeFilter Less(String fieldname,String upperTerm)

          (3)在結(jié)果中查詢QueryFilter

          RangeQuery q=new RangeQuery(new Term(“publicshdate”,”1970-01-01”),

          new Term(“publishdate”,”1999-01-01”),true);

          QueryFilter filter=new QueryFilter(q);

          Hits hits=searcher.search(query,filter);

          3.    分析器Analysis

          3.1. 自帶分析器和過濾器

          Ø         標(biāo)準(zhǔn)過濾器:StandardAnalyzer

          Ø         大小寫轉(zhuǎn)換器:LowerCaseFilter

          Ø         忽略詞過濾器:StopFilter

          public StopFilter(TokenStream input,String [] stopWords)

          public StopFilter(TokenStream in,String [] stopWords,boolean ignoreCase)

          public StopFilter(TokenStream input,Set stopWords,boolean ignoreCase)

          public StopFilter(TokenStream in, Set stopWords)

          其中,參數(shù)TokenStream代表當(dāng)前正在進(jìn)行處理的流;String類型的數(shù)組代表一個用數(shù)組表示的忽略詞集合;Set類型的參數(shù)與String一樣,是用來表示忽略詞集合的;boolean表示當(dāng)與忽略詞集合中的詞進(jìn)行匹配時,是否需要忽略大小寫。

          Ø         長度過濾器:LengthFilter

          Ø         PerFieldAnalyzerWrapper

          Ø         WhitespaceAnalyzer

          String str="str1 str2 str3";

                 StringReader reader=new StringReader(str);

                 Analyzer anlyzer=new WhitespaceAnalyzer();

                

                 TokenStream ts=anlyzer.tokenStream("", reader);

                 Token t=null;

                 while( (t=ts.next())!=null ){

                     System.out.println(t.termText());

                 }

          3.2. 第三方過分析器

          Ø         單字分詞

          Ø         二分法:CJKAnalyzer、中科院ICTCLAS分詞、JE分詞

          Ø         詞典分詞

          3.2.1.JE分詞用法

          3.2.1.1.    示例

          import jeasy.analysis.MMAnalyzer;

          IndexWriter writer = new IndexWriter(INDEX_STORE_PATH, new MMAnalyzer()

          , true);

          String str=" Lucene是一個全文檢索引擎的架構(gòu),"+

                     "提供了完整的查詢引擎和索引引擎。Lucene以其方便使用、快" +

                     "速實施以及靈活性受到廣泛的關(guān)注。它可以方便地嵌入到各種應(yīng)用" +

                     "中實現(xiàn)針對應(yīng)用的全文索引、檢索功能,本總結(jié)使用lucene--2.3.2";

                 MMAnalyzer analyzer=new MMAnalyzer();

                 try{

                     System.out.println(analyzer.segment(str, "|"));

                 }

                 catch(Exception e)

                 {

                     e.printStackTrace();

                 }

          輸出結(jié)果:lucene|一個|全文|檢索|引擎|架構(gòu)|提供|完整|查詢|。。。。

          3.2.1.2.    設(shè)定正向最大匹配的字?jǐn)?shù)

          MMAnalyzer analyzer=new MMAnalyzer(4);

          3.2.1.3.    添加新詞

          MMAnalyzer.addWord(String word);

          MMAnalyzer.addDictionary(Reader reader);

           

          MMAnalyzer analyzer=new MMAnalyzer();

          MMAnalyzer.addWord("邁克爾雷第");

           

          4.    索引的合并

          RAMDirectory RAMDir=new RAMDirectory();

          IndexWriter writer = new IndexWriter(RAMDir, new StandardAnalyzer(), true);//刪除原有索引

          IndexWriter writer2=new IndexWriter(FSDirectory.getDirectory(path,true),

          new StandardAnalyzer(), true);

          writer.addDocument(doc1);

          writer2.addDocument(doc2);

          writer.close();

          writer2.addIndexes(new Directory[]{RAMDir});

          writer2.close();

          posted @ 2011-12-30 16:34 wyx 閱讀(1397) | 評論 (0)編輯 收藏

          Java方法導(dǎo)出Excel數(shù)據(jù)

          public ActionForward exportExcel(ActionMapping mapping,
             ActionForm form, HttpServletRequest request,
             HttpServletResponse response) {  
            String sfile = this.getServlet().getServletContext().getRealPath("/upload/")+ File.separator +"data.xls";// 服務(wù)器端名字
            String filename ="data.xls";// 客戶端名字
            OutputStream os = null;
            WritableWorkbook wwb = null;
            try {
             os = new FileOutputStream(savePath);
             wwb = Workbook.createWorkbook(os);//第一步,創(chuàng)建一個webbook,對應(yīng)一個Excel文件
             WritableSheet ws = wwb.createSheet("statistics", 0); //第二步,在webbook中添加一個sheet,對應(yīng)Excel文件中的sheet
                 for (int i = 0; i < titleList.size(); i++) {
              String title = (String) titleList.get(i);
              Label titleLabel = new Label(i+1, 0, title);//從第二列   第一行 開始
              ws.addCell(titleLabel);
             }
             for (int i = 0; i < dataList.size(); i++) {
              Map  obj= (HashMap) dataList.get(i);
              String areaName = (String) obj.get("時間");//價格
              Label areaNameLabel = new Label(0, i+1, areaName);
              ws.addCell(areaNameLabel);//第一行的值
              for (int k = 0; k < str.length; k++) {
               if(db != null&& db.trim().equals("0")&&i>2){
                Label label = new Label(1+(k*3), i + 1, "xxx");
                ws.addCell(label);
                   label = new Label(2+(k*3), i + 1, "xxx");
                ws.addCell(label);
                label = new Label(3+(k*3), i + 1, "xxx");
                ws.addCell(label); 
               }else{
               String number = (String) obj.get(str[k][0] + "n");//數(shù)量
                     String sum = (String) obj.get(str[k][0] + "s");//金額
                     String cif = (String) obj.get(str[k][0] + "c");//價格
                Label label = new Label(1+(k*3), i + 1, number==null?"0":number);
               ws.addCell(label);
                  label = new Label(2+(k*3), i + 1, sum==null?"0":sum);
               ws.addCell(label);
               label = new Label(3+(k*3), i + 1, cif==null?"0":cif);
               ws.addCell(label);
               }
                  }
             }
             wwb.write();
            } catch (Exception ex) {
             ex.printStackTrace();
            } finally {
             try {
              wwb.close();
              os.close();
             } catch (Exception e) {
              e.printStackTrace();
             }
            }
          try {
              response.setHeader("Content-Disposition", "attachment;filename="
               + filename);
             response.setContentType("application/vnd.ms-excel");
             BufferedOutputStream out = new BufferedOutputStream(
               new DataOutputStream(response.getOutputStream()));
             BufferedInputStream in = new BufferedInputStream(
               new FileInputStream(sfile));
             byte[] b = new byte[in.available()];
             in.read(b);
             out.write(b);
             out.close();
             in.close();
             } catch (IOException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
            }


          }

          posted @ 2011-12-30 13:45 wyx 閱讀(178) | 評論 (0)編輯 收藏

          JSP下載txt 和 Excel兩種文件

          jsp 下載txt文件和excel文件

          最近做了個用jsp下載的頁面 將代碼貼出來 權(quán)作記錄吧

          1 下載txt文件 

          這個花了我不少時間 原因是用ie下載txt文件時是在頁面中直接打開了文件.雖然查了一些資料,也看了別人的解決方案,可還是解決不了問題,最后發(fā)現(xiàn)是一個字母惹的禍:少寫一個字母 嘿嘿 夠馬虎!!!

          代碼如下:

          OutputStream o=response.getOutputStream();
             byte b[]=new byte[500];
             File fileLoad=new File("e:/test.txt");
              response.setContentType("application/octet-stream");

             response.setHeader("content-disposition","attachment; filename=text.txt");
             long fileLength=fileLoad.length();
             String length1=String.valueOf(fileLength);
             response.setHeader("Content_Length",length1);
             FileInputStream in=new FileInputStream(fileLoad);
             int n;
             while((n=in.read(b))!=-1){
              o.write(b,0,n);
             }
            
             in.close();
             out.clear();
             out = pageContext.pushBody();

          2 下載excel文件 

          跟下載txt文件時的唯一區(qū)別是ContentType值的設(shè)置不同:

          OutputStream o=response.getOutputStream();
             byte b[]=new byte[500];
             File fileLoad=new File("e:/text.xls");
             response.reset();
            

              response.setContentType("application/vnd.ms-excel");

             response.setHeader("content-disposition","attachment; filename=text.xls");
             long fileLength=fileLoad.length();
             String length1=String.valueOf(fileLength);
             response.setHeader("Content_Length",length1);
             FileInputStream in=new FileInputStream(fileLoad);
             int n;
             while((n=in.read(b))!=-1){
              o.write(b,0,n);
             }
            
             in.close();
             out.clear();
             out = pageContext.pushBody();

           

           

          這兩個本來是放在一起的,因為我的頁面中需要判斷是下載的txt文件還是xls文件  在這里給分開了 需要注意的是,最后兩句一定要加上,否則會出現(xiàn)getOutputStream()錯誤的!!!!

           

           

           

           

           

           

           

           

          實例:

          <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
          <%
          String path = request.getContextPath();
          String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
          %>
          <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
          <html>
          <head>
              <base href="<%=basePath%>">
              <title>My JSP 'index.jsp' starting page</title>
              <script type="text/javascript">
                 function download(filename){
                   var url = encodeURI("down2.jsp?filename="+filename);
                   window.location.href= url;
                 }
              </script>
          </head>

          <body>
          普通測試:
          <a href="javascript:void(0)" onclick="download('a.txt');">Down a.txt</a>  
          中文文件名測試:
          <a href="javascript:void(0)" onclick="download('中文.txt');">Down 中文.txt</a>  
          普通轉(zhuǎn)向:
          <a href="a.txt">down.txt</a>  
          </body>
          </html>

           

          down2.jsp:
          <%@ page language="java" import="java.util.*,java.io.* " pageEncoding="UTF-8"%>
          <%
          request.setCharacterEncoding("utf-8");
          String filename = request.getParameter("filename");
          filename = new String(filename.getBytes("ISO-8859-1"),"UTF-8");
          System.out.println(filename);
          OutputStream o=response.getOutputStream();
          byte b[]=new byte[500];
          /** * 得到文件的當(dāng)前路徑 * @param args */
          String   serverpath=request.getRealPath("\\");
          File fileLoad=new File(serverpath+filename);
          response.setContentType("application/octet-stream");
          response.setHeader("content-disposition","attachment; filename="+filename);
          long fileLength=fileLoad.length();
          String length1=String.valueOf(fileLength);
          response.setHeader("Content_Length",length1);
          FileInputStream in=new FileInputStream(fileLoad);
          int n;
          while((n=in.read(b))!=-1){
             o.write(b,0,n);
          }
          in.close();
          out.clear();
          out = pageContext.pushBody();
          %>

          posted @ 2011-12-21 10:53 wyx 閱讀(4835) | 評論 (0)編輯 收藏

          JS導(dǎo)出Excel

           JS導(dǎo)出EXCEL的兩種方法

          function method1(tableid) {//整個表格拷貝到EXCEL中
              var curTbl = document.getElementById(tableid);
              var oXL = new ActiveXObject("Excel.Application");
              //創(chuàng)建AX對象excel
              var oWB = oXL.Workbooks.Add();
              //獲取workbook對象
                  var oSheet = oWB.ActiveSheet;
              //激活當(dāng)前sheet
              var sel = document.body.createTextRange();
              sel.moveToElementText(curTbl);
              //把表格中的內(nèi)容移到TextRange中
              sel.select();
              //全選TextRange中內(nèi)容
              sel.execCommand("Copy");
              //復(fù)制TextRange中內(nèi)容
              oSheet.Paste();
              //粘貼到活動的EXCEL中      
              oXL.Visible = true;
              //設(shè)置excel可見屬性
          }
          function method2(tableid) //讀取表格中每個單元到EXCEL中
          {
              var curTbl = document.getElementById(tableid);
               var oXL = new ActiveXObject("Excel.Application");
               //創(chuàng)建AX對象excel
               var oWB = oXL.Workbooks.Add();
               //獲取workbook對象
              var oSheet = oWB.ActiveSheet;
              //激活當(dāng)前sheet
               var Lenr = curTbl.rows.length;
               //取得表格行數(shù)
               for (i = 0; i < Lenr; i++)
               {
                   var Lenc = curTbl.rows(i).cells.length;
                   //取得每行的列數(shù)
                   for (j = 0; j < Lenc; j++)
                   {
                       oSheet.Cells(i + 1, j + 1).value = curTbl.rows(i).cells(j).innerText;
                       //賦值
                   }
               }
               oXL.Visible = true;
               //設(shè)置excel可見屬性
          }

           

          <input type="button" onclick="javascript:method1('TableExcel');" value="第一種方法導(dǎo)入到EXCEL">
          <input type="button" onclick="javascript:method2('TableExcel');" value="第二種方法導(dǎo)入到EXCEL">

           

          posted @ 2011-12-20 11:27 wyx 閱讀(4791) | 評論 (2)編輯 收藏

          主站蜘蛛池模板: 白玉县| 阿克| 曲麻莱县| 界首市| 临清市| 临潭县| 隆化县| 永顺县| 沐川县| 鲁甸县| 青川县| 吴桥县| 乌拉特中旗| 尼木县| 苍梧县| 尚义县| 平昌县| 宜春市| 文成县| 永修县| 新绛县| 轮台县| 金阳县| 隆回县| 灌云县| 奇台县| 鸡东县| 余庆县| 化德县| 荣成市| 新和县| 会东县| 五原县| 桂东县| 错那县| 汤原县| 平潭县| 漯河市| 修武县| 盐边县| 腾冲县|