這篇文章算是對我前幾年在做搜尋引擎專案時候無法解決的一個問題畫一個句號吧,用處不大,不過可以彌補下自己的一個遺憾。
當時的場景是這樣子的,本來正常人的習慣總是在搜索框輸入正常搜索詞然後進行搜索,但是總有一些用戶會自認為聰明的,從地址欄複製出URL,然後改parameter然後進行訪問,類似http://www.xxx.com/search?keyword =%E4%B8%AD%E6%96%87 (IE下的顯示,至於chrome和firefox等則會在網址列顯示中文) ,當使用者提交的請求在IE下是http://www.xxx.com/search?keyword =中文 時,你會發現服務端(web處理後端)根本無法識別這種字符,這是瀏覽器在向後端提交請求的時候,其參數必須是iso-8859-1規範的URLEncode,在寫web程式的時候,IE必須要我們手動去轉換編碼,而chrome和firefox則可轉可不轉,因為它們會在傳輸的時候自動轉換。
後端無法辨識字符,也就是我們常說的亂碼。這種亂碼產生的原因也是因為解碼錯誤,我們的web容器(框架、類似java中的jetty/tomcat/jboss和python中的django之類的)會自動把這串字元進行UrlDecode.此時,IE提交的沒有經過編碼的字元被解碼,那可想而知,再也回不來了(多少人曾經像我一樣看到這種亂碼,病急亂投醫)。
ok,解決這種問題的方案其實有兩種,第一種是在到達web後端之前(沒辦法在js層,因為用戶是直接敲地址欄的回車的),也就是說是在服務端的前端(nginx)進行預處理,將沒有編碼的字元進行url編碼。第二種是重新編譯web容器中關於servlet處理參數進行decode的邏輯,進行判斷是否需要urldecode。
鑑於實現的難度,我選擇了第一種,在nginx進行處理,在nginx中採用lua進行對參數進行轉碼,然後再反向代理到web後端。
在這裡,需要視乎自己的專案而定,有幾種情況要注意,例如自己的專案是UTF-8編碼還是GBK編碼,客戶的環境是UTF-8還是GBK,這些都要做不同的處理,例如我的系統是瀏覽器所在系統是windows,所以我的客戶機的編碼是GBK,然後我的專案是UTF-8的,所以在進行urlencoding之前,還需要再進行將GBK-》UTF- 8的操作。
set_by_lua $arg_name ' local iconv = require("luaiconv") local cd = iconv.new( "utf-8","gbk") if(string.find(ngx.var.arg_name,"%")){ ngx.var.arg_name, err = cd:iconv(ngx.var.arg_name) } return ngx.escape_uri(ngx.var.arg_name) ';在這個場景下,我的參數名稱是name,然後我採用了luaiconv的函式庫來轉換。其實我這個邏輯不是很嚴謹,例如我沒有判斷編碼,在判斷是否需要編碼的場景,也只是透過字串中是否含有%來做判斷。
三年前,會對IE網址列手動輸入中文進行處理的搜尋引擎,還只有谷歌,不過今日再看,已經有不少的公司也做到了。
以上就介紹了IE瀏覽器在網址列針對param直接輸入中文導致亂碼的解決方案,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

PHP用於構建動態網站,其核心功能包括:1.生成動態內容,通過與數據庫對接實時生成網頁;2.處理用戶交互和表單提交,驗證輸入並響應操作;3.管理會話和用戶認證,提供個性化體驗;4.優化性能和遵循最佳實踐,提升網站效率和安全性。

PHP在數據庫操作和服務器端邏輯處理中使用MySQLi和PDO擴展進行數據庫交互,並通過會話管理等功能處理服務器端邏輯。 1)使用MySQLi或PDO連接數據庫,執行SQL查詢。 2)通過會話管理等功能處理HTTP請求和用戶狀態。 3)使用事務確保數據庫操作的原子性。 4)防止SQL注入,使用異常處理和關閉連接來調試。 5)通過索引和緩存優化性能,編寫可讀性高的代碼並進行錯誤處理。

在PHP中使用預處理語句和PDO可以有效防範SQL注入攻擊。 1)使用PDO連接數據庫並設置錯誤模式。 2)通過prepare方法創建預處理語句,使用佔位符和execute方法傳遞數據。 3)處理查詢結果並確保代碼的安全性和性能。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP可以輕鬆創建互動網頁內容。 1)通過嵌入HTML動態生成內容,根據用戶輸入或數據庫數據實時展示。 2)處理表單提交並生成動態輸出,確保使用htmlspecialchars防XSS。 3)結合MySQL創建用戶註冊系統,使用password_hash和預處理語句增強安全性。掌握這些技巧將提升Web開發效率。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Dreamweaver CS6
視覺化網頁開發工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。