<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Dedian  
    -- 關(guān)注搜索引擎的開發(fā)
    日歷
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567
    統(tǒng)計
    • 隨筆 - 82
    • 文章 - 2
    • 評論 - 228
    • 引用 - 0

    導航

    常用鏈接

    留言簿(8)

    隨筆分類(45)

    隨筆檔案(82)

    文章檔案(2)

    Java Spaces

    搜索

    •  

    積分與排名

    • 積分 - 65497
    • 排名 - 816

    最新評論

    閱讀排行榜

    評論排行榜

     

    2009年5月29日

    微軟從未放棄搜索引擎的競爭,一直和Google暗暗較勁。盡管live search在內(nèi)部員工里像是一個joke,但老大一直毫不猶豫地往里砸錢。

    說 實話,我盡量使用微軟的產(chǎn)品,操作系統(tǒng)放棄了linux,開發(fā)工具放棄了perl和java,當然這些是工作使然。但map我以前用 MapQuest,現(xiàn)在改用live map,瀏覽器也棄Firefox改用IE8,但凡能用的,我都會改用微軟的產(chǎn)品,不過對于搜索引擎,感覺實在太爛了,搜出來的東西總不是自己想要的,往 后翻了10來頁也不見有用的。后來就偷偷把Google設為默認引擎。見到一個同事比我更過分,連outlook的搜索都改用Google Desktop來搜索。

    后來,3月初的時候,內(nèi)部就發(fā)布了一個新的搜索引擎,叫Kumo(酷摸?)。據(jù)說是因為live這個名字不好,不 信把它反過來念念看看是什么?我覺得只是一個名字的更換沒有什么意義。后來還是忍不住上去試了試,發(fā)現(xiàn)確實比原來的那個好一些。沒事的時候也會用Kumo 摸一把。

    今天,鮑老大又宣布發(fā)布一個新的搜索引擎,叫Bing。感覺怎樣?我怎么讀的像有病的‘病’?還不叫Search Engine,改叫Decision Engine,夠新潮的概念。我不太清楚為什么取這樣一個名字(據(jù)鮑老大說,是因為它短小好記),不過從一個日文名字變成一個中文名字,我感覺這是陸奇上臺登 上Search老大交椅之后的一個成功。記得前兩天Search主頁的封面就開始用上內(nèi)部某員工拍的中國陽朔的風景照片。不管猜測對不對,新的搜索引擎還 是要試一試,結(jié)果有好事之徒一上來就搜了個“六四”,結(jié)果出來的全是大學四六級考試,讓人有些瀑布寒。還沒有公開release,公關(guān)就已經(jīng)做得這么好 了。

    讓人更囧的是,為慶祝新的release,search組的人每人發(fā)了一件T-shirt。據(jù)說前面是"I Bing",后面是“U Bing”。聽起來像“我有病,你也有病”。不過Search組的人并以為然,因為他們?yōu)?#8220;Bing”取了一個中文名字叫“必應”。比“谷歌”好一點么?

    其他組的好事之徒可沒那么友好,測試了一段時間之后,把這個“bing”的搜索引擎親切地叫做Mr. Bean。

    當然,面對新鮮事物,我們還應該抱著積極的態(tài)度。我想因為在測試階段,我更愿意相信這是因為沒有足夠的用戶行為數(shù)據(jù)導致的短暫的發(fā)育不良。這個“必應”在下周可能就會正式發(fā)布了。讓我們試目以待。
    posted @ 2009-05-29 13:20 Dedian 閱讀(3634) | 評論 (14)編輯 收藏

    2007年5月31日



    先前有說過,“很 多的軟件做成web-based是web3.0的一個趨勢”。從技術(shù)角度上說,這些web-based的應用程序和以前裝在本地硬盤的軟件有些不一樣,確 切地可以理解那些具有服務功能的網(wǎng)站或者應用程序為能夠瀏覽器所容納的對象,而瀏覽器只是一個可以支持多種對象的容器,可對象的后臺的服務應用程序正是 deploy在各種web服務器上的軟件。

    而那些所謂的腳本語言只是容器與各種對象的通訊語言。

    一直以來,容器和后臺服務應用程序一直在改進。但更多的是一個又一個鮮活的對象通過瀏覽器展現(xiàn)在我們眼前,默默地改變我們的生活。

    其 實,說很多的軟件做成web-based就是變成一個個可以為瀏覽器所接納的對象模型只概括了其中的一部分。它只是說到軟件的表現(xiàn)形式。這很容易讓大家忽 略數(shù)據(jù)的存儲形式,而默認這樣的web-based的服務讓我們更多的是享受網(wǎng)絡上的數(shù)據(jù)或者搜索引擎上的數(shù)據(jù)。我們不用經(jīng)常下載軟件占據(jù)自己的硬盤,有 了網(wǎng)絡電視,我們也不用下載電影,甚至也無需下載音樂。我們自己的數(shù)據(jù)比如email,blog,訂閱的雜志,收藏的信息也都存放在各個網(wǎng)站的服務器上, 而無需下載下來。

    我們似乎已經(jīng)習慣了在線的狀態(tài)。淡忘了脫機的那個年代。而一向標新立異的Google似乎又找到回歸的需求,那就是最近推出的的Google Gears。它提供人們一個瀏覽器的插件,通過這個插件我們下載數(shù)據(jù)到本地硬盤,并且提供一個小型數(shù)據(jù)庫引擎(SQLite)在本地硬盤幫助存儲,建立索引和搜索數(shù)據(jù)。另外提供接口實現(xiàn)后臺的數(shù)據(jù)同步而無需占用瀏覽器資源。

    目前Google Gears的API應用在Google Reader上,即用戶可以下載訂閱的電子雜志到本地硬盤,方便整理和收藏。

    一句話,軟件有放在網(wǎng)上的趨勢,人們也同樣關(guān)注個人數(shù)據(jù)的搜集和存放。舉個例子,我一直用Del.icio.us來收藏一些技術(shù)網(wǎng)站或者文章,可有一天我查閱技術(shù)文章的時候,點擊鏈接過去,卻是物是人非頁已去。這時我就想當時文章要是可以自動下載到自己硬盤并整理好那該多好。當然,手工的Copy+Paste就算了,我希望的是像Del.icio.us的一鍵操作。

    posted @ 2007-05-31 14:27 Dedian 閱讀(1924) | 評論 (1)編輯 收藏

    2007年2月2日

    Got a question, when I apply sort command line in linux to sort some domain names by dictionary order, no matter which option i used, it will sort some domains like this:

    ...
    abca.com
    abc-d.com
    abce.com
    ...

    I am curious what comparison function it applys in its' sorting function. I supposed it should be a string comparison, like strcmp function, but it is not. coz strcmp will compare ascii code of characters in string one by one, thus above sorting should like this:

    abc-d.com
    abca.com
    abce.com

    one guess is that when sorting names the special characters like "." "-" will be skipped. but still got some problem when sorting following names:

    abc---d.com
    abc--d.com
    abc-d.com

    why can linux sorting keep this order? if it skips some special characters, above names should be compared equally and maybe sorted as a random order.

    confused, anybody has thought about that?

    -----
    p.s.

    Haven't got updated here for quite a long time, coz I am back to program with c under linux and I believe it is a place for Java programmers.

    -----

    update:

    Linux sorting compares unicode of strings … more about unicode is here




    posted @ 2007-02-02 07:10 Dedian 閱讀(1417) | 評論 (1)編輯 收藏

    2006年10月27日


    隨著網(wǎng)絡上信息量的日益增加,人們的學習和工作越來越離不開網(wǎng)絡搜索引擎(有些生活中的小例子在《Google 今天8歲》文中有提到)。

    但是,另外一方面,我們會對搜索出來的成千上萬的結(jié)果束手無措,使得我們基本上對第一頁的搜索結(jié)果保持興趣,從而引發(fā)各種為爭取出現(xiàn)在搜索引擎的第一頁的各種技術(shù)(如SEO)或手段(Spamdexing)出現(xiàn),惡劣的則大打出手,甚至搜索引擎公司出現(xiàn)各種幕后黑手

    對于用戶來說,則需要一點智商,來迅速地達到自己的搜索目的。

    對于搜索引擎的老大Google顯然注意到這一事實以及這一事實帶來的客戶需求:即搜索引擎應該滿足客戶自定義化(Customizable).

    最近,Google推出的產(chǎn)品 custom search service 則適應了這一需要。

    idea很簡單,就是用戶可以自己根據(jù)自己的興趣所在設置一些自己經(jīng)常去的或者感興趣的又信息量比較大的一些網(wǎng)站。這樣就可以制定Google的搜索引擎就搜索這幾個網(wǎng)站,或者以這幾個網(wǎng)站的為主。

    例外,這個簡單idea的產(chǎn)品還具備web2.0的色彩。也就是可以幾個興趣相投的人一起編輯網(wǎng)站列表,從而類似一個搜索圈(搜索社區(qū))搜索出大家共同感興趣的東西。

    有興趣的大家可以自己玩玩。我初步自定義了一個與Blog有關(guān)的搜索引擎。

    點擊這里?;蛘哌B接:
    http://www.google.com/coop/cse?cx=006688650489436466578%3Ac7-4rxi0jf4

    或者點擊這個簡單的域名地址:

    http://blogdigger.info

    大家有興趣可以一起玩,只要你們有g(shù)mail的賬號。

    加入的方法很簡單,就是點擊主頁上的鏈接:
    ?
    當然,你需要一個Google 的賬號(沒有也沒有關(guān)系,只需要用你們的email注冊一個就可以了,很簡單)
    ?
    這樣,你就可以成為這個搜索引擎的一員了,平時,你覺得那個網(wǎng)站很好,里面的信息量也比較大,你可以把這個網(wǎng)站添加到Blog Digger的網(wǎng)站列表中。也可以為你感興趣的一些搜索添加搜索條目。
    ?
    如果慢慢的覺得這個自定義的Google好玩,就記住這個鏈接吧:http://blogdigger.info





    posted @ 2006-10-27 06:04 Dedian 閱讀(2392) | 評論 (3)編輯 收藏

    2006年10月21日

    Not sure if it is a bug of (Http)URLConnection, but it hang sometimes for some URLs while calling any functions to get information from connection (includes getResponseCode, getInputStream, getContent, getContentLength, getHeaderField blabla..) after connection has been built (even I have set the read timeout and connect time out).

    the functions openConnection() and connect() are ok, curious about that problem.

    anybody has the same problem or similar problem with URLConnection?
    posted @ 2006-10-21 07:20 Dedian 閱讀(1313) | 評論 (0)編輯 收藏

    2006年10月7日


    ---祝大家中秋愉快---

    Ajax (AsynchronousJavaScript and XML)是近年來流行的一門web 技術(shù)。在Blogjava上看到有人開始在介紹AJAX,但仿佛流于概念或理論的東西,對于想用Ajax的初學者似乎不是很make sense。我想,學習任何一樣新的技術(shù),例子和步驟是極為make sense的兩樣東西。

    筆者想結(jié)合過去的學習經(jīng)驗簡單講講使用Ajax的基本步驟和舉幾個實用例子。由于筆者主要在于后臺端的開發(fā),所以很多腳本并不是很擅長。Ajax也主要限于以前大學的修課和近期的一些為后臺端程序的測試的簡單實現(xiàn)。所以只是一個拋磚引玉的使用Ajax版本,歡迎相互學習交流。

    0. 導讀

    ??? 1。使用Ajax的基本流程
    ???
    2。使用Ajax的基本步驟。(簡單例子--> Demo)
    ??? 3。
    再來一個例子(Google Suggest)。(Demo)
    ??? 4。家庭作業(yè) :)


    1。使用Ajax的基本流程

    在筆者看來,Ajax更像是一個簡單的網(wǎng)絡框架,它描述著如何高效地使網(wǎng)絡前端的數(shù)據(jù)展現(xiàn)和網(wǎng)絡后端的數(shù)據(jù)之間的交互?;旧?,就是瀏覽器提供一個XMLHttpRequest(當然在IE里是ActiveXObject)的對象向后臺端的腳本程序或者Servlet Classes發(fā)送http請求,從后臺端的回應中獲取文本數(shù)據(jù)(如xml格式和最近有人討論的Json格式)并嵌入前臺段的網(wǎng)頁中或腳本中。

    下圖是一個簡單的流程圖:



    2。使用Ajax的基本步驟。

    下面,我們結(jié)合上面的流程,以及一個簡單的例子(見這篇文章)過一遍基本的步驟。(藍色代碼為標準寫法)

    第一步:Form 代碼:接受前臺端的輸入,并通過Action方法(方法函數(shù)里包含創(chuàng)建XMLHttpRequest對象)把request post到后臺端。

    <input id="username" name="username" type="text"
    ? onblur="checkName(this.value,'')" />
    <span class="hidden" id="nameCheckFailed">
    ? This name is in use, please try another.
    </span>

    <script language="javascript">
    function checkName(input, response)
    {
    ? if (response != ''){
    ??? // Response mode
    ??? message?? = document.getElementById('nameCheckFailed');
    ??? if (response == '1'){
    ????? message.className = 'error';
    ??? }else{
    ????? message.className = 'hidden';
    ??? }
    ? }else{
    ??? // Input mode
    ??? url? = 'http://localhost/xml/checkUserName.php?q=' + input;
    ??? loadXMLDoc(url);
    ? }
    }

    var req;

    function loadXMLDoc(url)
    {
    ??? // branch for native XMLHttpRequest object
    ??? if (window.XMLHttpRequest) {
    ??????? req = new XMLHttpRequest();
    ??????? req.onreadystatechange = processReqChange;
    ??????? req.open("GET", url, true);
    ??????? req.send(null);
    ??? // branch for IE/Windows ActiveX version
    ??? } else if (window.ActiveXObject) {
    ??????? req = new ActiveXObject("Microsoft.XMLHTTP");
    ??????? if (req) {
    ??????????? req.onreadystatechange = processReqChange;
    ??????????? req.open("GET", url, true);
    ??????????? req.send();
    ??????? }
    ??? }
    }
    </script>


    注:
    1。 這里的form只是一個input box,action的方法是onblur,就是響應失去焦點的事件,然后調(diào)用一個函數(shù)checkName, 這個函數(shù)里通過XMLHttpRequest向PHP server script 發(fā)送Post請求(看得出來,這里的php server script的文件名叫checkUserName.php,唯一參數(shù)是q)。
    2。函數(shù)loadXMLDoc里有個通用的創(chuàng)建XMLHttpRequest對象的代碼,標準代碼整理如下:
    ??????? var req;
    ??? ??? function foo()
    ??? ??? {
    ??? ??? ??? req = false;

    ??? ??? ??? // branch for native XMLHttpRequest object
    ??? ??? ??? if(window.XMLHttpRequest)
    ??? ??? ??? {
    ??? ??? ??? ??? try
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? req = new XMLHttpRequest();
    ??? ??? ??? ??? }
    ??? ??? ??? ??? catch(e)
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? req = false;
    ??? ??? ??? ??? }
    ??? ??? ??? }
    ??? ??? ??? else if(window.ActiveXObject) // branch for IE/Windows ActiveX version
    ??? ??? ??? {
    ??? ??? ??? ??? try
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? req = new ActiveXObject("Msxml2.XMLHTTP");
    ??? ??? ??? ??? }
    ??? ??? ??? ??? catch(e)
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? try
    ??? ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? ??? req = new ActiveXObject("Microsoft.XMLHTTP");
    ??? ??? ??? ??? ??? }
    ??? ??? ??? ??? ??? catch(e)
    ??? ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? ??? req = false;
    ??? ??? ??? ??? ??? }
    ??? ??? ??? ??? }
    ??? ??? ??? }
    ??? ??? ??? if(req)
    ??? ??? ??? {
    ??? ?? ?? ?? ?? ??
    //do something here
    ???? ??? ??? }
    ??? ??? ???

    ??? ??? }

    第二步:響應文本處理代碼:XMLHttpRequest對象里有個類似消息響應函數(shù)的屬性,即通過設置 req.onreadystatechange 來告訴XMLHttpRequest在哪個函數(shù)里處理服務端返回的文本信息。
    如在上面的例子中:
    req.onreadystatechange = processReqChange;
    那么我們接著要有一個processReqChange的函數(shù):
    function processReqChange() 
    {
    // only if req shows "complete"
    if (req.readyState == 4) {
    // only if "OK"
    if (req.status == 200)
    {
    // ...processing statements go here...
    processResponse();
    } else {
    alert("There was a problem retrieving
    the XML data:\n" + req.statusText);
    }
    }
    }


    function processResponse()
    {
    response = req.responseXML.documentElement;
    method = response.getElementsByTagName('method')[0].firstChild.data;
    result = response.getElementsByTagName('result')[0].firstChild.data;
    eval(method + '(\'\', result)');

    }
    注:
    1。 基本上processReqChange 函數(shù)是標準代碼的寫法。
    2。這里要用到前面定義的全局變量(XMLHttpRequest對象)req

    第三步:后臺端代碼(這個例子是php server script):接受前臺端的請求,處理其參數(shù),并返回相應的結(jié)果。

    文件名: checkUserName.php

    <?php
    header('Content-Type: text/xml');

    function nameInUse($q)
    {?
    ? if (isset($q)){
    ??? switch(strtolower($q))
    ??? {
    ????? case? 'drew' :
    ????????? return '1';
    ????????? break;
    ????? case? 'fred' :
    ????????? return '1';
    ????????? break;
    ????? default:
    ????????? return '0';
    ??? }
    ? }else{
    ??? return '0';
    ? }
    ?
    }
    ?>
    <?php echo '<?xml version="1.0" encoding="UTF-8"? standalone="yes"?>'; ?>
    <response>
    ? <method>checkName</method>
    ? <result><?php
    ??? echo nameInUse($_GET['q']) ?>
    ? </result>
    </response>
    注:代碼很簡單,就不用解釋了。這里返回的是xml格式的字符串。

    總體效果見這里
    輸入"fred"或者"drew"的名字,失去焦點后會顯示名字已存在的信息。


    ?3。再來一個例子。

    這里再講一個實用的例子,這是以前上課的一個課堂作業(yè),也很有代表性。是關(guān)于Google Suggest(好像新的Google Toolbar上就用的這個功能)的應用問題。這里是寫好的DEMO?,F(xiàn)在越來越多的網(wǎng)站提供類似Web Service的API, 我們利用他們提供的API URL可以返回一些我們用的著的數(shù)據(jù),放在我們的網(wǎng)頁上。這里就用的上Ajax。只不過有些返回來的文本數(shù)據(jù)是xml格式的,就可以利用上面的簡單例子來處理,但很多像Google Suggest那樣是返回一段類似代碼格式的文本。我們就要利用Javascript的eval函數(shù),把這些文本當作一段代碼在嵌入自己的網(wǎng)頁中。如果嵌入的代碼中含有函數(shù),則需要自己再寫一個同名的函數(shù)作為實現(xiàn)。(這就是流程圖中的optional的func 3)

    這里完整代碼就不貼了,貼一些關(guān)鍵代碼(原本后臺端是用Java Servlet寫的,但做demo的空間沒有Tomcat不支持Servlet,所以改用Php實現(xiàn),大家可以自己用Java再寫一邊作為家庭作業(yè) :) ):

    1) form 代碼:

    <form name = "QForm" method="POST" action="google_suggest.php">
    ??? <table bgcolor="8080C0" width="90%" >
    ??? <tr>
    ??? ??? <td? nowrap>Search Term:</td>
    ??? ??? <td ><input type="text" name="qtext"? onkeyup="return GetSuggestion()" size="60"></td>
    ??? </tr>
    ??? <tr>
    ??? ??? <th colspan="2" align="left" bgcolor="#A8A8FF"><DIV id=google_suggest_target>results go here . . . </DIV></th>
    ??? </tr>
    ??? </table>
    ??? </form>

    注:
    a. 看得出來,要把查詢的字符串post到google_suggest.php上
    b. action的函數(shù)是GetSuggestion(),其返回的字符串會顯示在預留的網(wǎng)頁空間里。

    2) 后臺端代碼(PHP):這里主要接收前臺的請求,并不請求轉(zhuǎn)化為向Google Suggest的API URL請求,把接收到的文本信息返回給前端。代碼很簡單,如下:

    文件名:google_suggest.php

    <?php
    function getGoogleSuggest($q)
    {

    ??? $url = "http://www.google.com/complete/search?hl=en&js=true&qu=" . $q;
    ??? return file_get_contents($url);
    }
    ?>

    <?php echo getGoogleSuggest($_POST['q']) ?>

    注:
    a。 Google Suggest API 返回的是一個代碼格式的文本信息,如下:
    sendRPCDone(frameElement, "", new Array(), new Array(), new Array(""));
    所以我們再前臺接受到這個文本信息之后,應該寫一個sendRPCDone的函數(shù)來做進一步信息處理(比如說列表出查詢結(jié)果)。

    3) 前臺文本處理代碼:

    ??? <script type="text/javascript">
    ??? ??? var req;
    ??? ??? function GetSuggestion()
    ??? ??? {
    ??? ??? ??? req = false;
    ??? ??? ??? var f = document.QForm;

    ??? ??? ??? // branch for native XMLHttpRequest object
    ??? ??? ??? if(window.XMLHttpRequest)
    ??? ??? ??? {
    ??? ??? ??? ??? try
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? req = new XMLHttpRequest();
    ??? ??? ??? ??? }
    ??? ??? ??? ??? catch(e)
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? req = false;
    ??? ??? ??? ??? }
    ??? ??? ??? }
    ??? ??? ??? else if(window.ActiveXObject) // branch for IE/Windows ActiveX version
    ??? ??? ??? {
    ??? ??? ??? ??? try
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? req = new ActiveXObject("Msxml2.XMLHTTP");
    ??? ??? ??? ??? }
    ??? ??? ??? ??? catch(e)
    ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? try
    ??? ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? ??? req = new ActiveXObject("Microsoft.XMLHTTP");
    ??? ??? ??? ??? ??? }
    ??? ??? ??? ??? ??? catch(e)
    ??? ??? ??? ??? ??? {
    ??? ??? ??? ??? ??? ??? req = false;
    ??? ??? ??? ??? ??? }
    ??? ??? ??? ??? }
    ??? ??? ??? }
    ??? ??? ??? if(req)
    ??? ??? ??? {
    ??? ??? ??? ??? var url = "google_suggest.php";
    ???????
    ??? ??? ??? ??? req.onreadystatechange = processReqChange;
    ??? ??? ??? ??? req.open("POST", url, true);

    ??????? ??? ??? req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    ??? ??? ??? ??? req.setRequestHeader("Method", "POST " + url + " HTTP/1.1");
    ??? ??? ??? ??? req.send("q=" + escape(document.QForm.qtext.value));
    ??? ??? ??? }
    ??? ??? ???

    ??? ??? }
    ??? ???
    ??? ??? function processReqChange()
    ??? ??? {
    ??? ??? ??? if(req.readyState == 4) // only if req shows "loaded"
    ??? ??? ??? {
    ??? ??? ???????????????? if (req.status == 200) // only if "OK"
    ??? ??? ???????????????? {
    ??? ??? ???????????????? ??? ??? x = req.responseText;
    ??? ??? ???????????????????????? eval(x);
    ??
    ? ??? ???????????????? }
    ??? ??? ???????????????? else
    ??? ??? ???????????????? {
    ??? ??? ?????????? ??? ??? ????? alert("There was a problem retrieving the XML data:\n" + req.statusText);
    ??? ??? ???????????????? }
    ??? ??? ??? }
    ??? ??? ??? else if(req.readyState == 2)
    ??? ??? ??? {
    ??? ??? ??? }
    ??? ??? }
    ??? ???
    ??? ??? function sendRPCDone(frameElement, qString, arr1, arr2, arr3)
    ??? ??? {
    ??? ???
    ??? ??? ??? var suggest_results = eval(arr1);
    ??? ??? ??? var counts = eval(arr2);
    ??? ??? ??? var htmlstr = "<TABLE cellspacing=4 border=0>";
    ??? ??? ??? for (var i=0; i < suggest_results.length; i++)
    ??? ??? ??? {
    ??? ??? ??? ??? htmlstr += "<tr><td><a href=\"javascript:self.location=\'http://www.google.com/search?hl=en&q=" + suggest_results[i] + "&btnG=Google+Search\'\">" + suggest_results[i] + "</a></td>";
    ??? ??? ??? ??? htmlstr += "<TD width=200><font color= 228b22>" + counts[i] + "</font></TD></TR>"
    ??? ??? ?????? ??? ?
    ??? ??? ??? }
    ??? ??? ??? htmlstr += "</TABLE>";
    ??? ??? ??? document.getElementById("google_suggest_target").innerHTML = htmlstr;
    ??? ???
    ??? ??? }
    ??? ???
    ??? ??? </script>

    4。家庭作業(yè) :)

    一定要自己寫一些代碼,才能鞏固知識:)
    題目:
    我們經(jīng)常用del.icio.us來收藏我們喜歡的網(wǎng)站或者文章,并加一些類似讀書筆記的注釋。那么我們怎么利用del.icio.us提供的API來訪問我們的讀書筆記信息,并顯示在自己的Blog里呢?
    提示:
    1。你要有一個del.icio.us的賬號,并且已經(jīng)有所網(wǎng)頁收藏作為實驗數(shù)據(jù):)
    2。API URL 是 "http://del.icio.us/feeds/json/" + "你的賬號名";自己參看一下,看返回什么樣的格式文本。另外,如果要限制返回的記錄數(shù),可以加"?count=10"這樣的參數(shù)。


    最后,祝大家中秋愉快!

    ---------------------------完----------------------------




    posted @ 2006-10-07 07:05 Dedian 閱讀(2247) | 評論 (2)編輯 收藏

    2006年10月6日

    reference: http://us3.php.net/java
    help doc: http://php-java-bridge.sourceforge.net/

    1- Make sure u have Installed Apache 2 & PHP 5 and Java J2EE 1.5
    2- download pecl-5.0.5-Win32.zip and php-java-bridge_2.0.8.zip, which will include
    extra dll(s)
    ?? - unpack pecl pkg to your extensions folder, in PHP5 its ext.
    ?? - unpack java-Bridge to root php folder, in my case its simply C:\PHP
    ??
    Note:
    1. the java-Bridge inculdes new versions of certain files like php_java.dll
    ?? so, it would be wise to rename your old files that came with PECL pkg for example
    ?? file_old, to rollback at anytime.
    2. Don't run batch file under php-java-bridge after unpacking to php root folder, just add following lines in php.ini configure file (depends on installation fold of j2ee):

    extension=php_java.dll
    extension_dir = "C:\php\ext"
    [java]
    java.java_home=C:\Program Files\Java\jre1.5.0_06
    java.java=C:\Program Files\Java\jre1.5.0_06\bin\javaw.exe
    java.log_level=2
    ;java.log_file=ext/JavaBridge.log

    posted @ 2006-10-06 09:05 Dedian 閱讀(1135) | 評論 (0)編輯 收藏

    2006年9月29日

    http://www.apachelounge.com/forum/viewtopic.php?t=570

    http://www.webmasterstop.com/86.html
    posted @ 2006-09-29 05:44 Dedian 閱讀(1026) | 評論 (0)編輯 收藏

    2006年9月28日


    估計大家已經(jīng)在Google的主頁上看到了新的logo。對,今天是google8歲的生日。

    記不清什么時候第一次使用了Google,如今一個搜索引擎改變了人們的網(wǎng)絡生活,也帶來了互聯(lián)網(wǎng)的革命。如今人們大談網(wǎng)絡社區(qū)或社會化的同時,搜索引擎又開始一個新的臺階。

    8 年的時間,Google從一個單一的搜索產(chǎn)品已經(jīng)衍生出各種改變或影響人們生活的產(chǎn)品,并不斷推動網(wǎng)絡概念和技術(shù)上的變革。比如我們經(jīng)常用的產(chǎn)品有 Google talk, Google Adsence, Google Gmail, Google Calendar, Google Map, Google Video, Google Store, Google Earth,Google toolbar, Google Desktop. 還有很多Google正在思考的產(chǎn)品。

    總而言之,如果網(wǎng)絡成為你生活中的一部分,那么Google也越來越成為你生活的一部分。Google的文化連同它的產(chǎn)品也越來越成為很多其他網(wǎng)站公司效仿的對象。

    那讓我們看看我們普通網(wǎng)民一般用Google來搜索什么?

    1。如果你有個朋友多年未見,不妨用Google搜搜他的名字。
    2。如果你提筆忘成語或古詩,不妨用Google搜搜你能想起來的殘缺部分。
    3。如果你想找一張圖片,不妨也搜搜看。
    4。如果你想做作業(yè),寫文章或?qū)懏厴I(yè)論文,最好不過了??梢运训胶芏喔信d趣的,相關(guān)的素材。
    5。如果你不知道翻譯你的成績單,利用Google的翻譯功能吧。
    6。如果你有不認識的單詞,句子,俚語或者一些文化背景的東西,用用Google,wiki的查詢結(jié)果通常在第一頁。
    7。如果你聽到一首好歌,且不知道歌名,誰唱的,還想知道歌詞,那就用你聽到的幾句歌詞搜搜吧。
    8。如果你接到一個莫名其妙的電話,搜一搜,說不定知道是哪家公司打過來的。
    9。覺得一個人或者一個網(wǎng)站或者一邊文章很cool,不妨也搜一搜,會有很多有趣的東西出現(xiàn)。
    10。大家都在談論著一件事,或者最近很流行的一個話題或術(shù)語,搜一搜,看看他們到底在說什么。
    11。有一個似乎很著名的英文縮寫,搜一搜,看看到底全稱是什么。
    12。電腦遇到問題了,怎么辦?先不要著急,先搜一搜,看看有沒有人和你一樣的問題,有沒有解決方案。
    13。這家伙的網(wǎng)頁做的很cool,怎么弄得?搜一搜,保證長見識。
    14。很想問問題,搜一搜你的問題,說不定有答案。

    好了,估計還有很多,大家接著補充。。。
    posted @ 2006-09-28 07:55 Dedian 閱讀(1047) | 評論 (1)編輯 收藏

    2006年9月26日

    當你有一個很好的idea的時候,你或許會感到有一絲興奮。然而如果你發(fā)現(xiàn)你的idea以你一己之力卻無法實現(xiàn),并且還找不到志同道合的同志,你的興奮就會很快地變?yōu)橛魫灐T龠^幾天,你會發(fā)現(xiàn)網(wǎng)上已經(jīng)有人做了一件幾乎同樣的事并且比你事先的idea還要做的好的時候,那種郁悶又會升級為失落。

    其實很多普通的又有點智慧的IT人都要不同程度地承受這樣的一種失落。

    抓蝦就是這樣一個曾經(jīng)讓我有幾許失落的感覺。失落得我有很長一段時間沒有注冊一個用戶。不過收拾收拾自己的心情,我還是很欣然的接受這樣一個優(yōu)秀的國產(chǎn)web 2.0網(wǎng)站。

    其實抓蝦的idea很簡單。它是一個把web 2.0概念和目前風行的基于RSS信息標準聚合格式很好地結(jié)合在一起的新興國產(chǎn)訂閱網(wǎng)站。盡管國外很早就有像Bloglines這樣的在線RSS信息訂閱網(wǎng)站。但不如抓蝦把web 2.0的概念有機地結(jié)合在一起。前者只是一個簡單的訂閱系統(tǒng)和簡單的共享。

    關(guān)于web 2.0這個從上次網(wǎng)絡泡沫的廢墟上站起來的概念,目前大都的網(wǎng)民都有親密接觸。2005開始在國內(nèi)流行至今的Blog和wiki其實就是web 2.0產(chǎn)物中的代表。

    以前的網(wǎng)站更像一個信息發(fā)布的平臺。如果說網(wǎng)站是一個電影院的話,那我們這些網(wǎng)民充其量就是觀看電影的觀眾,即便我們可以注冊成為VIP而進入包廂看電影亦不過如此。你甚至可以把電影帶回家看,但你不能控制電影院播放電影的內(nèi)容,也不能隨隨便便發(fā)布你自己制作的電影。

    然而,web 2.0的概念就是給網(wǎng)民提供一個享受各種web服務的平臺。

    網(wǎng)民不再是觀眾,而可以是演員,導演,發(fā)行商,甚至二販子。從技術(shù)角度上講,web 2.0使用戶開始可以控制數(shù)據(jù)。從用戶角度講,web 2.0使Internet成為一個虛擬社區(qū),大家可以相互交流和共享。(從這種意義上說,早期的BBS和P2P下載軟件都是web2.0)

    關(guān)于RSS聚合,我一直認為它只是一個基于xml的數(shù)據(jù)結(jié)構(gòu)。在很早以前開始用.Net開發(fā)的時候,我就接受xml schema的一個思路,就是實現(xiàn)數(shù)據(jù)與其表現(xiàn)形式相分離。這也是我克服想嘲笑xml這樣一個如此簡單的網(wǎng)絡標準的沖動。不過那時,我就有用RSS作為 Internet上凌亂不堪的信息的一個標準結(jié)構(gòu)的想法,這樣搜索引擎就會變得簡單(也曾經(jīng)為此寫過一個類似資料收集器的小程序)。尤其在選了一門 Distributed Multimedia Information Management的課程后。里面大談網(wǎng)絡的Ontology和RDF技術(shù)。其實也就是用xml的數(shù)據(jù)結(jié)構(gòu)去描述網(wǎng)絡實體及其內(nèi)在聯(lián)系的一種技術(shù)。不過,rdf相對于簡單的rss來說,在應用上似乎超前一些。

    有了web 2.0的概念,有了標準的數(shù)據(jù)結(jié)構(gòu),再加上一些具體的網(wǎng)站實現(xiàn)技術(shù)(比如目前流行的Ruby),你就可以自己搗鼓一個web 2.0的網(wǎng)站出來。抓蝦很顯然在這方面做的比較成功。一方面,國內(nèi)這方面成功的網(wǎng)站還比較少(經(jīng)常去的也就是抓蝦和豆瓣),另一方面,目前rss(如 blog)正在國內(nèi)大肆流行的季節(jié)。

    當然現(xiàn)在不少web 2.0沒戲的論調(diào)。其實這沒什么新鮮。網(wǎng)絡的東西就是這樣,每個人都有idea,都可以有技術(shù)做,但要存活做大,就這能是少數(shù)。web 2.0目前還是燒錢階段,因為提供的服務都是免費的(大家已經(jīng)習慣了網(wǎng)絡的免費午餐),只能燒錢搶用戶,最后賣流量,再搞壟斷。如果沒錢,就只能做成像奇客發(fā)現(xiàn)(diglog.com)這樣子(這個網(wǎng)站的idea和著名的digg.com類似,但顯然還在incubation階段)。這一點,和web 1.0沒有什么區(qū)別。這也是為什么大都的IT人依然郁悶,生活在各大小不等的目前還存活的公司的庇護下做著自己各自的夢想。

    posted @ 2006-09-26 08:51 Dedian 閱讀(1945) | 評論 (2)編輯 收藏

    2006年9月23日

    http://www.oracle.com/technology/pub/articles/maps1.html
    posted @ 2006-09-23 02:52 Dedian 閱讀(1073) | 評論 (1)編輯 收藏

    2006年9月21日

    When I try to get some information of http connection to some websites (say http://linuxbyte.net) by function HttpURLConnection.getResponseCode(), it seems tthat JVM hangs for quite a while. Somebody says that is maybe the problem of http server who must be a Microsoft webserver. Here and here are the bug report information for Java 1.3 or before. Though it is said that the problem has been solved after java 1.4, i still get undesirable a long time waiting before a SocketException (Connection reset) is thrown out. Btw, conn.setConnectTimeout or conn.setConnectTimeout is involved for this problem. I am not sure if there is any method that can save time to skip those bad links.
    posted @ 2006-09-21 06:32 Dedian 閱讀(1139) | 評論 (0)編輯 收藏

    2006年9月19日

    Here is a good article to introduce Ruby ..why we choose Ruby instead of Perl and Python ?
    posted @ 2006-09-19 05:51 Dedian 閱讀(949) | 評論 (0)編輯 收藏

    2006年8月29日

    -- Scenario:
    ??? The purpose of a reader is to interpret a low-level byte stream (ByteArrayInputStream, StringInputStream, FileInputStream and so on) as a character stream and provid character input to whatever class needs it. And it is very simple to convert an inputstream to a reader:
    Reader reader = new InputStreamReader( in ); //in is an instance of class InputStream or derived classes
    But the issue is sometimes we need convert a reader to inputstream, think about following scenaros:
    1.? the original inputstream has been filtered by certian reader, now we need save back filtered content into database by inputstream: we can not use original inputstream but filtered stream which can only get from your reader.
    2.? Given a class who contains a reader to access a streaming content after complex parsering or downloading, we want to utilize the streaming content in this class while not repeating complex operations for content analysis, so we need employ some wrapper methods to get inputstream from reader.

    -- Solution:
    1. write own InputStream implementation, such as following:

    class MyInputStream extends InputStream
    {
    private Reader rd;
    public MyInputStream(Reader rd)
    {
    super();
    this.rd = rd;
    }
    ?
    ?
    // implement the read() method to make this all work
    publicint read()
    {
    int t = rd.read();
    // you can do your processing on the inputReader here
    // fiddle with the values and return
    return t;
    ?
    }
    }
    Note: Applications that need to define a subclass of InputStream must always provide a method that returns the next byte of input.
    (refer to http://java.sun.com/j2se/1.4.2/docs/api/java/io/InputStream.html)

    -- anything else? BTW, for parsering xml-based input stream by SAX, I am glad to see that the inputSource constructor can take either InputStream or Reader (refer to http://java.sun.com/j2se/1.4.2/docs/api/org/xml/sax/InputSource.html)


    posted @ 2006-08-29 09:46 Dedian 閱讀(1338) | 評論 (0)編輯 收藏

    2006年8月19日

    for general purpose hash function:

    http://www.partow.net/programming/hashfunctions/

    for cryptography & hash function

    http://www.x5.net/faqs/crypto/

    for a faster and better hash function (comparison of several hash function):

    http://burtleburtle.net/bob/hash/doobs.html

    ----> for further reading...
    posted @ 2006-08-19 03:01 Dedian 閱讀(983) | 評論 (0)編輯 收藏
     
    Copyright © Dedian Powered by: 博客園 模板提供:滬江博客
    主站蜘蛛池模板: 91精品免费高清在线| 又硬又粗又长又爽免费看| 最好看最新的中文字幕免费| 亚洲精品国产精品乱码不卡√| 国产福利电影一区二区三区,免费久久久久久久精 | 免费一级毛片不卡在线播放 | 亚洲一区二区三区久久| 免费看黄的成人APP| 国产亚洲精品a在线无码| 在线观看免费黄色网址| 亚洲天天做日日做天天欢毛片| 免费女人高潮流视频在线观看 | 亚洲成年网站在线观看| 在线播放免费人成视频在线观看| 99亚偷拍自图区亚洲| 永久免费无码网站在线观看| 女bbbbxxxx另类亚洲| 亚洲国产精品成人| 特级做A爰片毛片免费看无码| 婷婷亚洲久悠悠色悠在线播放| 7x7x7x免费在线观看| 国产精品高清视亚洲一区二区| 成人免费午间影院在线观看| 相泽南亚洲一区二区在线播放| 亚洲不卡无码av中文字幕| a级成人毛片免费图片| 亚洲国产超清无码专区| 香蕉视频在线观看免费国产婷婷| 激情小说亚洲色图| 亚洲AV无码码潮喷在线观看| 国产在线a免费观看| 黄床大片30分钟免费看| 亚洲综合无码一区二区| 国产裸模视频免费区无码| 久久久久久国产a免费观看不卡| 亚洲国产综合专区在线电影| 青青草国产免费久久久91| 97在线免费视频| 亚洲精品无码专区久久| 亚洲av无码成h人动漫无遮挡| 免费看美女被靠到爽|