Tommy 碎碎念

Tommy Wu's blog

修正 Spreadsheet_Excel_Writer 的 unicode 問題
post by tommy @ 21 六月, 2008 15:10

在經過之前所提過的修正之後, 的確可以在 Excel 的欄位中正確的使用 unicode 了. 不過最近在 Study-Area 有人提到 Worksheet 的名稱與列印的 Header 與 Footer 都不能使用 unicode. 試了一下, 果然不能正確使用. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
PHP chmod() 慘案
post by tommy @ 28 五月, 2008 09:56

話說前一陣子在 php 裡頭用到了 chmod 這個函式, 依據以往在 linux 下頭使用 chmod 指令的經驗, 加上使用 php 時, 並沒有做型別檢查的功能, 很自然的就會認為這個函式如同其他 php 的函式一般, 可以用數字也可以用字串來表示要更改的屬性. 而且, 的確在一開始的使用上, 做一些 o+w 或 o-w 之類的動作時, 都十分的正常, 一點都沒有懷疑這會有問題.

不過... 前幾天碰到了一個 g+s 的動作, 發現.... 一跑到這兒, 整個屬性反而被改成 000 了, 也就是被清空了. 這是怎麼回事呢?

想了很久, 也測了一些寫法, 最後, 終於在官方的 chmod 說明中看到, 這個 mode 參數, 只能是整數, 對於前述的字串參數來說, 是不對的. (說到這兒, 既然不允許, 是不是應該全部都失敗會比較好一些, 不要讓人誤以為可以使用, 結果... 只有某些情形下會不能用)

回頭把程式改了一下, 先取出屬性再做一堆 OR 運算, 自己弄出類似的結果, 然後再去把屬性改成自行運算後的結果, 這樣子果然就正常了. 有用到 chmod 的人, 自己注意一下吧.

Del.icio.us Furl HEMiDEMi Technorati MyShare
透過 php 更改 ldap 的密碼
post by tommy @ 06 三月, 2008 19:14

一般來說, 我們在使用 php 去檢查使用者的帳號密碼時, 都是直接用該組帳號密碼去執行 ldap_bind() 的動作, 如果成功的話, 表示密碼是對的, 如果失敗的話, 表示密碼是錯的. (唯一的例外是... 如果密碼是空字串, 也會成功, 所以用這個方法要先檢查密碼是不是空的) 如:

if ($password !== '' && ldap_bind($id, "uid=$user,dc=example,dc=com", $password))
echo "password correct!\n";
else
echo "wrong password!\n";

但是, 如果要修改密碼時, 又該如何呢? 我們可以用下面的方式:

