首先,说一下情况:
1、我本地用的是Apache,服务器上用的是Nginx。
2、设置的伪静态起作用,没有问题。
3、PHP代码。
有个tag标签功能,其中有tag中文标签,我想让链接是中文的形式出现,就像本站上的这个链接一样。
http://segmentfault.com/t/%E6%95%B0%E6%8D%AE%E5%BA%93%E8%AE%BE%E8%AE%A1
在浏览器和鼠标悬停在链接上的时候,效果是如下:
http://segmentfault.com/t/数据库设计
当然中文是通过urlencode("数据库设计")得到的字符串是:%E6%95%B0%E6%8D%AE%E5%BA%93%E8%AE%BE%E8%AE%A1
真正的问题来了:
当我使用了伪静态后,发现自动把 “%E6%95%B0%E6%8D%AE%E5%BA%93%E8%AE%BE%E8%AE%A1” urldecode解码了。
在网上找了好多资料,说是只要urlencode(urlencode("数据库设计"))就行了,没错,虽然管用了。但是这样的话就不如我直接使用这个标签id就好了,比如http://segmentfault.com/t/123。但是我想要的是显示中文,就和本站的效果一样。
举个例子,伪静态代码如下:
<code>RewriteCond %{QUERY_STRING} ^(.*)$ RewriteRule ^(.*)/abc/([\w_\-\%\|\!\,\#]+)$ $1/abc.php?tag=$1&%1 [L] </code>
那么如何才能禁止apache和Nginx自动把字符串解码呢?
回复内容:
首先,说一下情况:
1、我本地用的是Apache,服务器上用的是Nginx。
2、设置的伪静态起作用,没有问题。
3、PHP代码。
有个tag标签功能,其中有tag中文标签,我想让链接是中文的形式出现,就像本站上的这个链接一样。
http://segmentfault.com/t/%E6%95%B0%E6%8D%AE%E5%BA%93%E8%AE%BE%E8%AE%A1
在浏览器和鼠标悬停在链接上的时候,效果是如下:
http://segmentfault.com/t/数据库设计
当然中文是通过urlencode("数据库设计")得到的字符串是:%E6%95%B0%E6%8D%AE%E5%BA%93%E8%AE%BE%E8%AE%A1
真正的问题来了:
当我使用了伪静态后,发现自动把 “%E6%95%B0%E6%8D%AE%E5%BA%93%E8%AE%BE%E8%AE%A1” urldecode解码了。
在网上找了好多资料,说是只要urlencode(urlencode("数据库设计"))就行了,没错,虽然管用了。但是这样的话就不如我直接使用这个标签id就好了,比如http://segmentfault.com/t/123。但是我想要的是显示中文,就和本站的效果一样。
举个例子,伪静态代码如下:
<code>RewriteCond %{QUERY_STRING} ^(.*)$ RewriteRule ^(.*)/abc/([\w_\-\%\|\!\,\#]+)$ $1/abc.php?tag=$1&%1 [L] </code>
那么如何才能禁止apache和Nginx自动把字符串解码呢?
你这个Rewrite应该不会英文中文产生歧义吧,只是你配置Rewrite参数里只识别了encode形式的文字,所以导致了不能重新向而已吧。
你可以直接在正则里接受所有字符,这样就可以正常运行了。
另外,自动解码应该是浏览器完成的,不是WebServer控制的。

phpssionscanStorestrings、numbers、arrays、andobjects.1.strings:textdatalikeusernames.2.numbers:integersorfloatsforcounters.3.arrays:listslikeshoppingcarts.4.objects:complextructuresthataresialized。

tostartaphpsession、outsession_start()atthescript'sbeginning.1)placeitbe foreanyouttosetthesscookie.2)usesionsionsionsionserdatalikelogintatussorshoppingcarts.3)再生セッションインドストップレベントフィックスアタック

セッション再生とは、新しいセッションIDを生成し、セッション固定攻撃の場合にユーザーが機密操作を実行するときに古いIDを無効にすることを指します。実装の手順には次のものが含まれます。1。感度操作を検出、2。新しいセッションIDを生成する、3。古いセッションIDを破壊し、4。ユーザー側のセッション情報を更新します。

PHPセッションは、アプリケーションのパフォーマンスに大きな影響を与えます。最適化方法には以下が含まれます。1。データベースを使用してセッションデータを保存して応答速度を向上させます。 2。セッションデータの使用を削減し、必要な情報のみを保存します。 3.非ブロッキングセッションプロセッサを使用して、同時実行機能を改善します。 4.セッションの有効期限を調整して、ユーザーエクスペリエンスとサーバーの負担のバランスを取ります。 5.永続的なセッションを使用して、データの読み取り時間と書き込み時間を減らします。

phpsesionsareserver-side、whilecookiesareclient-side.1)Sessionsionsionsoredataontheserver、aremoresecure.2)cookiesstoredataontheclient、cookiestoresecure、andlimitedinsizeisize.sesionsionsionivationivationivationivationivationivationivationivate

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 中国語版
中国語版、とても使いやすい

Dreamweaver Mac版
ビジュアル Web 開発ツール

ホットトピック









