MySQL安裝是出現could not start the service mysql error:0 提示錯誤,解決方法:
          首先,在管理工具->服務里面將MySQL的服務給停止,然后打開cmd 進入你的MySQL bin目錄下,例如 C:\Program Files\MySQL\MySQL Server 5.0\bin 然后使用如下命令mysqld-nt -remove 然后就會顯示......success! 好了下面進入添加刪除程序,找到MySQL選擇卸載,記得選擇remove。最后將MySQL目錄刪除,還有數據庫的目錄也刪除。  然后再重新安裝下就可以了~!~  嘿嘿
          posted @ 2009-05-13 23:47 胡鵬 閱讀(829) | 評論 (1)編輯 收藏
                 首先訪問qq.mail.com 這個url分析html代碼,發現,里面有很多加密的js,而且配合httpwatch工具發現,哇,靠,這個太復雜了。
          如果簡單的使用java模擬瀏覽器 訪問qq mail服務器獲取 好友列表,實在是太困難了,個人能力有限實現不了,想了其他辦法,創建了
          web項目,分析不了騰訊是怎么加密,但我可以作為一種代理,如圖:

             要采用上面的方式來獲取好友,大致可以分為一下幾個步驟:
          1.首先制作一個login.jsp頁面,代碼直接從騰訊郵件的登陸頁面中復制過來,把頁面交互的改成我們自己的服務器.
              (1)獲取驗證碼的地址:http://ptlogin2.qq.com/getimage?aid=23000101 后面帶個隨機數,為了防止瀏覽器緩存。
              (2)當用戶輸入用戶名 密碼 和驗證碼,點登陸的時候,也讓用戶提交到我們的服務器來。
          2. 我這里寫了一個servlet,該類是從qq郵件服務器中獲取驗證碼的,如何獲取呢?我采用的是
          httpclient4.0-beta2 包,該包是apache的 Apache HttpComponents project,是個開源的,具體使用和了解可以訪問:
          http://hc.apache.org/httpcomponents-client/index.html,(該項目功能很強大)
                在獲取了驗證碼之后,qq服務器他在cookie中寫了一個verifysession,當你點登陸的時候
          客戶端校驗需要。
          3. 把客戶端提交過來的信息我們去請求qq服務器,這樣就會登陸成功了,服務器會返回帶sid的html代碼,解析出來sid的值
          然后訪問http://m11.mail.qq.com/cgi-bin/addr_listall?sid=" +sid+"&sorttype=null&category=common,就獲取到qq中好友分組,以及每一個組的鏈接地址
          4.請求每一個鏈接  就可以得到每一組的好友了

                   上面我只是寫了實現的思路,有興趣的可以跟我聯系,具體代碼可以分享 給大家 。。。  qq:253041869
          posted @ 2009-05-07 17:54 胡鵬 閱讀(4139) | 評論 (23)編輯 收藏
          目前最高版本:   http://downloads.sourceforge.net/opencsv/opencsv-1.8-src-with-libs.tar.gz        
            開源的opencsv, 用來操作csv,這個還是不錯的。   要看介紹還是去看官方的文檔吧,下了,感覺還不錯的~  一些使用的東東上面說的很清楚,我也懶的復制了,這個給自己標注下吧。。 hoho
          posted @ 2009-05-04 20:04 胡鵬 閱讀(685) | 評論 (0)編輯 收藏
                  有時候要獲取其他網站的代碼來實現模擬登陸,下面使用servlet來實現:程序代碼如下:


          String urlStr = "http://xxx.xxx.xx.xx";
                   URL url 
          = new URL(urlStr);
                   URLConnection conn 
          = url.openConnection();
                    conn.connect();          
                    InputStream is 
          = conn.getInputStream();
                    
                  
          //得到輸入的編碼器,將文件流進行jpg格式編碼
                      JPEGImageDecoder decoder = JPEGCodec.createJPEGDecoder(is);
                   
          //得到編碼后的圖片對象
                   BufferedImage image = decoder.decodeAsBufferedImage();
                   
          //得到輸出的編碼器
                    OutputStream output = response.getOutputStream();
                    JPEGImageEncoder encoder 
          = JPEGCodec.createJPEGEncoder(output);
                    encoder.encode(image);
          //對圖片進行輸出編碼
                    is.close();//關閉文件流
                    output.close();
            比較簡單。。。。。hoho
          posted @ 2009-04-23 20:38 胡鵬 閱讀(387) | 評論 (0)編輯 收藏
              只是了解個大概,具體細節上不太清楚,這篇文章不錯,基本上都講清楚了。。。 嘿嘿,學習下。。。                                      相信大家對 String 和 StringBuffer 的區別也已經很了解了,但是估計還是會有很多同志對這兩個類的工作原理有些不清楚的地方,今天我在這里重新把這個概念給大家復習一下,順便牽出 J2SE 5.0 里面帶來的一個新的字符操作的類—— StringBuilder (先別忙著扔我磚頭,我還算清醒,我這里說的不是 C #, Java 也有 StringBuilder 類)。那么這個 StringBuilderStringBuffer 以及我們最早遇見的 String 類有那些區別呢?在不同的場合下我們應該用哪個呢?我講講自己對這幾個類的一點看法,也希望大家提出意見,每個人都有錯的地方,在錯了改的同時更是一個學習的好機會。

              簡要的說, String 類型和 StringBuffer 類型的主要性能區別其實在于 String 是不可變的對象(為什么?問問 Java 的設計者吧,為什么 String 不是原生類型呢?)因此在每次對 String 類型進行改變的時候其實都等同于生成了一個新的 String 對象,然后將指針指向新的 String 對象,所以經常改變內容的字符串最好不要用 String ,因為每次生成對象都會對系統性能產生影響,特別當內存中無引用對象多了以后, JVM 的 GC 就會開始工作,那速度是一定會相當慢的。這里嘗試舉個不是很恰當的例子:

          String S1 = “abc”;
          For(int I = 0 ; I < 10000 ; I ++) // For 模擬程序的多次調用
          {
          S1 + = “def”;
          S1 = “abc”;
          }

              如果是這樣的話,到這個 for 循環完畢后,如果內存中的對象沒有被 GC 清理掉的話,內存中一共有 2 萬多個了,驚人的數目,而如果這是一個很多人使用的系統,這樣的數目就不算很多了,所以大家使用的時候一定要小心。

              而如果是使用 StringBuffer 類則結果就不一樣了,每次結果都會對 StringBuffer 對象本身進行操作,而不是生成新的對象,再改變對象引用。所以在一般情況下我們推薦使用 StringBuffer ,特別是字符串對象經常改變的情況下。而在某些特別情況下, String 對象的字符串拼接其實是被 JVM 解釋成了 StringBuffer 對象的拼接,所以這些時候 String 對象的速度并不會比 StringBuffer 對象慢,而特別是以下的字符串對象生成中, String 效率是遠要比 StringBuffer 快的:

          String S1 = “This is only a” + “ simple” + “ test”;
          StringBuffer Sb = new StringBuilder(“This is only a”).append(“ simple”).append(“ test”);

              你會很驚訝的發現,生成 String S1 對象的速度簡直太快了,而這個時候 StringBuffer 居然速度上根本一點都不占優勢。其實這是 JVM 的一個把戲,在 JVM 眼里,這個

          String S1 = “This is only a” + “ simple” + “test”; 其實就是: String S1 = “This is only a simple test”; 所以當然不需要太多的時間了。但大家這里要注意的是,如果你的字符串是來自另外的 String 對象的話,速度就沒那么快了,譬如:

          String S2 = “This is only a”;
          String S3 = “ simple”;
          String S4 = “ test”;
          String S1 = S2 +S3 + S4;

              這時候 JVM 會規規矩矩的按照原來的方式去做, S1 對象的生成速度就不像剛才那么快了,一會兒我們可以來個測試作個驗證。

              由此我們得到第一步結論: 在大部分情況下 StringBuffer > String

              而 StringBuilder 跟他們比又怎么樣呢?先簡單介紹一下, StringBuilder 是 JDK5.0 中新增加的一個類,它跟 StringBuffer 的區別看下面的介紹(來源 JavaWorld ):

              Java.lang.StringBuffer 線程安全的可變字符序列。類似于 String 的字符串緩沖區,但不能修改。可將字符串緩沖區安全地用于多個線程??梢栽诒匾獣r對這些方法進行同步,因此任意特定實例上的所有操作就好像是以串行順序發生的,該順序與所涉及的每個線程進行的方法調用順序一致。

              每個字符串緩沖區都有一定的容量。只要字符串緩沖區所包含的字符序列的長度沒有超出此容量,就無需分配新的內部緩沖區數組。如果內部緩沖區溢出,則此容量自動增大。從 JDK 5.0 開始,為該類增添了一個單個線程使用的等價類,即 StringBuilder 。與該類相比,通常應該優先使用 StringBuilder 類,因為它支持所有相同的操作,但由于它不執行同步,所以速度更快。

              但是如果將 StringBuilder 的實例用于多個線程是不安全的。需要這樣的同步,則建議使用 StringBuffer 。

              這樣說估計大家都能明白他們之間的區別了,那么下面我們再做一個一般性推導:

              在大部分情況下 StringBuilder > StringBuffer

              因此,根據這個不等式的傳遞定理: 在大部分情況下 StringBuilder > StringBuffer > String

              既然有這樣的推導結果了,我們做個測試驗證一下:

              測試代碼如下:

          public class testssb {

          /** Creates a new instance of testssb */
          final static int ttime = 10000;// 測試循環次數
          public testssb() {
          }

          public void test(String s){
          long begin = System.currentTimeMillis();
          for(int i=0;i<ttime;i++){
          s += "add";
          }
          long over = System.currentTimeMillis();
          System.out.println(" 操作 "+s.getClass().getName()+" 類型使用的時間為: " + (over - begin) + " 毫秒 " );
          }

          public void test(StringBuffer s){
          long begin = System.currentTimeMillis();
          for(int i=0;i<ttime;i++){
          s.append("add");
          }
          long over = System.currentTimeMillis();
          System.out.println(" 操作 "+s.getClass().getName()+" 類型使用的時間為: " + (over - begin) + " 毫秒 " );
          }

          public void test(StringBuilder s){
          long begin = System.currentTimeMillis();
          for(int i=0;i<ttime;i++){
          s.append("add");
          }
          long over = System.currentTimeMillis();
          System.out.println(" 操作 "+s.getClass().getName()+" 類型使用的時間為: " + (over - begin) + " 毫秒 " );
          }

          // 對 String 直接進行字符串拼接的測試
          public void test2(){
          String s2 = "abadf";
          long begin = System.currentTimeMillis();
          for(int i=0;i<ttime;i++){
          String s = s2 + s2 + s2 ;
          }
          long over = System.currentTimeMillis();
          System.out.println(" 操作字符串對象引用相加類型使用的時間為: " + (over - begin) + " 毫秒 " );
          }

          public void test3(){
          long begin = System.currentTimeMillis();
          for(int i=0;i<ttime;i++){
          String s = "abadf" + "abadf" + "abadf" ;
          }
          long over = System.currentTimeMillis();
          System.out.println(" 操作字符串相加使用的時間為: "+ (over - begin) + " 毫秒 " );
          }

          public static void main(String[] args){
          String s1 ="abc";
          StringBuffer sb1 = new StringBuffer("abc");
          StringBuilder sb2 = new StringBuilder("abc");

          testssb t = new testssb();
          t.test(s1);
          t.test(sb1);
          t.test(sb2);
          t.test2();
          t.test3();
          }
          }

              以上代碼在 NetBeans 5.0 IDE/JDK1.6 上編譯通過,循環次數 ttime 為 10000 次的測試結果如下:
          操作 java.lang.String 類型使用的時間為: 4392 毫秒
          操作 java.lang.StringBuffer 類型使用的時間為: 0 毫秒
          操作 java.lang.StringBuilder 類型使用的時間為: 0 毫秒
          操作字符串對象引用相加類型使用的時間為: 15 毫秒
          操作字符串相加使用的時間為: 0 毫秒

              好像還看不出 StringBufferStringBuilder 的區別,把 ttime 加到 30000 次看看:
          操作 java.lang.String 類型使用的時間為: 53444 毫秒
          操作 java.lang.StringBuffer 類型使用的時間為: 15 毫秒
          操作 java.lang.StringBuilder 類型使用的時間為: 15 毫秒
          操作字符串對象引用相加類型使用的時間為: 31 毫秒
          操作字符串相加使用的時間為: 0 毫秒

              StringBufferStringBuilder 的性能上還是沒有太大的差異,再加大到 100000 看看,這里就不加入對 String 類型的測試了,因為對 String 類型這么大數據量的測試會很慢滴……
          操作 java.lang.StringBuffer 類型使用的時間為: 31 毫秒
          操作 java.lang.StringBuilder 類型使用的時間為: 16 毫秒

              能看出差別了,但其中有多次的測試結果居然是 StringBufferStringBuilder 快,再加大一些到 1000000 看看(應該不會當機吧?):
          操作 java.lang.StringBuffer 類型使用的時間為: 265 毫秒
          操作 java.lang.StringBuilder 類型使用的時間為: 219 毫秒

              有些少區別了,而且結果很穩定,再大點看看, ttime = 5000000 :

          ······ Exception in thread "main" java.lang.OutOfMemoryError: Java heap space ······

              呵呵,算了,不去測試了,基本來說都是在性能上都是 StringBuilder > StringBuffer > String 的了。 
          posted @ 2009-04-22 20:31 胡鵬 閱讀(2328) | 評論 (0)編輯 收藏
          如下程序會輸出什么?
          public class Creator {
          public static void main(String[] args) {
          for(int i=0;i<100;i++)
          Creature creature
          = new Creature();

          System.out.println(Creature.numCreated());
          }
          }

          class Creature{
          private static long numCreated = 0;

          public Creature(){
          numCreated
          ++;
          }

          public static long numCreated(){
          return numCreated;
          }
          }
          編譯的時候發現:上面的程序在Creature creature = new Creature(); 發現語法錯誤,這個為什么呢???,覺得很奇怪啊,
          原來java語言規范不允許一個額本地變量聲明語句作為一條語句在for,while,或do循環中重復執行。 一個本地變量聲明作為一條語句只能直接出現在一個語句塊中。
          針對上面的程序:可以有幾種方式來修改,Creature creature = new Creature();改成 new Creature(); 也可以改成
          {
          Creature creature
          = new Creature();
          }
          等等。。。。。。。。。。。。。。。。。。。。。

          posted @ 2009-04-19 15:05 胡鵬 閱讀(191) | 評論 (0)編輯 收藏
            簡單的hello world hoho:
          public class Null {
              
          public static void greet(){
                  System.out.println(
          "hello world!");
              }
              
          public static void main(String[] args) {
                  ((Null)
          null).greet();
              }
          }
          程序運行結果: hello world! 
          posted @ 2009-04-19 11:22 胡鵬 閱讀(195) | 評論 (0)編輯 收藏
          在網頁中嵌入 media play的代碼,比較簡單實現 hoho,希望大家有用哇。。
          <object align=middle classid=CLSID:22d6f312-b0f6-11d0-94ab-0080c74c7e95 class=OBJECT

          id=MediaPlayer width=360 height=70 >
          <param name=ShowStatusBar value=-1><param name=Filename

          value=http://008.org.cn/mp3/rosebush/2.mp3>
          <embed type=application/x-oleobject

          codebase=http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701

          flename=mp src=http://008.org.cn/mp3/rosebush/2.mp3 width=360 height=70></embed></object>
          在網頁中嵌入 real play 的代碼:
          htmlavi
          <OBJECT height=300 width=500 classid=clsid:CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA><PARAM NAME="_ExtentX" VALUE="13229"><PARAM NAME="_ExtentY" VALUE="7938"><PARAM NAME="AUTOSTART" VALUE="-1"><PARAM NAME="SHUFFLE" VALUE="0"><PARAM NAME="PREFETCH" VALUE="0"><PARAM NAME="NOLABELS" VALUE="0"><PARAM NAME="SRC" VALUE="http://192.168.2.56:8085/pmi/resupload/00000000000000000042/100001/1087890034804_1.rm"><PARAM NAME="CONTROLS" VALUE="ImageWindow"><PARAM NAME="CONSOLE" VALUE="Clip1"><PARAM NAME="LOOP" VALUE="0"><PARAM NAME="NUMLOOP" VALUE="0"><PARAM NAME="CENTER" VALUE="0"><PARAM NAME="MAINTAINASPECT" VALUE="0"><PARAM NAME="BACKGROUNDCOLOR" VALUE="#000000"></OBJECT><BR>
          <OBJECT height=30 width=500 classid=clsid:CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA><PARAM NAME="_ExtentX" VALUE="13229"><PARAM NAME="_ExtentY" VALUE="794"><PARAM NAME="AUTOSTART" VALUE="0"><PARAM NAME="SHUFFLE" VALUE="0"><PARAM NAME="PREFETCH" VALUE="0"><PARAM NAME="NOLABELS" VALUE="0"><PARAM NAME="CONTROLS" VALUE="ControlPanel"><PARAM NAME="CONSOLE" VALUE="Clip1"><PARAM NAME="LOOP" VALUE="0"><PARAM NAME="NUMLOOP" VALUE="0"><PARAM NAME="CENTER" VALUE="0"><PARAM NAME="MAINTAINASPECT" VALUE="0"><PARAM NAME="BACKGROUNDCOLOR" VALUE="#000000"></OBJECT>
          posted @ 2009-04-16 20:34 胡鵬 閱讀(12917) | 評論 (0)編輯 收藏
             把當前網頁中的代碼導入到word中,會啟動本地word,,, 還是不錯的,而且代碼量很少。 嘿嘿
          <html>
          <head>
          <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
          <title>網頁上內容導出到word</title>
          </head>
          <body>
          <div id="Layer1" >Happy New Year ! ! !
          <input type=button name='button_export' title='導出到word'  onclick=OpenWord() value=下載到word></div>
          </div>
          <input type='button' value='fullscreen' onClick="window.open('c:\\a.html','fullscreen','fullscreen,scrollbars');">

          <input name="but1" type="button" onClick="window.open('b.html');" value="b.html">
          <iframe name="iframe2" src=""></iframe>

          <p>this is a test!</p>
          <table align="center" width="300" border="1" bordercolor="#2baeff" cellpadding="0" cellspacing="0" bgcolor="lightblue">
          <Tr><Td>1</td><Td>2</td><Td>3</td></tr>
          <Tr><Td>4</td><Td>5</td><Td>6</td></tr>
          <Tr><Td>7</td><Td>8</td><Td>9</td></tr>
          </table>

          <input type="checkbox" id="chk">chkTest<br><br>
          <input type="button" name="testOpen" value="openWindow" onClick="var newWindow = window.open('a.html');newWindow.document.all('chk').checked = true;">
          </body>
          </html>
          <script language="javascript">
          function OpenWord(){
          Layer1.style.border
          =0
          ExcelSheet 
          = new ActiveXObject('Word.Application');
          ExcelSheet.Application.Visible 
          = true;
          var mydoc=ExcelSheet.Documents.Add('',0,1);
          myRange 
          =mydoc.Range(0,1)
          var sel=Layer1.document.body.createTextRange()
          sel.select()
          Layer1.document.execCommand('Copy')
          sel.moveEnd('character')
          myRange.Paste();
          location.reload()
          ExcelSheet.ActiveWindow.ActivePane.View.Type
          =9
          }
          </script>
          posted @ 2009-04-16 20:32 胡鵬 閱讀(1390) | 評論 (0)編輯 收藏
               一個項目中在寫ibatis中的sql語句時,where user_id in (#user_id_list# ), 運行時總是不行,后來上網查了查,才知道這里不該用#,而應該用$,隨即查了下#與$的區別. 
          總結如下: 
          1.#是把傳入的數據當作字符串,如#user_id_list#傳入的是1,2,則sql語句生成是這樣,in ('1,2') ,當然不可以

          2.$傳入的數據直接生成在sql里,如#user_id_list#傳入的是1,2,則sql語句生成是這樣,in(1,2) 這就對了. 

          3.#方式能夠很大程度防止sql注入. 

          4.$方式無法方式sql注入. 

          5.$方式一般用于傳入數據庫對象.例如傳入表名. 

          6.一般能用#的就別用$. 
          直觀的說 
          #str# 出來的效果是  'str' 
          $str$ 出來的效果是  str 

          另外  ##只能用在特定的幾個地方 $$可以用在任何地方  比如 order by $str$ 

          你甚至可以直接寫  $str$  把 order by 這個字串放在str里傳進來 
          今天花了N久,才把這個問題搞出來,郁悶下,不過出來了也挺開心的,終于搞定啦,嘿嘿~!~   
          posted @ 2009-04-16 20:13 胡鵬 閱讀(3027) | 評論 (0)編輯 收藏
          僅列出標題
          共10頁: First 上一頁 2 3 4 5 6 7 8 9 10 下一頁 

          導航

          <2025年5月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          統計

          常用鏈接

          留言簿(3)

          隨筆分類

          隨筆檔案

          agile

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 西畴县| 化隆| 伊金霍洛旗| 定日县| 乐平市| 青阳县| 昌乐县| 新余市| 延吉市| 胶州市| 开封县| 漳浦县| 河津市| 太保市| 衡阳县| 永州市| 新巴尔虎左旗| 黄冈市| 临汾市| 英山县| 和静县| 北票市| 平顶山市| 吴忠市| 东丰县| 伊春市| 郴州市| 汶川县| 安顺市| 三原县| 青河县| 民丰县| 平利县| 彰化市| 景洪市| 桂东县| 武川县| 佳木斯市| 徐汇区| 高清| 景洪市|