if (ldap_mod_replace($id, "uid=$username,dc=example,dc=com",
array('userpassword' => "{MD5}".base64_encode(pack("H*",md5($newpass)))
echo "succeded\n";
else
echo "failed";

就是先用該使用者 (或有權限改密碼的帳號) bind 之後, 去更改 userpassword 這個屬性. 使用 md5 的方式去設定密碼.

Del.icio.us Furl HEMiDEMi Technorati MyShare
phpmsnclass v1.8
post by tommy @ 11 十一月, 2007 10:13

更新 phpmsnclass 版本為 1.8.  (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
FPDF UTF-8 簡繁中文支援
post by tommy @ 20 十月, 2007 12:49

以前, 在 FPDF 的中文支援中, 並不支援 UTF-8 編碼, 所以每次要產生 pdf 檔案時, 都要用 iconv 轉成 BIG5 或 GB 來使用. 如果同一段文字有簡體也有繁體時, 這個轉換就會有問題 (不過還好我們之前的案子, 還沒碰到這個問題, 系統把兩種編碼分開來用, 並沒有衝突的情形發生). 後來, 有人改了一個 unicode 版本的 FPDF, 雖然有支援 UTF-8 了, 但是... 作法是把字型檔也整個編入 pdf 檔案中, 結果.... 是可以使用沒錯, 但是... 原本幾 KB 的 pdf 檔案, 變成幾 MB, 根本沒有實用性. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
在 PHP 中使用 TLS 與 OpenLDAP 連線
post by tommy @ 20 六月, 2007 19:55

首先, TLS 是在 Protocol Version 3 才有提供, 所以必須在 ldap_connect() 之後, 使用 ldap_set_option() 設定使用 protocol version 3 才可以. 如果這樣子處理, 並沒有辦法正確的執行 ldap_bind(), 則必須在你 client 端的 ldap.conf 中, 加上 TLS_REQCERT 這個參數, 其值為 nerver 或 allow 才可以. 如果沒有 ldap.conf, 也可以利用環境變數 LDAPTLS_REQCERT 來設定, 或直接使用 putenv() 來設定這個變數. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
phpmsnclass v1.7
post by tommy @ 17 六月, 2007 16:08
更新 phpmsnclass 版本為 1.7. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
MySPAM v0.0.4a
post by tommy @ 11 六月, 2007 09:51

MySPAM v0.0.4a 推出, 其實早在半年多前, 小張張就把他做的搜尋功能給我了, 不過... 我一直懶的去動, 直到昨天有人問我這件事... 才動手改了一下. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
phpmsnclass v1.6
post by tommy @ 07 六月, 2007 16:04

更新 phpmsnclass 版本為 1.6. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
msn.class.php v1.5, fix some small bug
post by tommy @ 06 四月, 2007 18:54

修改之前發送 MSN 的 php calss. 修正一些 bug. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
msn.class.php v1.4, We can talk to Yahoo now!
post by tommy @ 02 四月, 2007 09:24

修改之前發送 MSN 的 php calss. 修正一些 bug, 並加上與 Yahoo 即時通互傳的功能. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
msn.class.php v1.3a, a simple msnbot
post by tommy @ 29 三月, 2007 11:08

修改之前發送 MSN 的 php calss. 加入一些小功能, 可以做成簡單的 msnbot. (閱讀全文)

Del.icio.us Furl HEMiDEMi Technorati MyShare
讓 PhpBB2 也用中文數字吧! Part II
post by tommy @ 15 三月, 2007 12:09
加上動態使用背景圖案並把顯示的文字做些旋轉. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
讓 LifeType 的 AuthImage 顯示中文數字 Part II
post by tommy @ 14 三月, 2007 15:01
加上動態使用背景圖案並把顯示的文字做些旋轉. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
msn.class.php v1.2 (修正 32 位元機器 OIM 問題)
post by tommy @ 13 三月, 2007 18:31
修改之前發送 MSN 的 php calss. 修正在 32 位元的機器上, 無法計算出正確的 challenge code, 因此無法正確發送離線訊息的問題. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
msn.class.php v1.1
post by tommy @ 13 三月, 2007 11:37
修改之前發送 MSN 的 php calss . 主要是加上 timeout 的設計, 以避免在 MSN protocol 修改之後, 程式可能會有無法結束的情形. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
在 shell script 中發送 MSN 訊息
post by tommy @ 12 三月, 2007 08:25
有了之前用 PHP 寫的 MSN class 之後, 要在一般的 shell script 中來發送 MSN 的訊息就不是件難事了. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
使用 PHP 發送 MSN 訊息
post by tommy @ 11 三月, 2007 10:55
最近有個自動發送 MSN 訊息的需求, 是在系統有異常時, 希望可以發送 MSN 訊息通知相關人員 (一般還是發 email, 只是, 多數人並不是隨時都在檢查並讀取 email, 並沒有 IM 的即時效果). 我記得在 Study Area 有看過類似的作法, 找到了這一篇文章 , 打算照著做就可以了, 可惜... 怎麼試都不成功. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
Zend Platform 3.0 安裝烏龍事件
post by tommy @ 08 三月, 2007 14:54
好像在幾個月前吧, 家裡的 Debian 中的 php 升到了 5.2 之後, 原本的 Zend Platform 2.2 就不能使用了, 所以搭配的 Zend Studio 5.5 就失去了遠端除錯的功能了 (雖然... 我好像也幾乎沒有使用到). (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
Google AdSense plugin for LifeType v0.2
post by tommy @ 07 三月, 2007 21:23
讓 google_ad_width, google_ad_height, google_ad_format 等變數也改成可以由使用者自行設定. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
Google AdSense plugin for LifeType
post by tommy @ 07 三月, 2007 14:14
前兩天申請了 Google AdSense 的帳號, 發現 LifeType 本身, 並沒有外掛程式提供這個服務, 只能自己在 template 中加入自己的程式碼. 不過, 對於一個多人使用的 blog 程式來說, 如果每個人都要去改 template, 似乎不太正確. 所以就寫了這個外掛程式來使用. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
讓 PhpBB2 也用中文數字吧!
post by tommy @ 01 三月, 2007 16:02
同樣的方式, 我們也可以讓 phpBB 也使用中文數字的圖片. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
讓 LifeType 的 AuthImage 顯示中文數字
post by tommy @ 01 三月, 2007 14:59
之前雖然把 AuthImage 改成用 Better Captcha 的圖型來顯示, 效果不錯, 不過... Better Captcha 的圖有時仍會不太容易看的懂. 所以就想了另一種方式, 把這個改用中文字來顯示, 對於看不懂中文的外國 bot 來說, 應該就有足夠的效果. 當然... 對人來說, 如果看的懂中文, 也應該是很容易就可以看出結果來. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
修正 phpsysinfo 在顯示 /dev/hda1x 時, 會重複的問題
post by tommy @ 27 二月, 2007 10:34
如果你的 partition 切的太多, 有出現 10 或以上的數字時, 在使用 phpsysinfo 這個軟體時, 會把這類的 partition 認為時 1 那一個, 而重複顯示這類的 partition. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
PostgreSQL ODBC 連線的 client encoding mismatch 錯誤
post by tommy @ 01 二月, 2007 00:01
前天把公司某台主機的 PostgreSQL 由 8.0.3 升級到 8.2.1. 原本以為一切都正常, 不過後來發現, 在另外一台 Windows 的機器上頭, 使用 php 寫的一些透過 ODBC 連線的程式都無法正常執行. (閱讀全文)
Del.icio.us Furl HEMiDEMi Technorati MyShare
Bad Behavior 已經阻擋了 48 個過去 7 天試圖闖關的垃圾迴響與引用。
Power by LifeType. Template design by JamesHuang. Valid XHTML and CSS