openwebmail 安装

阅读更多

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-3.05.tar.gz (必要)
  • MIME-Base64-3.01.tar.gz (必要)
  • Digest-1.08.tar.gz (必要)
  • Digest-MD5-2.33.tar.gz (必要)
  • libnet-1.19.tar.gz (必要)
  • Text-Iconv-1.2.tar.gz (必要)
  • libiconv-1.9.1.tar.gz ( 可選擇 , 多國語言內碼轉換 )
  • CGI-SpeedyCGI-2.22.tar.gz (可選擇, 常駐執行)
  • Compress-Zlib-1.33.tar.gz (可選擇, 網頁壓縮)
  • ispell-3.1.20.tar.gz (可選擇, 拼字檢查)
  • Quota-1.4.10.tar.gz (可選擇, Quota control)
  • Authen-PAM-0.14.tar.gz (可選擇, 外掛式認證)
  • ImageMagick-5.5.3.tar.gz (可選擇, 縮圖製作)
  • tnef-1.2.3.1.tar.gz (可選擇, MS-Tnef 支援)
  • antiword-0.35.tar.gz (可選擇, MSWord 檔預覽)
  • openssl-0.9.7d.tar.gz (可選擇, POP3 的 SSL 支援, 若系統有 libssl 則不需要)
  • Net_SSLeay.pm-1.25.tar.gz (可選擇, POP3 的 SSL 支援)
  • IO-Socket-SSL-0.96.tar.gz (可選擇, POP3 的 SSL 支援)
  • clamav-0.70.tar.gz (可選擇, 病毒信掃描)
  • Mail-SpamAssassin-2.63.tar.gz (可選擇, 垃圾信判讀/學習)

以上的套件, 一般來說是透過 source 安裝, 但如果您用的是 RedHat Linux, 那也有 rpm 可以快速安裝

 

安裝套件 (由 source 安裝)

首先請先到 http://turtle.ee.ncku.edu.tw/openwebmail/download/packages/ 下載上述的各個套件

安裝 CGI.pm 套件

cd /tmp
tar -zxvf CGI.pm-3.05.tar.gz
cd CGI.pm-3.05
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-3.01.tar.gz
cd MIME-Base64-3.01
perl Makefile.PL
make
make install

; 雖然您的機器可能已經安裝了 MIME-Base64 這個套件 , 還是建議您從 source 重新裝一次 . 這樣做的話 , 可以確定 MIME-Base64 中的 XS 支援有被啟動 , 可以大幅地增加處理 MIME 附件編碼與解碼的速度


安裝 libnet 套件

cd /tmp
tar -zxvf libnet-1.19.tar.gz
cd libnet-1.19
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-8) 的轉換), 這個轉換的動作是透過 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 設定有誤. 您可以將 misc/patches/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/

  1. 首先是安裝 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)

  1. 接著檢查您的系統是否有裝 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

  1. 接著是檢查您的系統是否有裝 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/release/ 下可以下載 Open WebMail 的各個 Release (openwebmail-x.yy.tar.gz), 這是屬於經過測試後, 功能較為穩定的版本. 而在 http://turtle.ee.ncku.edu.tw/openwebmail/download/current/ 下的 openwebmail-current.tar.gz 則是含有最新功能或修正, 但是沒有經過詳細的測試的程式碼. 至於 http://turtle.ee.ncku.edu.tw/openwebmail/download/snapshot/ 是擺放 current 的每日快照版本, 主要是為了方便追蹤每天程式碼變動的 current 的快照版本

如果您的作業系統是 FreeBSD, 而且您的 apache 是透過 pkg_add 方式安裝

恭喜您 , 您的作業環境和 Open WebMail 發展小組是一樣的 , 所以安裝手續非常的簡單

  1. chmod 4555 /usr/bin/suidperl
  2. cd /usr/local/www
    tar -zxvBpf openwebmail-X.XX.tar.gz
  3. /usr/local/www/cgi-bin/openwebmail/openwebmail-tool.pl --init


註: 透過FreeBSD 本身的 PORTS, 可以很方便地安裝 Open WebMail,

cd /usr/ports/mail/openwebmail
make install clean

如果您的作業系統是 Linux RedHat 7.x/8.x/9.x, 而您想自己從 source 安裝的話

  1. cd /var/www
    tar -zxvBpf openwebmail-X.XX.tar.gz
    mv data/openwebmail html/
    rmdir data
  2. cd /var/www/cgi-bin/openwebmail
    修改 etc/auth_unix.conf (由 etc/defaults/auth_unix.conf copy 過來改)
    1. passwdfile_encrypted 設成 /etc/shadow
    2. passwdmkdb 設成 none
  3. 修改 etc/openwebmail.conf
    1. mailspooldir 設成 /var/spool/mail
    2. ow_htmldir 設成 /var/www/html/openwebmail
      將 ow_cgidir 設成 /var/www/cgi-bin/openwebmail
    3. spellcheck 設成 /usr/bin/ispell
  4. /var/www/cgi-bin/openwebmail/openwebmail-tool.pl --init
  5. 將下列文字加到 /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

  1. 安裝 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
  2. /var/www/cgi-bin/openwebmail/openwebmail-tool.pl --init

