Nginx如何判断手机
计划使用Nginx进行缓存,缓解后端压力。网站有手机和桌面两个版本,目前用PHP进行简单的判断,代码如下:
<code>function isMobile(){ $ua = $_SERVER['HTTP_USER_AGENT']; $ismobile = preg_match('/Android|iPhone|IEMoble|Mobile/i', $ua); $ismobile = preg_match('/iPad|Tablet/i', $ua) ? 0 : $ismobile; $ismobile = isset($_COOKIE['ismobile']) ? 1 : $ismobile; return $ismobile; }</code>
在PHP判断的思路是这样的:
判断UA有无
Android|iPhone|IEMoble|Mobile
字样,有则为手机再判断UA中有无
iPad|Tablet
字样,有则不是手机如果存在名为
ismobile
的cookie,则无论UA强制设为手机
我希望实现的是将以上判断逻辑直接在Nginx上实现,并设置为cache key(当然能同时向后端发送额外的标头更好,这样可以保证前后端判断结果绝对一致,哈哈)
因为本人英语很差,又对Nginx语法等不了解,所以想请教下大神,能否给个DEMO,谢谢!
回复内容:
计划使用Nginx进行缓存,缓解后端压力。网站有手机和桌面两个版本,目前用PHP进行简单的判断,代码如下:
<code>function isMobile(){ $ua = $_SERVER['HTTP_USER_AGENT']; $ismobile = preg_match('/Android|iPhone|IEMoble|Mobile/i', $ua); $ismobile = preg_match('/iPad|Tablet/i', $ua) ? 0 : $ismobile; $ismobile = isset($_COOKIE['ismobile']) ? 1 : $ismobile; return $ismobile; }</code>
在PHP判断的思路是这样的:
判断UA有无
Android|iPhone|IEMoble|Mobile
字样,有则为手机再判断UA中有无
iPad|Tablet
字样,有则不是手机如果存在名为
ismobile
的cookie,则无论UA强制设为手机
我希望实现的是将以上判断逻辑直接在Nginx上实现,并设置为cache key(当然能同时向后端发送额外的标头更好,这样可以保证前后端判断结果绝对一致,哈哈)
因为本人英语很差,又对Nginx语法等不了解,所以想请教下大神,能否给个DEMO,谢谢!
英语差不是理由,我英语基本上没及格过呢,还不是照样Google?大不了用翻译呗。
善用搜索,很多问题都可以解决。
这是我用Google搜索“nginx判断手机”找到的第一篇文章:传送门

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

如何解決 Nginx 403 Forbidden 錯誤?檢查文件或目錄權限;2. 檢查 .htaccess 文件;3. 檢查 Nginx 配置文件;4. 重啟 Nginx。其他可能原因還包括防火牆規則、SELinux 設置或應用程序問題。

在 Linux 中啟動 Nginx 的步驟:檢查 Nginx 是否已安裝。使用 systemctl start nginx 啟動 Nginx 服務。使用 systemctl enable nginx 啟用在系統啟動時自動啟動 Nginx。使用 systemctl status nginx 驗證啟動是否成功。在 Web 瀏覽器中訪問 http://localhost 查看默認歡迎頁面。

服務器無權訪問所請求的資源,導致 nginx 403 錯誤。解決方法包括:檢查文件權限。檢查 .htaccess 配置。檢查 nginx 配置。配置 SELinux 權限。檢查防火牆規則。排除其他原因,如瀏覽器問題、服務器故障或其他可能的錯誤。

解決 Nginx 跨域問題有兩種方法:修改跨域響應頭:添加指令以允許跨域請求,指定允許的方法和頭,以及設置緩存時間。使用 CORS 模塊:啟用模塊並配置 CORS 規則,允許跨域請求、方法、頭和設置緩存時間。

問題的答案:304 Not Modified 錯誤表示瀏覽器已緩存客戶端請求的最新資源版本。解決方案:1. 清除瀏覽器緩存;2. 禁用瀏覽器緩存;3. 配置 Nginx 允許客戶端緩存;4. 檢查文件權限;5. 檢查文件哈希;6. 禁用 CDN 或反向代理緩存;7. 重啟 Nginx。

確認 Nginx 是否啟動的方法:1. 使用命令行:systemctl status nginx(Linux/Unix)、netstat -ano | findstr 80(Windows);2. 檢查端口 80 是否開放;3. 查看系統日誌中 Nginx 啟動消息;4. 使用第三方工具,如 Nagios、Zabbix、Icinga。

如何在 Windows 中配置 Nginx?安裝 Nginx 並創建虛擬主機配置。修改主配置文件並包含虛擬主機配置。啟動或重新加載 Nginx。測試配置並查看網站。選擇性啟用 SSL 並配置 SSL 證書。選擇性設置防火牆允許 80 和 443 端口流量。

查看 Nginx 運行狀態的方法有:使用 ps 命令查看進程狀態;查看 Nginx 配置文件 /etc/nginx/nginx.conf;使用 Nginx 狀態模塊啟用狀態端點;使用 Prometheus、Zabbix 或 Nagios 等監控工具。
