跳到主要內容

使用mod_rewrite將php及變數改為顯示html的教學

由於客戶網站SEO優化需要,需要吧原本網站的PHP檔名及帶有變數的PHP網都址改成html,以利搜尋引擎優先排序,所以需要做一下的設定工作。

1、如果是自己架的xampp伺服器需要找到httpd.conf檔案,用筆記本打開
xampp\apache\conf\httpd.conf
搜尋以下的設定
LoadModule rewrite_module modules/mod_rewrite.so

如果前面有#號吧#拿掉即可,這樣就啟用mod_rewrite功能了,如果是租虛擬主機大部分的mod_rewrite都是啟用的,如果沒有啟用可以寫信請主機商開啟這項設定即可。


2、找到需要轉換成.html的模組資料夾,例如我們需吧

http://test.com/modules/news/index.php的php都顯示為html,那就在news資料夾中建立一個.htaccess檔,然後用筆記本打開編輯

假設我們要吧
http://test.com/modules/news/index.php 讓他顯示為 http://test.com/modules/news/index.html
可以在.htaccess中輸入
RewriteEngine on
RewriteBase /modules/news 
RewriteRule ^index.html index.php 

其中的RewriteBase 是檔案的位置,如果是根目錄就輸入
RewriteBase /

即可,完成設定後儲存,當然如果就這樣更新瀏覽器是沒用的,還是會顯示http://test.com/modules/news/index.php,必須手動輸入 http://test.com/modules/news/index.html,如果有出現網站內容就表示設定成功了,mod_rewrite已經吧index.php檔名改成index.html 了。

3、如果是遇到有帶變數的的網址,例如http://test.com/modules/news/view.php?id=1,可以這樣設定
RewriteEngine on
RewriteBase /modules/news
RewriteRule ^view-([0-9]+)\.html$ view.php?id=$1
這樣就會顯示為

http://test.com/modules/news/view-1.html

如果是帶兩個或多個變數的網址,例如
http://test.com/modules/news/view.php?id=1&cat_id=2
可以這樣設定
RewriteEngine on
RewriteBase /modules/news
RewriteRule ^view-([0-9]+)page([0-9]+)\.html$ view.php?id=$1&cat_id=$2 [PT]

這樣就會顯示為

http://test/modules/news/view-1page2.html

4、如果不是數字的變數,而是英文字或是加上數字組合成的變數,例如像是這樣的
http://test.com/index.php?sid=center

可以這樣設定,輸入

RewriteEngine on
RewriteBase /
RewriteRule ^index-([a-zA-Z0-9_-]+)\.html$ index.php?sid=$1

就會顯示為

http://test.com/index-center.html

5、設定好.htaccess之後,雖然網址是可以顯示為.html的但還需要修改網站的按鈕與連結,包括php迴圈產生的網址,全部改成.html才行,例如以下為一個Xoops的模組tpl所帶出的變數網址。
 <{foreach item=item from=$block key=key}>
<a  href="<{xoAppUrl /}>modules/news/view.php?id=<{$item.hid}>""><{$item.name}>
             </a>
 <{/foreach}>    
原本是會產生
view.php?id=1
view.php?id=2
view.php?id=3
view.php?id=4
view.php?id=5

php的動態網址,所以需要修改為

 <{foreach item=item from=$block key=key}>
<a  href="<{xoAppUrl /}>modules/news/view-<{$item.hid}>.html""><{$item.name}>
             </a>
 <{/foreach}>      

這樣連結就會顯示為
view-1.html
view-2.html
view-3.html
view-4.html
view-5.html
以達到製作偽.html頁面的目的,如果檔案是包在php裡面沒輸出樣板,也是一樣的修改方法,在迴圈中吧變數改網址加上.html即可。


教學撰寫  徐嘉裕  Neil hsu

留言

這個網誌中的熱門文章

好用的windows備份檔案dos指令XCOPY-教學撰寫:徐嘉裕Neil hsu