如果您的作業系統是其他的 Unix, 配合 Apache

  1. 首先找到您的 Apache data 和 cgi-bin 目錄的父目錄,
    以下我們以 /usr/local/apache/share 作例子,
    並假設 openwebmail-x.yy.tar.gz 放在 /tmp
  2. cd /usr/local/apache/share
    tar -zxvBpf openwebmail-x.yy.tar.gz
    mv data/openwebmail htdocs/
    rmdir data
  3. cd /usr/local/apache/share/cgi-bin/openwebmail/
    修改 etc/openwebmail.conf
    1. mailspooldir 設成 您系統中的 mail spool, 一般是 /var/mail 或是 /var/spool/mail
    2. ow_htmldir 設成 /usr/local/apache/share/htdocs
      將 ow_cgidir 設成 /usr/local/apache/share/cgi-bin
  4. 修改 etc/auth_unix.conf (由 etc/defaults/auth_unix.conf copy 過來改)
    1. passwdfile_encrypted 設成 '/etc/shadow'
    2. passwdmkdb 設成 'none'

: 各 Unix 平台改法不見得相同, 請參考 defaults/auth_unix.conf 中的說明, 以便得知確切的改法

  1. 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/suidperl 改成 !您的 suidperl 所在的路徑

  1. 檢查您的 suidperl 程式的 mode, 看看是否是 r-sr-xr-x, 如果不是的話

    chmod 4555 /usr/local/bin/suidperl
  2. /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 可以發現有 defaults/openwebmail.conf, openwebmail.conf.help 和 openwebmail.conf 這三個檔, 其中

defaults/openwebmail.conf - 內定的 Open WebMail 設定檔, 包含所有可以設定的選項
openwebmail.conf.help - defaults/openwebmail.conf 所有選項的說明檔
openwebmail.conf - 主要的設定檔, 管理者要設定的選項, 應該都寫在這個檔案裡頭, 而不應該直接去改 defaults/openwebmail.conf

openwebmail.conf 的內容

# Open WebMail configuration file
#
# This file contains just the overrides from defaults/openwebmail.conf
# 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
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

enable_viruscheck no
enable_spamcheck no
enable_learnspam no

default_language en

smtp


--
Open WebMail Project (http://openwebmail.org)

以上的內容可能隨著您系統而有所不同 , 不過在您完成前述的安裝後 , 您可以修改以下幾個選項

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

enable_viruscheck

是否呼叫外部程式進行病毒掃描, 預設是 no, 這個功能需要在系統上先安裝 ClamAV 這套軟體

enable_spamcheck

是否呼叫外部程式進行垃圾信判讀, 預設是 no, 這個功能需要在系統上先安裝 SpamAssassin 這套軟體

enable_learnspam

是否呼叫外部程式進行垃圾信學習, 預設是 no, 通常這個功能與 enable_spamcheck 要互相配合, 因為學習所得到資料庫將會在 spamcheck 進行垃圾信判讀時被參考

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 種類 , 並且提供一些必要的建議事項

  1. 首先會檢查 etc/dbm.conf 中的 dbm_ext, dbmopen_ext 和 dbmopen_haslock 三個選項的設定是否正確, 如果設定有誤的話, 您會看到如下的畫面

    Please change the following 3 options in etc/dbm.conf

    from

    dbm_ext .db
    dbmopen_ext none
    dbmopen_haslock no


    to

    dbm_ext .db
    dbmopen_ext %dbm_ext%
    dbmopen_haslock yes


    管理者可以將 etc/defaults/dbm.conf copy 成 dbm.conf, 然後將正確的 dbm 設定值, 寫到 etc/dbm.conf 中
  2. 其次是檢查系統上的 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'

 

測試 Open WebMail

在完成上面的步驟後, 您可以連線到

http://your_server_hostname/cgi-bin/openwebmail/openwebmail.pl

並且登入看看是否一切正常

Sendmail.cf 的修改

為了安全的考量, 某些系統上的 sendmail.cf 內定只聽在 127.0.0.1 這個 IP, 所以 sendmail 只接受 local 的連線 (即 local 的程式可以送信出去), 但是卻無法接收 remote 端的連線(即無法接受 remote 送來的信件). 如果您的機器發生這樣的情形, 解決步驟如下:

  1.  

你可能感兴趣的:(RedHat,Perl,CGI,EXT,Linux)