海南苯概企业管理有限公司

0712-2888027 189-8648-0214
微信公眾號

孝感風信網(wǎng)絡(luò)科技有限公司微信公眾號

當前位置:主頁 > 技術(shù)支持 > Linux > nginx不支持.htaccess解決辦法

nginx不支持.htaccess解決辦法

時間:2016-03-24來源:風信官網(wǎng) 點擊: 964次
Dedecms網(wǎng)站該如何移動化?得分幾步?近日,站長學院分享了一篇關(guān)于Dedecms網(wǎng)站移動化的文章,據(jù)該文章表示,Dedecms網(wǎng)站移動化只需五步便可搞定!他是如何做到的呢?

文/洪石陳

第一步:安裝Dedecms移動站點的兩種方式

(1)下載新版本直接安裝使用,Dedecms版本:V5.7SP1正式版(2015-06-18)該版本包含舊版本所沒有的移動站點功能。

(2)老版本升級(僅針對增加移動站點功能),下載最新版本(注意網(wǎng)站編碼需與原站一致),復制壓縮包中以下文件到原站對應(yīng)目錄下:

Dedecms網(wǎng)站 Dedecms網(wǎng)站移動化 網(wǎng)站移動化 網(wǎng)站優(yōu)化

注意:

如果原站有非默認模板,如某欄目模板為/templets/defaultst_default_news.htm,可將/templets/defaultst_default_m.htm復制一份改名為list_default_news _m.htm。

即:pc端網(wǎng)站模板需有對應(yīng)的移動端網(wǎng)站模板,后者文件名為前者文件名后“_m”。

安裝或升級dedecms完成,此時應(yīng)該就可以進行移動跳轉(zhuǎn)適配了,但,dedecms 20150618版本提供的移動站點功能在使用過程中發(fā)現(xiàn)一些問題,需要進行修改后才可正常使用,所以有了下面的dedecms修改步驟…

第二步:修改Dedecms

(1)原站如做了將DATA移到根目錄外的安全設(shè)置,需修改/m/index.php代碼:

  • if(!file_exists(dirname(__FILE__).'/../data/common.inc.php'))
  • {
  • header('Location:install/index.php');
  • exit();
  • }

將其中/../data/common.inc.php改為/../../data/common.inc.php,或直接將以上5行代碼刪除。

(2) 移動站點首頁在會第一次訪問時自動生成首頁靜態(tài)文件,前提是/m/目錄需設(shè)置為可寫權(quán)限,否則將無法正常更新。之后更新首頁靜態(tài)文件需登陸后臺手動更新: 在“更新主頁HTML”中將“選擇主頁模板”改為“default/index_m.htm”,將“主頁位置”改為“../m/index.html”, 再生成主頁靜態(tài)文件。

Dedecms網(wǎng)站 Dedecms網(wǎng)站移動化 網(wǎng)站移動化 網(wǎng)站優(yōu)化

注:該版本號稱“自動生成HTML版”,但默認移動站模板里卻有<a href="index.php">的動態(tài)首頁鏈接,需替換為<a href="index.html">靜態(tài)鏈接形式。

※如覺得使用靜態(tài)頁面麻煩,想將首頁設(shè)置為動態(tài)瀏覽,可修改/m/index.php:

  • $row['showmod'] = isset($row['showmod'])? $row['showmod'] : 0;
  • if ($row['showmod'] == 1)
  • {
  • $pv->SaveToHtml(dirname(__FILE__).'/index.html');
  • include(dirname(__FILE__).'/index.html');
  • exit();
  • } else {
  • $pv->Display();
  • exit();
  • }

以上代碼替換為一行:

  • $pv->Display();

第三步:首頁“圖文資訊”部分的url為pc端鏈接,修改為移動端鏈接:

搜索模板/templets/default/index_m.htm中所有<a href="[field:arcurl/]"> ,替換為<a href="view.php?aid=[field:id/]">

第四步:通用頭部含有搜索框,搜索跳轉(zhuǎn)至pc端搜索頁面,建議刪除:

在/templets/default/header_m.htm中刪除以下代碼:

  • <form class="am-topbar-form am-topbar-left am-form-inline am-topbar-right" role="search" action="{dede:global.cfg_cmsurl/}/plus/search.php">
  • <input type="hidden" name="mobile" value="1" />
  • <input type="hidden" name="kwtype" value="0" />
  • <div class="am-form-group">
  • <input name="q" type="text" class="am-form-field am-input-sm" placeholder="輸入關(guān)鍵詞">
  • </div>
  • <button type="submit" class="am-btn am-btn-default am-btn-sm">搜索</button>
  • </form>

第五步: 移動站點默認使用二級目錄,但目前移動適配需要使用二級域名(前段時間是可以使用二級目錄的,但目前已調(diào)整,不能再提交二級目錄),所以我們要設(shè)置移動站可通過二級域名訪問,解析二級域名至網(wǎng)站所在服務(wù)器ip,并在服務(wù)器/空間上將二級域名綁定到/m/目錄。

成功設(shè)置二級域名后,通過二級域名瀏覽網(wǎng)站會發(fā)現(xiàn)圖片均無法顯示,原因是圖片路徑有誤——圖片路徑為“/uploads/x/y.jpg”

