apache2.4.33偽靜態配置入門教程(1)

来源:https://www.cnblogs.com/ghostwu/archive/2018/05/16/9048816.html
-Advertisement-
Play Games

偽靜態: 把動態網頁的請求方式偽裝成靜態網頁 要使用偽靜態技術,要在httpd.conf中啟用偽靜態模塊: 把前面的#號去掉 通常利用Apache的rewrite模塊對 URL 進行重寫的時候, rewrite規則會寫在 .htaccess 文件里。但要使 apache 能夠正常的讀取.htacce ...


偽靜態: 把動態網頁的請求方式偽裝成靜態網頁

要使用偽靜態技術,要在httpd.conf中啟用偽靜態模塊: 

LoadModule rewrite_module modules/mod_rewrite.so

把前面的#號去掉

通常利用Apache的rewrite模塊對 URL 進行重寫的時候, rewrite規則會寫在 .htaccess 文件里。但要使 apache 能夠正常的讀取.htaccess 文件的內容,就必須對.htaccess 所在目錄進行配置。從安全性考慮,根目錄的AllowOverride屬性一般都配置成不允許任何Override ,即

<Directory />
    AllowOverride None
    Require all denied
</Directory>

一、在 AllowOverride 設置為 None 時, .htaccess 文件將被完全忽略, 當此指令設置為 All 時,apache才會讀取.htaccess中的規則並應用

我的DocumentRoot:

DocumentRoot "/www"
root@dev:/www# ls -a
.  ..  .htaccess  index.htm
root@dev:/www# cat .htaccess 
RewriteEngine on
RewriteRule ^(.*)\.html$ $1.htm
root@dev:/www# cat index.htm 
<h3>this is index.htm</h3>
root@dev:/www# 

.htaccess規則詳解:

RewriteEngine on #開啟偽靜態

RewriteRule ^(.*)\.html$ $1.htm #當訪問以.html結尾的文件時,會被路由到(.*).htm的地址,比如:

訪問http://localhost/index.html -----> 會被規則解釋為http://localhost/index.htm,這樣讀到的內容是www目錄下的index.htm文件的內容

要使偽靜態生效,需要對/www 目錄設置為

Options Indexes FollowSymLinks
AllowOverride All Require all granted

 我的httpd.conf配置:

1,去除httpd.conf中的註釋和空行

grep -v "^\s*#" httpd.conf | grep -v "^$" > httpd.conf.bak

2,httpd.conf完整配置:

ServerRoot "/usr/local/httpd24"
Listen 80
LoadModule mpm_prefork_module modules/mod_mpm_prefork.so
LoadModule authn_file_module modules/mod_authn_file.so
LoadModule authn_core_module modules/mod_authn_core.so
LoadModule authz_host_module modules/mod_authz_host.so
LoadModule authz_groupfile_module modules/mod_authz_groupfile.so
LoadModule authz_user_module modules/mod_authz_user.so
LoadModule authz_core_module modules/mod_authz_core.so
LoadModule access_compat_module modules/mod_access_compat.so
LoadModule auth_basic_module modules/mod_auth_basic.so
LoadModule reqtimeout_module modules/mod_reqtimeout.so
LoadModule filter_module modules/mod_filter.so
LoadModule mime_module modules/mod_mime.so
LoadModule log_config_module modules/mod_log_config.so
LoadModule env_module modules/mod_env.so
LoadModule headers_module modules/mod_headers.so
LoadModule setenvif_module modules/mod_setenvif.so
LoadModule version_module modules/mod_version.so
LoadModule unixd_module modules/mod_unixd.so
LoadModule status_module modules/mod_status.so
LoadModule autoindex_module modules/mod_autoindex.so
<IfModule !mpm_prefork_module>
</IfModule>
<IfModule mpm_prefork_module>
</IfModule>
LoadModule dir_module modules/mod_dir.so
LoadModule alias_module modules/mod_alias.so
LoadModule rewrite_module modules/mod_rewrite.so
<IfModule unixd_module>
User daemon
Group daemon
</IfModule>
ServerAdmin [email protected]
ServerName 127.0.0.1
<Directory />
    AllowOverride None
    Require all denied
</Directory>
DocumentRoot "/www"
<Directory "/www">
    Options Indexes FollowSymLinks
    AllowOverride All
    Require all granted
</Directory>
<IfModule dir_module>
    DirectoryIndex index.html
