google app enging for java 用來跑 PHP

前幾天 google 發布了 google app engine 支援了 java 後,就有聽說有人可以利用 Quercus 專案,來支援 PHP ,這是一個令人興奮的消息啊。像我不太會寫 python 的人,有 PHP 的支援,更可以讓更多的 web developer 快速上手。

幾天後,有一家公司的 blog 上發表了一篇「Run PHP on the Google App Engine」,他們已經成功的在 app engine 上執行 php 了。

他所列的步驟如下:

  1. Register a free account.
  2. Download this file to your computer.
  3. Edit application XML tag in the file war\WEB-INF\appengine-web.xml to the name of the application you have registered.
  4. Finally upload your application. I downloaded Google App Engine SDK for Java and use the following command in windows.

但我在本地端測試的時候,因為少了一些 package 所以沒辦法在本地端執行,你可以到 http://www.codehaus.org/ 下載 jetty package ,並且解壓縮到 app-engine 的 lib 目錄,即可以使用 dev_appserver.sh 這個指令在本地端測試了。Depoy 到 google 的 GAE 上的話,就不用這這個 package 了。

另外他沒有支援 Mysql 之類的關聯性資料庫,所以如果要 port 一些跟資料庫相關的東西的話,應該要自行改寫其資料庫的部份。

二個 postgresql 的 Tips

最近公司會用到 postgresql 來作為 Database ,不過因為之前都使用 Mysql 的 DB 設定和使用方法,所以有一些的不習慣,底下有二個我目前用到小技巧。

之前在 mysql 下,會使用 desc table 這個指令,來列出目前該 table 的 schema 有哪些。不過經由 postgresql 的 1.4. Accessing a Database 章節裡的使用者留言下說明,要用以下的方法來取代:

  1. SELECT column_name,data_type FROM information_schema.columns WHERE table_name = 'table_name'

如果是 show table 這個指令,就得由以下的指令來取代:

  1. SELECT table_name FROM information_schema.tables WHERE table_schema = 'public'

另外由於我目前寫 php 時,都是經由 pdo 來存取 Database ,所以一般來說,我們都會使用 PDO::lastInsertId 來取得最後一筆插入的 ID ,不過因為 postgresql 並不支援該方法,所以會一直產生 false 的值。查了一下 php.net 的 PDO::lastinsertid 裡面的說明,他是改 select 一個 Sequences 的值,所以我依照我的需求改寫一下,就可以查出 last insert id 了。

  1. <?php
  2. function lastInsertId($table,$pk  = "id")
  3. {
  4.     $query = "SELECT currval('{$table}_{$pk}_seq') AS last_value";
  5.     $temp_q_id = $pdo->prepare($query);
  6.     $temp_q_id->execute();
  7.  
  8.     if($temp_q_id)
  9.     {
  10.         $temp_result = $temp_q_id->fetch(PDO::FETCH_ASSOC);
  11.         return ( $temp_result ) ? $temp_result['last_value'] : false;
  12.     }
  13. }
  14. ?>

當然在 php.net 上有更優雅的寫法,就是即時的分析 sql 字串,來找出 table ,但因為我的 pk 的鍵值都不一樣,所以才要自行作改寫了。

jquery 判定 browser 種類

在工作中,有一些需要為 IE 作特別的 hack ,例如像 IE 的 option 不吃 onclick 的事件之類的。但又不想讓他影響到 IE 之外的 browser 。在 jquery 裡面,可以使用下列的參數來判定是不是使用 IE 。

  1. if(jQuery.browser.msie) alert("這個 browser 是 IE");

當然其他的參數也可以判定 browser 的板本與種類,可以參考Utilities/jQuery.browser這份文件。

歷史上的今天-2009.03.12

很久沒報告近況了,自從在十二月被某知名網路公司 layoff 後,在一月份底就進到了新公司。而這段日子來,找工作實在是景氣非常的不好,很多公司都說很喜歡我,可是最後都跟我說手頭已經沒有任何的員額。這樣算是騙人去面試嘛?