要快速的備份某個硬碟全部資料到備份硬碟中,雖然是可以用windows內建的備份與還原,但如果重灌windows可會有key不同而無法還原的問題,還要改一堆設定煩死了,直接用dos指令XCOPY來做檔案的複製就很快了,資料也不會丟失,好朋友可以參考看看!! 首先開啟windows所有程式->附屬應用程式->開啟命令提示字元! 然後輸入以下指令 XCOPY C:\xxx   F:\xxx /s 藍字的 C:\xxx  為複製檔案來源位置例如要複製整個C槽就輸入 C:\ 綠色的   F:\xxx 為複製目的位置,例如要放到F槽的備份資料夾,就輸入  F:\ 備份 紅字的 S 為複製類型參數,可以自行修改為以下的參數設定: ================================================================= /A    只複製設定成保存屬性的檔案,不要改變屬性的設定。 /M    只複製設定成保存屬性的檔案,並清除保存屬性。 /D:m-d-y  複製指定日期當天或之後變更的檔案。如果沒給日期,只複製那些來源檔案日期比目的檔案日期為新的檔案。 /EXCLUDE:file1[+file2][+file3]...         指定檔案清單字串。每個字串應在不同行。如果有字串對應到要進行複製的檔案絕         對路徑的任何部分,這個檔案會被排除複製。例如,指定字串         \obj\ 或 .obj 的話,會排除所有在 obj 目錄下副檔名是.obj 的檔案複製。 /P    在建立每個目的檔案時顯示提示。 /S    複製每個目錄及其包含的子目錄,不複製空目錄。 /E    複製每個目錄及其包含的子目錄,也複製空目錄。/S 與 /E相同,能夠用來修改 /T。 /V   ...

jQuery取得下拉選單selected中數值與內容的方法

假設選單狀態為: <select id='selectname '> <option value='v1' data-id="d1">選單A</option> <option value='v2' data-id="d2">選單B</option> <option value='v3' data-id="d3">選單C</option> </select> 以jQuery取得選單數值與內容方法如下: 1、取得下拉選單 value 數值的方法 $selectname=$('#selectname').val(); alert($selectname); //顯示選單中 selected 狀態的value數值v1 or  v2  or  v3。 2、取得下拉選單中 data-id 數值的方法 $data-id= $(this).find(':selected').attr('data-id'); alert($data-id); //顯示選單中 selected 狀態的data-id數值d1 or  d2 or  d3。 3、取得下拉選單中 文字 的方法 $selecttext=$(this).find(':selected').text(); alert($selecttext); //顯示選單中 selected 狀態的文字內容,如選單A or  選單B or 選單C。 教學撰寫:徐嘉裕 Neil hsu

PhpSpreadsheet電子表格PHP匯出excel排版範例->Xoops-教學撰寫:徐嘉裕Neil hsu

在開發模組時如果要吧資料表內容匯出excel,最常用的套件因該就是PHPExcel,但是官網已經說明PHPExcel套件因升級不易只能支援到php5.6, 該物件已於2017年正式棄用,並於2019年永久歸檔 ,換句話說PHPExcel套件對於日後新版的excel格式均不支援,為保持程式在最新狀態只好棄用PHPExcel改使用PhpSpreadsheet電子表格套件,該套件也是能匯出excel,還能匯出LibreOffice Calc,感覺還不錯! 唯一比較麻煩的是使用PhpSpreadsheet要先佈署composer,如果沒佈署composer是沒辦法使用的,還好官方有釋出已經設定好的phpoffice套件可以直接引入使用,省了很多麻煩,使用PhpSpreadsheet方法如下: 1、先下載PhpSpreadsheet套件,我已經幫大家吧phpoffice一起打包上傳 https://drive.google.com/file/d/1jw73diWVjbcr1ycY-gtqM2cGfpLp1zS_/view?usp=sharing 下載回來後解壓縮吧phpoffice跟PhpSpreadsheet丟到Xoops模組的class資料夾中,未來如需更新PhpSpreadsheet可到官網下載最新版覆蓋即可 https://github.com/PHPOffice/PhpSpreadsheet 2、然後建立一個excel.php放在模組根目錄中 以下為編排excel表格常用的函數設定 include_once "header.php"; //先引入autoload.php檔 include_once XOOPS_ROOT_PATH.'/modules/ 模組ID /class/phpoffice/vendor/autoload.php'; use PhpOffice\PhpSpreadsheet\Spreadsheet; use PhpOffice\PhpSpreadsheet\IOFactory; $spreadsheet = new Spreadsheet(); //實體化Excel工作表 //設置電子表格元數據的操作: $spreadsheet->getProperties() ->setCreator...