相對根目錄路徑形式,在pc站頁面中顯示正常,因為pc站域名下存在該目錄,而二級域名綁定的是二級目錄,其中并不存在該目錄,

所以訪問圖片會返回 404錯誤。對此,有多種解決方案,下面提供兩個思路(示例pc站:www.nt090.com ;移動站:m.nt090.com):

(1)URL 重寫(推薦

將對http://m.nt090.com/uploads/的訪問重寫 至http://www.nt090.com/uploads/,apache環(huán)境下,在/m/目錄中的.htaccess(如無則需新建)中增加以下代碼即可:

  • RewriteEngine on
  • RewriteCond %{http_host} ^m.nt090.com [NC]
  • RewriteRule ^uploads/(.*)$ http://www.nt090.com/uploads/$1 [L]

iis環(huán)境下類似規(guī)則。

(2)修改模板路徑

在所有移動端模板中的<head></head>中增加:

<base href="http://www.nt090.com" />

再將代碼中的

“<a href="list.php”改為完整路徑“<a href=" http://m.nt090.com/list.php”

“<a href="viewphp”改為完整路徑“<a href=" http://m.nt090.com/view.php”

另:需將根目錄下的/images/defaultpic.gif(縮略圖默認圖片)復制到/m/目錄下,否則列表頁中如存在無縮略圖的文章,對應(yīng)縮略圖位置會無法正常顯示圖片。

其他:

1、如有欄目不想在首頁下方列表區(qū)域或通用頭部顯示,可在后臺對應(yīng)的欄目管理/常規(guī)選項中設(shè)置隱藏。

2、為了更好的實現(xiàn)pc端和移動端匹配效果,可在pc端模板增加類似如下代碼:

首頁

  • <meta http-equiv="mobile-agent" content="format=xhtml;url={dede:global.cfg_mobileurl/}/">
  • <script type="text/javascript">
  • if(window.location.toString().indexOf('pref=padindex') != -1){}else{if(/AppleWebKit.*Mobile/i.test(navigator.userAgent) || (/MIDP|SymbianOS|NOKIA|SAMSUNG|LG|NEC|TCL|Alcatel|BIRD|DBTEL|Dopod|PHILIPS|HAIER|LENOVO|MOT-|Nokia|SonyEricsson|SIE-|Amoi|ZTE/.test(navigator.userAgent))){if(window.location.href.indexOf("?mobile")<0){try{if(/Android|Windows Phone|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)){window.location.href="{dede:global.cfg_mobileurl/}/";}else if(/iPad/i.test(navigator.userAgent)){}else{}}catch(e){}}}}
  • </script>

欄目頁

  • <meta http-equiv="mobile-agent" content="format=xhtml;url={dede:global.cfg_mobileurl/}/list.php?tid={dede:field.id/}">
  • <script type="text/javascript">
  • if(window.location.toString().indexOf('pref=padindex') != -1){}else{if(/AppleWebKit.*Mobile/i.test(navigator.userAgent) || (/MIDP|SymbianOS|NOKIA|SAMSUNG|LG|NEC|TCL|Alcatel|BIRD|DBTEL|Dopod|PHILIPS|HAIER|LENOVO|MOT-|Nokia|SonyEricsson|SIE-|Amoi|ZTE/.test(navigator.userAgent))){if(window.location.href.indexOf("?mobile")<0){try{if(/Android|Windows Phone|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)){window.location.href="{dede:global.cfg_mobileurl/}/list.php?tid={dede:field.id/}";}else if(/iPad/i.test(navigator.userAgent)){}else{}}catch(e){}}}}
  • </script>

文章頁

  • <meta http-equiv="mobile-agent" content="format=xhtml;url={dede:global.cfg_mobileurl/}/view.php?aid={dede:field.id/}">
  • <script type="text/javascript">
  • if(window.location.toString().indexOf('pref=padindex') != -1){}else{if(/AppleWebKit.*Mobile/i.test(navigator.userAgent) || (/MIDP|SymbianOS|NOKIA|SAMSUNG|LG|NEC|TCL|Alcatel|BIRD|DBTEL|Dopod|PHILIPS|HAIER|LENOVO|MOT-|Nokia|SonyEricsson|SIE-|Amoi|ZTE/.test(navigator.userAgent))){if(window.location.href.indexOf("?mobile")<0){try{if(/Android|Windows Phone|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)){window.location.href="{dede:global.cfg_mobileurl/}/view.php?aid={dede:field.id/}";}else if(/iPad/i.test(navigator.userAgent)){}else{}}catch(e){}}}}
  • </script>

代碼中的{dede:global.cfg_mobileurl/}部分要替換為包含“http://”的二級域名(即:http: //m.nt090.com),如不想修改模板里的相關(guān)代碼,也可修改/include/common.inc.php中的$cfg_mobileurl 變量賦值為二級域名。