</IfModule>
<Files ".ht*">
    Require all denied
</Files>
ErrorLog "logs/error_log"
LogLevel warn
<IfModule log_config_module>
    LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
    LogFormat "%h %l %u %t \"%r\" %>s %b" common
    <IfModule logio_module>
      LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
    </IfModule>
    CustomLog "logs/access_log" common
</IfModule>
<IfModule alias_module>
    ScriptAlias /cgi-bin/ "/usr/local/httpd24/cgi-bin/"
</IfModule>
<IfModule cgid_module>
</IfModule>
<Directory "/usr/local/httpd24/cgi-bin">
    AllowOverride None
    Options None
    Require all granted
</Directory>
<IfModule headers_module>
    RequestHeader unset Proxy early
</IfModule>
<IfModule mime_module>
    TypesConfig /etc/httpd24/mime.types
    AddType application/x-compress .Z
    AddType application/x-gzip .gz .tgz
</IfModule>
<IfModule proxy_html_module>
Include /etc/httpd24/extra/proxy-html.conf
</IfModule>
<IfModule ssl_module>
SSLRandomSeed startup builtin
SSLRandomSeed connect builtin
</IfModule>

對於偽靜態,主要註意偽靜態模塊是否載入,Directory下麵的設置

 

二,也可以把偽靜態規則寫在apache配置文件的Directory段,為了驗證配置的作用,可以先把.htaccess刪除或者重命名

root@dev:/www# ls -a
.  ..  .htaccess.bak  index.htm
<Directory "/www">
    Options Indexes FollowSymLinks
    AllowOverride none
    RewriteEngine on
    RewriteRule ^(.*)\.html$ $1.htm
    Require all granted
</Directory>

即使AllowOverride 設置為none,偽靜態依然生效,註意修改完apache的配置文件需要重啟apache伺服器

/usr/local/httpd24/bin/apachectl restart

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 持續集成交付部署是什麼意思,它給我們帶來什麼好處? 先貼一張圖 持續集成(Continuous Integration) 持續集成強調開發人員提交了新代碼之後,立刻進行構建、(單元)測試(這個要看情況了是否需要) 持續交付(Continuous Delivery) 持續交付在持續集成的基礎上,將集成 ...
  • 在實際的web開發中,經常會遇到以下情況,導致給用不好的體驗:     a、程式未處理的異常,直接輸出顯示到用戶頁面     b、用戶訪問的資源不存在,直接顯示系統預設的404頁面     c、其它以下請求錯誤狀態的系統預設頁面(403等)   為了給用戶友好的體驗,在實際項目開發中, 需要對系統會... ...
  • SM4加密演算法實現Java和C#相互加密解密 近期由於項目需要使用SM4對數據進行加密,然後傳給Java後臺,Java後臺使用的也是SM4的加密演算法但是就是解密不正確,經過一步步調試發現Java中好多數據類型與C#的相同的數據類型是存在不同的比如:byte在Java中範圍是-127~128,而C#中 ...
  • 一、問題描述 InnerHTML 中文顯示為&#1052;&#1086;&#1076;&#1077;&#1083;&#1100; 二、解決方法 在初始化CQ對象前,先設置執行以下語句: CsQuery.Config.HtmlEncoder = CsQuery.HtmlEncoders.None; C... ...
  • Smobiler 4.4已經正式發佈,還不快來看看?原文地址:https://www.smobiler.com/portal.php?mod=view&aid=53這次更新要感謝我們的用戶,在使用smobiler的過程中不吝反饋,同時我們的程式員也及時響應用戶提出的新增、優化、修複等內容。 在這次更 ...
  • 開源且功能強大的C# 擴展方法類庫Pure.Ext (支持.Net Framework和.Net Core) ...
  • 在Linux系統中使用yum安裝軟體時,提示yum處於鎖定狀態 通過查詢得知,可能是系統內部在自動升級,可通過強制關閉yum進程 之後yum就可以正常使用了 ...
  • cat命令 作用:連接多個文件並且列印到屏幕輸出,或者重定向到其他文件,也可以用來查看顯示單個文件,或者多個文件。 格式: cat [option] [file] 1,最簡單的用法,直接跟文件名稱,查看文件內容 2,也可以使用如下方式,向文件寫入或者追加內容 3,-n與-b 都是對文件進行編號,-b ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...