[PHP][JavaScript] urlencode と encodeURI でのエンコードと文字化け問題

Wed, October 19, 2011 - 4 min read

 

PHP と JavaScript でエンコードするタイミングによりIEで文字化け問題が発生しました。  

解決方法としては、PHP側でエンコードしてJavaScript側に渡さないようにして、PHP側からはそのまま値を渡してJavaScript側でエンコードすればOKでした。  

■ 文字化け問題が発生するパターン  

[PHP]

コントローラで urlencode して、テンプレートに出力する。

$url = urlencode('http://example.com/?p=2&keyword=テスト');
$smarty->assign('url', $url);

↓  

[HTML]

次へ

↓  

[JavaScript]

function formsubmitt (action_url) {
    form.action = action_url;
    form.submit();
}

 

■ IEでも正常に処理できるパターン  

[PHP]

コントローラでエンコードせずに、そのままテンプレートに渡す。

$url = 'http://example.com/?p=2&keyword=テスト';
$smarty->assign('url', $url);

↓  

[HTML]

次へ

↓  

[JavaScript]

function formsubmitt (action_url) {
    form.action = encodeURI(action_url);
    form.submit();
}

 

以上です。  

【参考】

javascript: escape(), encodeURI(), encodeURIComponent() 比較 (groundwalker.com) はてなブックマーク - javascript: escape(), encodeURI(), encodeURIComponent() 比較 (groundwalker.com)

URL(URI)エンコード・デコードを行う - JavaScript TIPSふぁくとりー はてなブックマーク - URL(URI)エンコード・デコードを行う - JavaScript TIPSふぁくとりー

PHP: urlencode - Manual はてなブックマーク - PHP: urlencode - Manual