以上代碼為dedecms新版模板所使用,第一行<meta>標簽代碼為百度發(fā)現(xiàn)跳轉(zhuǎn)適配關(guān)系的方式(可同時使用)之一——“Meta 標記”,下面幾行javascript代碼的功能是識別是否移動端設(shè)備訪問,如是則將當前pc端頁面自動跳轉(zhuǎn)到匹配的移動端頁面。

另外,還可使用<link>標簽以便于百度更好地發(fā)現(xiàn)PC站和移動站的移動適配關(guān)系,在模板的<head></head>標簽內(nèi)加入如下代碼:

PC站首頁模板:

  • <link rel="alternate" media="only screen and (max-width: 640px)" href="http://m.nt090.com" >

PC站欄目頁模板:

  • <link rel="alternate" media="only screen and (max-width: 640px)" href="http://m.nt090.com/list.php?tid={dede:field.id/}" >

PC站文章頁模板:

  • <link rel="alternate" media="only screen and (max-width: 640px)" href=" http://m.nt090.com/view.php?aid={dede:field.id/}" >

移動站首頁模板:

  • <link rel="canonical" href="http://www.nt090.com/ "/>

欄目頁模板:

  • <link rel="canonical" href="http://www.nt090.com{dede:type typeid='0' row=1}[field:typelink /]{/dede:type}"/>

文章頁模板:

  • <link rel="canonical" href="http://www.nt090.com/{dede:field.id runphp='yes'}$id=@me;@me='';$url=GetOneArchive($id);@me=$url['arcurl'];{/dede:field.id}"/>

至此,移動站架設(shè)基本成型。

提交移動跳轉(zhuǎn)適配

URL對應(yīng)關(guān)系示例:

Dedecms網(wǎng)站 Dedecms網(wǎng)站移動化 網(wǎng)站移動化 網(wǎng)站優(yōu)化

適配方式:

欄目頁的對應(yīng)關(guān)系沒有規(guī)律,且數(shù)量較少,使用URL適配 ;文章頁為有規(guī)律的網(wǎng)址,且數(shù)量多,使用規(guī)則適配。

提交文章頁規(guī)則適配(如圖):

Dedecms網(wǎng)站 Dedecms網(wǎng)站移動化 網(wǎng)站移動化 網(wǎng)站優(yōu)化

提交首頁和欄目頁URL適配(如圖):

Dedecms網(wǎng)站 Dedecms網(wǎng)站移動化 網(wǎng)站移動化 網(wǎng)站優(yōu)化

對于欄目較多的Dedecms網(wǎng)站,人工列出所有的欄目頁URL對顯然很費事,這里推薦一個方法可以輕松解決該問題:

※在模板中嵌入以下代碼,對應(yīng)前臺頁面中即可顯示所有欄目的URL對,復制粘貼即可:

{dede:channelartlist row=100 typeid='top'}

http://www.nt090.com{dede:field name='typeurl'/} 

http://m.nt090.com/list.php?tid={dede:field name='id'/}<br>

{dede:channel type='son' noself='true'}

http://www.nt090.com[field:typelink/] http://m.nt090.com/list.php?tid=[field:id/]<br>

{/dede:channel}

{/dede:channelartlist}

※提交完規(guī)則適配,等待百度審核。

如果所提交的適配關(guān)系有誤,處理狀態(tài)將很快會出現(xiàn)“校驗失敗”的提示。

Dedecms網(wǎng)站 Dedecms網(wǎng)站移動化 網(wǎng)站移動化 網(wǎng)站優(yōu)化

很長一段時間以來,很多站長應(yīng)該都發(fā)現(xiàn)移動適配“校驗中”時間很長,對于此問題,目前官方已做了改進,校驗效率有了明顯提升,以前所提交的適配關(guān)系發(fā)現(xiàn)正在陸續(xù)通過。

以下為很早前提交、近期已通過適配的一個網(wǎng)站示例:

Dedecms網(wǎng)站 Dedecms網(wǎng)站移動化 網(wǎng)站移動化 網(wǎng)站優(yōu)化

本文方案基于Dedecms尚未成熟的移動站功能,雖較為簡單易用,但美中不足的是目前移動站URL僅能使用動態(tài)地址,如需使用靜態(tài)地址需要通過設(shè)置偽靜態(tài)來實現(xiàn),或者等待Dedecms發(fā)布下一個較為成熟的版本,再或者直接對Dedecms進行二次開發(fā)實現(xiàn)移動站的靜態(tài)頁面生成功能,對于此類操作本文就不再延伸……

熱門關(guān)鍵詞: nginx .htaccess 解決辦法
欄目列表
推薦內(nèi)容
熱點內(nèi)容
展開
库伦旗| 沁水县| 磐石市| 封开县| 武威市| 文山县| 浪卡子县| 剑川县| 色达县| 浦城县| 姜堰市| 两当县| 安陆市| 历史| 墨竹工卡县| 海晏县| 依安县| 荣成市| 越西县| 陇西县| 泰安市| 新化县| 巧家县| 平顺县| 靖西县| 鄯善县| 杭锦旗| 静宁县| 天柱县| 垫江县| 东阳市| 丰顺县| 财经| 苍山县| 潮州市| 广宗县| 金阳县| 株洲县| 邢台县| 余姚市| 沅江市|