如果 客 戶 紛 紛 要 求 將 Asp的 站 點(diǎn) 國 際 化 以 提 供 多 種 語 言 版 本 ,這個(gè)問題如何實(shí)現(xiàn)呢? 該 問 題 的 關(guān) 鍵 在 于 , 你 必 須 使 用 某 種 方 法 實(shí) 現(xiàn) 快 速 的 頁 面 內(nèi) 容 轉(zhuǎn) 換 。 可 以 將 此 問 題 看 成 是 從 數(shù) 據(jù) 庫 提 取 適 當(dāng) 數(shù) 據(jù) 并 用 ASP 動(dòng) 態(tài) 顯 示 。 在 本 文 中 我 們 將 討 論 如 何 使 用 Active Server Pages 的 字 典 對(duì) 象 以 及 一 個(gè) 后 臺(tái) 數(shù) 據(jù) 庫 實(shí) 現(xiàn) 國 際 化 支 持 。
具 體 實(shí) 現(xiàn) 過 程 分 以 下 三 個(gè) 步 驟 :
◇ 設(shè) 計(jì) 數(shù) 據(jù) 庫 并 存 儲(chǔ) 文 本 和 文 件 路 徑 。
◇ 從 數(shù) 據(jù) 庫 讀 取 數(shù) 據(jù) 到 字 典 對(duì) 象 。
◇ 在 ASP 頁 面 引 用 文 本 和 文 件 路 徑 。
二 、 步 驟 1 – 設(shè) 計(jì) 數(shù) 據(jù) 庫 并 存 儲(chǔ) 文 本 和 文 件 路 徑
我 們 需 要 在 數(shù) 據(jù) 庫 設(shè) 計(jì) 上 花 些 時(shí) 間 。 使 用 此 數(shù) 據(jù) 庫 , 我 們 希 望 能 夠 把 所 有 要 用 到 的 文 本 和 圖 片 適 當(dāng) 編 目 , 并 且 這 些 文 本 和 圖 片 不 能 重 復(fù) ; 如 果 要 在 應(yīng) 用 中 把“ 是 ” 改 成 “ 確 定 ” , 希 望 只 在 一 個(gè) 地 方 作 改 動(dòng) ; Web 維 護(hù) 者 在 更 改 內(nèi) 容 時(shí) 應(yīng) 能 夠 快 速 找 到 目 標(biāo) 文 本 。 基 于 以 上 要 求 , 讓 我 們 開 始 設(shè) 計(jì) 數(shù) 據(jù) 庫 。
首 先 創(chuàng) 建 兩 個(gè) 表 來 放 置 文 本 。 其 中 一 個(gè) 表 為 CommonStrings , 用 于 存 放 在 整 個(gè) 站 點(diǎn) 重 復(fù) 使 用 的 單 詞 和 短 語 。 另 外 一 個(gè) 表 為 SpecializedStrings , 用 于 存 放 只 在 特 定 頁 面 使 用 的 單 詞 和 短 語 。 把 公 用 和 限 于 特 定 頁 面 使 用 的 文 本 分 別 存 放 有 利 于 簡 化 站 點(diǎn) 維 護(hù) 。
兩 個(gè) 表 都 使 用 StringKey 字 段 來 標(biāo) 記 紀(jì) 錄 , 使 用 StringLanguage 來 說 明 所 用 語 言 , 聯(lián) 合 StringKey 和 StringLanguage 創(chuàng) 建 一 個(gè) 主 鍵 。 字 段 StringHolder 用 來 保 存 單 詞 、 短 語 或 語 句 。 這 個(gè) 字 段 必 須 創(chuàng) 建 唯 一 索 引 以 保 證 不 會(huì) 輸 入 重 復(fù) 的 單 詞 、 短 語 或 語 句 。
對(duì) 于 SpecializedStrings 表 , 還 需 要 一 個(gè) 額 外 的 字 段 ASPPage 來 標(biāo) 記 文 本 所 在 的 ASP 頁 面 。
對(duì) 于 圖 片 文 件 , 我 們 可 以 使 用 相 同 的 步 驟 創(chuàng) 建 表 來 存 儲(chǔ) 指 向 這 些 文 件 的 路 徑 。 只 需 要 在 CommonImage 表 和 SpecializedImage 表 中 用 FileName 字 段 替 換 對(duì) 應(yīng) 的 StringHolder 就 可 以 了 。
在 新 創(chuàng) 建 的 表 中 裝 入 數(shù) 據(jù) 時(shí) , StringKey 的 內(nèi) 容 應(yīng) 該 給 站 點(diǎn) 維 護(hù) 者 盡 可 能 多 的 提 示 以 表 明 頁 面 上 將 顯 示 的 文 本 。 例 如 , 對(duì) 于 一 個(gè) 在 線 銷 售 站 點(diǎn) 來 說 有 關(guān) 拒 絕 承 諾 的 聲 明 語 句 使 用 OrderDisclaimer 是 一 個(gè) 不 錯(cuò) 的 選 擇 , 站 點(diǎn) 維 護(hù) 者 由 此 可 以 非 常 清 楚 地 了 解 使 用 該 記 錄 將 在 Web 頁 面 上 顯 示 的 內(nèi) 容 。
把 那 些 公 用 的 單 詞 和 短 語 放 在 CommonStrings 表 。 這 樣 , 維 護(hù) 者 就 知 道 如 果 他 們 修 改 CommonStrings 表 中 的 一 個(gè) 記 錄 , 將 影 響 到 站 點(diǎn) 內(nèi) 的 許 多 頁 面 。
對(duì) 于 大 的 站 點(diǎn) , 可 以 設(shè) 計(jì) 一 個(gè) 易 于 使 用 的 界 面 來 輸 入 和 修 改 數(shù) 據(jù) 庫 中 的 文 本 。 準(zhǔn) 備 這 些 資 料 是 一 項(xiàng) 冗 長 乏 味 的 任 務(wù) , 越 簡 單 就 越 少 出 錯(cuò) 。
三 、 步 驟 2 – 從 數(shù) 據(jù) 庫 讀 取 數(shù) 據(jù) 到 字 典 對(duì) 象
字 典 對(duì) 象 ( Dictionary Object ) 是 一 個(gè) 多 用 途 的 服 務(wù) 器 端 對(duì) 象 , 它 相 當(dāng) 于 二 維 數(shù) 組 , 保 存 了 鍵 以 及 與 鍵 相 關(guān) 聯(lián) 的 數(shù) 據(jù) 。 提 取 數(shù) 據(jù) 的 唯 一 途 徑 在 于 取 得 鍵 值 或 索 引 。 可 以 把 字 典 對(duì) 象 的 作 用 范 圍 配 置 為 整 個(gè) 應(yīng) 用 范 圍 或 對(duì) 話 范 圍 , 而 不 必 擔(dān) 心 損 失 性 能 。 賦 予 應(yīng) 用 層 作 用 范 圍 意 味 著 對(duì) 象 只 被 實(shí) 例 化 一 次 , 且 所 有 會(huì) 話 均 使 用 同 一 個(gè) 字 典 對(duì) 象 。 以 下 代 碼 創(chuàng) 建 兩 個(gè) 字 典 對(duì) 象 實(shí) 例 , 分 別 和 兩 個(gè) 文 本 表 關(guān) 聯(lián) 。 記 住 , 我 們 希 望 對(duì) 象 只 被 初 始 化 一 次 , 所 以 把 這 些 代 碼 放 在 Application_OnStart 事 件 中 :
< Script RUNAT=SERVER Language=VBScript>
Sub Application_OnStart()
Dim DictCommonStrings
Dim DictSpecializedStrings
Dim Conn
Dim rsCommonStrings
Dim rsSpecializedStrings
Set DictCommonStrings = Server.CreateObject(“Scripting.Dictionary”)
Set DictSpecializedStrings = Server.CreateObject(“Scripting.Dictionary”)
接 下 來 的 任 務(wù) 是 把 數(shù) 據(jù) 裝 入 字 典 對(duì) 象 。 我 們 將 遍 歷 表 , 連 接 StringKey 和 StringLanguage , 并 把 連 接 后 的 值 作 為 字 典 的 鍵 值 , 把 StringHolder 放 在 對(duì) 應(yīng) 的 字 典 數(shù) 據(jù) 區(qū) 。 由 此 我 們 獲 得 了 使 用 數(shù) 據(jù) 庫 存 儲(chǔ) 數(shù) 據(jù) 的 彈 性 , 并 避 免 了 持 久 的 數(shù) 據(jù) 庫 連 接 而 導(dǎo) 致 的 性 能 影 響 。 事 實(shí) 上 , 數(shù) 據(jù) 庫 只 在 應(yīng) 用 啟 動(dòng) 時(shí) 被 訪 問 一 次 , 其 后 ASP 頁 面 將 從 速 度 更 快 的 字 典 對(duì) 象 讀 取 所 需 數(shù) 據(jù) 。
‘建立數(shù)據(jù)庫連接
Set Conn = Server. CreateObject(“ADODB.Connection”)
Conn.ConnectionString = “Some Connection String”
Conn.open
‘打開 CommonStrings 表, 遍歷所有記錄并裝入數(shù)據(jù)
Set rsCommonStrings = Conn.Execute(“Select StringKey, StringHolder from CommonStrings”)
Do until rsCommonStrings.EOF
DictCommonStrings.Add rsCommonStrings(“StringLanguage”) & rsCommonStrings(“StringKey”) _
,rsCommonStrings(“StringHolder”)
rsCommonStrings.MoveNext
Loop
‘打開SpecializedStrings表, 遍歷所有記錄并裝入數(shù)據(jù)
Set rsSpecializedStrings = Conn.Execute(“Select StringKey, StringHolder from SpecializedStrings”)
Do until rsSpecializedStrings.EOF
DictSpecializedStrings.Add rsSpecializedStrings (“StringLanguage”) & _
rsSpecializedStrings (“StringKey”) , rsSpecializedStrings (“StringHolder”)
rsSpecializedStrings.MoveNext
Loop
rsSpecializedStrings.Close
rsCommonStrings.Close
Conn.Close
Set rsSpecializedStrings = Nothing
Set rsCommonStrings = Nothing
Set Conn = Nothing
End Sub
< /Script>