離開了一個我滿喜歡的環境,裡面的同事說話和個性都非常的契合,跟我談論的東西也是我喜歡的。不過現在在新公司也是寫 php 和系統整合相關的工作,事實上還滿有趣的。在自已拿手的東西下,工作還滿輕鬆的。

為了找房子,最近也花了不少時間,才從永和搬到了石牌,因為本來從永和到新公司,光坐捷運就要 30 分鐘,還不包括走路到捷運站的時間。最後搬到了石牌,其實我搬到了新房間後,要到捷運站反而要走更長的時間,但是只要坐二站就到新公司了,這樣我也可以騎單車上下班哦。

每天的生活除了上班,就是搞 Fantasy Space ,要不然就是跟朋友出去吃飯聊天,其實這樣的日子我還過的滿愜意。其實只要開開心心的過生活,就不要想太多就好囉。

最近也在玩 plurk ,歡迎有興趣的人加入 我的 plurk 參觀啊。

Asus WL-500W 改機實錄

在幾個月前,買了 Asus WL-500W 這台 ip 分享器,看上的是他可以改機,與他支援 802.11N draft 的 protocol ,而且如果正式板出來的話,聽說還可以寄回去換主式板哦。雖然改機可能會破壞保固,但是可以自由的惡搞,這才是最令人爽快的。以下的內容就是 Asus WL-500W 的改機的方式。當然也是我自已作記錄的方式,避免之後忘記怎麼處理。

具備的知識與能力:

  • 最好有基本的 Linux 的管理與操作知識
  • 對於網路要有基本的了解
  • 不怕死的精神

刷機步驟:

  • 參考 OpenWRT for wl 500w 這篇文章,裡面其實已經說的滿詳細的。
  • 準備刷機的 Firmware ,我是使用 brcm-2.4/openvpn 這一板的(下載位置),因為我也想順便玩玩 openvpn 的功能。當然我也有不怕死的精神,所以我下載的是 snapshots 的板本。
  • 準備 tftp server 讓 wl-500w 可以更新他的 Firmware 。參考文件:Installing OpenWrt via TFTP
  • 我是使用 atftp 來作為我的 tftp server ,在 debian 下只要使用下列指令即可安裝:
    1. # apt-get install atftp

    安裝完後,照著上述說明完成架設 tftp server ,並且把 wl-500w 重開後,他就會自動下載更新。

  • 刷機的這段時間,不要拔掉電源,否則會有不可預期的錯誤發生。
  • 刷機完成後,如果想用 web 管理的話,可以進入http://192.168.1.1/作管理,一開始會請你設定 root 密碼。
  • 除了使用 web 管理之外, ssh root@192.168.1.1 也可以登入管理主機。
  • 有需要安裝什麼功能,可以利過 system/package 或是 opkg 來安裝。

Tips:

  • 如果要讓外部的人連上 ssh 除了可以在 web 介面設定之外,也可以在 /etc/config/firewall 下新增下列設定:

    1. config 'rule' 'ssh'
    2.         option 'src' 'wan'
    3.         option 'proto' 'tcp'
    4.         option 'src_ip' ''
    5.         option 'dest_ip' ''
    6.         option 'dest_port' '22'
    7.         option 'target' 'ACCEPT'
  • 啟用 usb 隨身儲存裝置,可參考 UsbStorageHowto 來實作,可 ssh 進去後,使用下列指令:
    1. #opkg update
    2. #opkg install
    3. #opkg install kmod-fs-vfat
    4. #opkg kmod-usb-core kmod-usb-ohci kmod-usb-storage kmod-usb2

    或是利用 web 界面中的 package 選項裡安裝 kmod-fs-vfat, kmod-usb-core,kmod-usb-ohci,kmod-usb-storage,kmod-usb2 。接著利用 fdisk -l 與 mount 指令,就可以把隨身裝置掛載上去了。

最後,歡迎加入惡搞世界。

« Older entries

 

碎碎念

統計

  • 文章數:208
  • 分類數:14
  • 評論數:381
  • 總字數:43887

誰來訪?