首先把系統(Rh8.0)裝好,並且安裝了sendmail,然後編輯sendmail.cf,把127.0.0.1這一行注釋掉,在/etc/hosts文件中添加了本機IP和域名的對應(這樣可以不配DNS 服務器 ),重啟郵件服務即可(防火牆裡面相關端口已經打開,如果沒有打開,執行ntsysv後重新
首先把系統(Rh8.0)裝好,並且安裝了sendmail,然後編輯sendmail.cf,把127.0.0.1這一行注釋掉,在/etc/hosts文件中添加了本機IP和域名的對應(這樣可以不配DNS
服務器),重啟郵件服務即可(防火牆裡面相關端口已經打開,如果沒有打開,執行ntsysv後重新配置一下防火牆)。到openwebmail網站下載了最新版本的rpm包,安裝比較順利。然後按照提示執行初始化操作:cd the_direcotry_of_openwebmail_cgi_scripts./openwebmail-tool.pl --init顯示有和suidperl相關的錯誤,於是用apt升級perl-suidperl,再進行初始化操作成功,按照顯示的提示修改相應文件,基本成功,再換一台電腦(hosts文件也要修改),用浏覽器打開網頁:http://yourdomain/cgi-bin/openwebmail/openwebmail.pl,即可看到webmail界面,輸入帳號密碼,進入信箱後出錯,看提示發現和Text-Iconv-1.2.tar.gz有關,於是再按照安裝提示重新安裝了Text-Iconv了,
測試成功!!!
安裝參考文件見下: 引用:
Open WebMail 官方站台
Open WebMail 的官方網址是 http://openwebmail.org, 這部機器位於美國 Spring Link 骨干上的機房, 是由熱心的網友 Daniel Pentecost 還有他的公司 Norvasen 與 Pentecost Inc. 所完全免費提供, 目前並由網友 Thomas Chung 負責整個網站的運行與維護. 在發展 Open WebMail 的過程中, 受到許許多多來自世界各地朋友的幫助, 實在是感動良多, 真的讓人有一種世界村, 天涯若比鄰的感覺...
至於 http://turtle.ee.ncku.edu.tw/openwebmail 則是程序發展的中心, 所有最新的程序代碼都是在這裡測試完後才開始對外公布, 然後復制 (mirror) 到官方站台及各地的 mirror site.
Open WebMail 安裝需求 支援 CGI 的 Web server
Perl 5.005 以上 (需有 suid perl 支持)
CGI.pm-2.74.tar.gz (必要)
MIME-Base64-2.12.tar.gz (必要)
libnet-1.0901.tar.gz (必要)
Text-Iconv-1.2.tar.gz (必要)
libiconv-1.9.1.tar.gz (可選擇)
CGI-SpeedyCGI-2.22.tar.gz (可選擇)
Compress-Zlib-1.21.tar.gz (可選擇)
ispell-3.1.20.tar.gz (可選擇)
Quota-1.4.6.tar.gz (可選擇)
Authen-PAM-0.12.tar.gz (可選擇)
ImageMagick-5.5.3.tar.gz (可選擇)
以上的套件, 一般來說是透過 source 安裝, 但如果您用的是 RedHat Linux, 那也有 rpm 可以快速安裝
安裝套件 (由 source 安裝) 首先請先到 http://turtle.ee.ncku.edu.tw/openwebmail/download/packages/ 下載上述的各個套件
安裝 CGI.pm 套件
cd /tmp
tar -zxvf CGI.pm-2.74.tar.gz
cd CGI.pm-2.74
perl Makefile.PL
make
make install
注: 可能您原本的機器上就已經安裝了 CGI.pm 這個套件, 不過由於有使用者回報 Open WebMail 如果使用太舊的 CGI.pm 版本, 會在上傳附件時, 發生當住的情形, 所以我們建議您安裝 2.74 以後或是更信的版本. 檢查 CGI.pm 版本的方式如下;
perl -MCGI -e 'print $CGI::VERSION'
安裝 MIME-Base64 套件
cd /tmp
tar -zxvf MIME-Base64-2.12.tar.gz
cd MIME-Base64-2.12
perl Makefile.PL
make
make install
注; 雖然您的機器可能已經安裝了 MIME-Base64 這個套件, 還是建議您從 source 重新裝一次. 這樣做的話, 可以確定 MIME-Base64 中的 XS 支持有被啟動, 可以大幅地增加處理 MIME 附件編碼與譯碼的速度
安裝 libnet 套件
cd /tmp
tar -zxvf libnet-1.0901.tar.gz
cd libnet-1.0901
perl Makefile.PL (ans 'no' if asked to update configuration)
make
make install
安裝 Text-Iconv-1.2 套件 (自 openwebmail 1.80起)
openwemail 自 1.80 版以後開始支持多國的字集轉換功能(如: 中文的簡繁轉換, 日文的 Shif-JIS/ISO-2022-JP/EUC-JP 轉換, 或是各種字集對 Unicode (UTF- 的轉換), 這個轉換的動作是透過 Text-Icon 套件來完成的. 而由於 Text-Iconv 事實上只是提供對系統 iconv() 相關函式 的一個 perl 接口, 所有首先要確認系統上是否支持 iconv() 相關函式, 方法如下
man iconv
如果下完命令後沒有出現相關的 manpage 說明文件, 表示系統可能不支持 iconv() 相關函式, 不過別擔心, 我們可以透過安裝 libiconv 這個套件來替系統加上對 iconv() 的支持
cd /tmp
tar -zxvf libiconv-1.9.1.tar.gz
cd libiconv-1.9.1
./configure
make
make install
現在再試一次 'man iconv' 確認 libiconv 已經被成功的安裝到系統之中
接下來就可以開始安裝 Text-Iconv 這個套件了
cd /tmp
tar -zxvf Text-Iconv-1.2.tar.gz
cd Text-Iconv-1.2
perl Makefile.PL
注: 如果您用的是 FreeBSD, 或是您剛才用手動安裝 libiconv-1.9.1.tar.gz 這個套件, 請在執行 perl Makefile.PL 之前, 先修改 Makefile.PL 檔案, 將 LIBS 和 INC 這兩行設定如下
'LIBS' => ['-L/usr/local/lib -liconv'], # e.g., '-lm'
'INC' => '-I/usr/local/include', # e.g., '-I/usr/include/other'
make
make test
注: 如果 make test 失敗, 代表您的 OS 不支持 iconv() 這個功能或是 Makefile.PL 中的 LIB, INC 設定有誤. 您可以將 uty/iconv.pl.fake 拷貝到 iconv.pl 這個檔案上, 讓 openwebmail 不透過 iconv 進行字集轉換. 這樣 簡/繁轉換 功能會還在, 但是會喪失如 自動轉換 UTF-8 格式信件的功能.
make install
安裝套件 (由 rpm 安裝)
如果您用的是 RedHat Linux, 那麼您可以透過 rpm 快速安裝, 下載 rpm 的網址在 http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/
首先是安裝 CGI, MIME-Base64 和 libnet 這三個套件
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh73/perl-CGI-2.752-34.99.6.i386.rpm
rpm -Uvh --force perl-CGI-2.752-34.99.6.i386.rpm
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh73/perl-MIME-Base64-2.12-14.i386.rpm
rpm -Uvh --force perl-MIME-Base64-2.12-14.i386.rpm
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh73/perl-libnet-1.0901-17.i386.rpm
rpm -Uvh --force perl-libnet-1.0901-17.i386.rpm
注: 您可以透過 rpm -qa | grep -i keyword 的方式來查詢系統上是否已安裝某特定套件
注: 如果想要讓 wget 透過 proxy 去抓數據的話, 請在使用 wget 前先執行下列命令
export http_proxy=http://your_proxy_server:3128 (for bash)
setenv http_proxy http://your_proxy_server:3128 (for csh/tcsh)
接著檢查您的系統是否有裝 suidperl 套件
rpm -q -a|grep -i suidperl
如果您的 7.3 系統沒有裝 suidperl 的話, 請
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh73/perl-suidperl-5.6.1-34.99.6.i386.rpm
rpm -Uvh --force perl-suidperl-5.6.1-34.99.6.i386.rpm
如果您的 8.x 系統沒有裝 suidperl 的話, 請
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh80/perl-suidperl-5.8.0-55.i386.rpm
rpm -Uvh --force perl-suidperl-5.8.0-55.i386.rpm
如果您的 9.x 系統沒有裝 suidperl 的話, 請
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh9/perl-suidperl-5.8.0-88.i386.rpm
rpm -Uvh --force perl-suidperl-5.8.0-88.i386.rpm
接著是檢查您的系統是否有裝 Texi-Iconv 套件
rpm -q -a|grep -i iconv
如果您的 7.3 系統沒有裝 Text-Iconv 的話, 請
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh73/perl-Text-Iconv-1.2-RH73.i386.rpm
rpm -Uvh --force perl-Text-Iconv-1.2-RH73.i386.rpm
如果您的 8.x 系統沒有裝 Text-Iconv 的話, 請
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh80/perl-Text-Iconv-1.2-RH80.i386.rpm
rpm -Uvh --force perl-Text-Iconv-1.2-RH80.i386.rpm
如果您的 9.x 系統沒有裝 Text-Iconv 的話, 請
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/packages/rh9/perl-Text-Iconv-1.2-RH80.i386.rpm
rpm -Uvh --force perl-Text-Iconv-1.2-RH80.i386.rpm
安裝 Open WebMail
在 http://turtle.ee.ncku.edu.tw/openwebmail/download/ 下可以下載 Open WebMail 的各個 Release 版本 (openwebmail-x.yy.tar.tgz) 與最新的 current 版本 (openwebmail-current.tgz). Release 版本 是屬於經過測試後, 功能較為穩定的版本, 而 current 則是含有每日最新功能或修正的程序代碼.
如果您的操作系統是 FreeBSD, 而且您的 apache 是透過 pkg_add 方式安裝
恭喜您, 您的作業環境和 Open WebMail 發展小組是一樣的, 所以安裝手續非常的簡單
chmod 4555 /usr/bin/suidperl
cd /usr/local/www
tar -zxvBpf openwebmail-X.XX.tgz
/usr/local/www/cgi-bin/openwebmail/openwebmail-tool.pl --init
如果您的操作系統是 Linux RedHat 7.x/8.x/9.x, 而您想自己從 source 安裝的話
cd /var/www
tar -zxvBpf openwebmail-X.XX.tgz
mv data/openwebmail html/
rmdir data
cd /var/www/cgi-bin/openwebmail
修改 auth_
unix.pl
set variable $unix_passwdfile_encrypted to '/etc/shadow'
set variable $unix_passwdmkdb to 'none'
修改 /var/www/cgi-bin/openwebmail/etc/openwebmail.conf
set mailspooldir to '/var/spool/mail'
set ow_htmldir to '/var/www/html/openwebmail'
set ow_cgidir to '/var/www/cgi-bin/openwebmail'
set spellcheck to '/usr/bin/ispell'
/var/www/cgi-bin/openwebmail/openwebmail-tool.pl --init
將下列文字加到 /etc/logrotate.d/syslog 讓系統定期砍掉過去的 log
/var/log/openwebmail.log {
postrotate
/usr/bin/killall -HUP syslogd
endscript
}
注: 如果您的操作系統是Linux RedHat 6.2(CLE 0.9), 請用 /home/httpd 取代上述的 /var/www
注: 如果您的 Linux 是 Redhat, 建議參考由 Emir Litric 所寫的 RedHat-README.txt
如果您的操作系統是 Linux RedHat 7.x/8.x/9.x, 而您想快速安裝的話,您可以利用由 Thomas Chung 所准備的 redhat
安裝 Open WebMail 的 released rpm,請到 http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/release/ 找出版本最新的 released rpm
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/release/openwebmail-2.10-1.i386.rpm rpm -Uvh openwebmail-2.10-1.i386.rpm
如果您想要安裝最新的 current rpm (比 released rpm 新, 但是可能有
bug),請到 http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/daily-build/ 找出日期最新的 current rpm
wget http://turtle.ee.ncku.edu.tw/openwebmail/download/redhat/rpm/daily-build/openwebmail-2.10-20031002.i386.rpm
rpm -Uvh openwebmail-2.10-20031002.i386.rpm
/var/www/cgi-bin/openwebmail/openwebmail-tool.pl --init
如果您的操作系統是其它的 Unix, 配合 Apache首先找到您的 Apache data 和 cgi-bin 目錄的父目錄,以下我們以 /usr/local/apache/share 作例子,並假設 openwebmail-x.yy.tgz 放在 /tmp
cd /usr/local/apache/share
tar -zxvBpf openwebmail-x.yy.tgz
mv data/openwebmail h
tdocs/
rmdir data
modify /usr/local/apache/share/cgi-bin/openwebmail/etc/openwebmail.conf
將 mailspooldir 設成 您系統中的 mail spool, 一般是 /var/mail 或是 /var/spool/mail
將 ow_htmldir 設成 /usr/local/apache/share/htdocs
將 ow_cgidir 設成 /usr/local/apache/share/cgi-bin
修改 auth_unix.pl
將 $unix_passwdfile_encrypted 設成 '/etc/shadow'
將 $unix_passwdmkdb 設成 'none'
注: 各 Unix 平台改法不見得相同, 請參考 auth_unix.pl 中的說明, 以便得知確切的改法
cd /usr/local/apache/share/cgi-bin/openwebmail
修改所有 openwebmail*.pl 的 perl script, 包括
openwebmail.pl, openwebmail-main.pl,
openwebmail-read.pl, openwebmail-viewatt.pl,
openwebmail-send.pl, openwebmail-spell.pl,
openwebmail-prefs.pl, openwebmail-folder.pl,
openwebmail-abook.pl, openwebmail-advsearch.pl,
openwebmail-cal.pl and openwebmail-tool.pl
將 script 中第一行 #!/usr/bin/perl 改成 !您的 suidperl 所在的路徑
檢查您的 suidperl 程序的 mode, 看看是否是 r-sr-xr-x, 如果不是的話
chmod 4555 /usr/local/bin/suidperl
/usr/local/apache/share/cgi-bin/openwebmail/openwebmail-tool.pl --init
注: 如果您是在 Solaris 上安裝 Open WebMail, 請記得建立 /etc/openwebmail_path.conf 這個檔案.然後在其中放入您 openwebmail CGI 所在的路徑
如果 openwebmail.pl 位於
/usr/local/apache/share/cgi-bin/openwebmail/openwebmail.pl
那麼 /etc/openwebmail_path.conf 應該如下:
/usr/local/apache/share/cgi-bin/openwebmail
注: 如果您用的是 Apache 2.0 以後的版本, 請在 apache 的設定檔 httpd.conf 中, 將
AddDefaultCharset ISO-8859-1
改成
AddDefaultCharset off
設定 Open WebMail 系統 在 cgi-bin/openwebmail/etc 可以發現有 openwebmail.conf.default, openwebmail.conf.help 和 openwebmail.conf 這三個檔, 其中
openwebmail.conf.default - 內定的設定檔, 包含所有 Open WebMail 可以頂的選項
openwebmail.conf.help - openwebmail.conf.default 所有選項的說明文件
openwebmail.conf - 主要的設定檔, 管理者要設定的選項, 應該都寫在這個檔案裡頭, 而不應該直接去改 openwebmail.conf.default
openwebmail.conf 的內容
# Open WebMail configuration file
#
# This file contains just the overrides from openwebmail.conf.default
# please make all changes to this file.
#
# This file sets options for all domains and all users.
# To set options on per domain basis, please put them in sites.conf/domainname
# To set options on per user basis, please put them in users.conf/username
#
domainnames auto
auth_module auth_unix.pl
mailspooldir /var/mail
dbm_ext .db
dbmopen_ext none
dbmopen_haslock no
ow_cgidir /usr/local/www/cgi-bin/openwebmail
ow_cgiurl /cgi-bin/openwebmail
ow_htmldir /usr/local/www/data/openwebmail
ow_htmlurl /openwebmail
logfile /var/log/openwebmail.log
spellcheck /usr/local/bin/ispell
default_language en
<default_signature>
--
Open WebMail Project (http://openwebmail.org)
</default_signature>
以上的內容可能隨著您系統而有所不同, 不過在您完成前述的安裝後, 您可以修改以下幾個選項
domainnames
一般情況下, openwebmail 應該能正確地判斷出您 server 的 domainname, 進而正確地設定使用者的預設 Email address, 但如果發生 openwebmail 判斷錯誤或是您希望設定成其它的 domainname, 你可以將這個選項由 auto 改成您所要的 domainname, 如 mail.myserver.com.tw
spellcheck
設定拼字檢查程序所在的路徑, 一般而言, 可能是以下其中之一, 您可以用 ls -l filename 方式檢查看看
/usr/bin/apsell
/usr/bin/ispell
/usr/local/bin/aspell
/usr/local/bin/ispell
default_language
內定的語言, 我們把它由 en(英文) 改成 zh_TW.Big5 (繁體中文)
注: 自 2.0 版 20030416 以後, 已經不需要在 openwebmail.conf 中設定 default_language 這個選項了, openwebmail 會根據使用者所用的浏覽器設定, 自動選擇適合的內定的語言
default_signature
設定預設的簽名檔, 設在這裡的值會成為每個新使用者的預設簽名檔, 不過使用時每個使用者可以依自己的需求, 設定成其它的內容
初始化 Open WebMail
在前面的安裝步驟裡頭, 最後一個步驟是
cd the_direcotry_of_openwebmail_cgi_scripts
./openwebmail-tool.pl --init
這個動作會建立一些 Open WebMail 在執行時會用到的對應表, 如簡繁轉換, 陰陽歷轉換等. 如果這個動作沒有做的話, 使用者將無法透過 Web 界面使用 Open WebMail
而由於在各種不同操作系統上的 perl 版本的差異, 其所使用的 dbm 種類也不盡相同, 有的可能需要特殊的設定後才能使用, --init 在建立上述對應表之前, 會測試系統上 perl 的 dbm 種類, 並且提供一些必要的建議事項
首先會檢查 openwebmail.conf 中的 dbm_ext, dbmopen_ext 和 dbmopen_haslock 三個選項的設定是否正確, 如果設定有誤的話, 您會看到如下的畫面
Please change the following 3 options in openwebmail.conf
from
dbm_ext .db
dbmopen_ext none
dbmopen_haslock no
to
dbm_ext .db
dbmopen_ext %dbm_ext%
dbmopen_haslock yes
其次是檢查系統上的 dbm 是否內定使用 DB_File.pm 這個模塊, 如果是而且有需要的話, 會建議您對 DB_File.pm 作一些必要的修改 (這個修改是由 DB_File.pm 作者所提供的), 您會看到如下畫面
Please modify /usr/libdata/perl/5.00503/mach/DB_File.pm by adding
$arg[3] = 0666 unless defined $arg[3];
before the following text (about line 247)
# make recno in Berkeley DB version 2 work like recno in version 1
請務必依照以上的建議作修改, 否則您的 Open WebMail 可能會無法完全正常動作, 也請記得在做完修改之後, 別忘了重新執行一次 './openwebmail-tool.pl --init'