PHP で Oracle クエリを実行すると漢字が文字化けする
環境:
Oracle データベースは XP にインストールされています。
バージョン: 10.2.0.3
NLS_LANGUAGE
AMERICAN
NLS_TERRITORY
AMERICA
NLS_CHARACTERSET
ZHS16GBK
1. (クライアントの動作言語環境は SIMPLIFIED CHINESE_CHINA.ZHS16GBK):
1,
cmd
set NLS_LANG=American_America.ZHS16GBK
sqlplus /nolog
conn scott/tiger@salesnew
insert into emp 値('7777','you','good','7709','1-11-2012','5000','800','20');
commit;
select * from emp;
EMPNO ENAME JOB MGR HIREDATE SAL COMM
---------- ---------- -------- - -- -------- ------------ ---------- ----------
DEPTNO
--- -------
7777 こんにちは 7709 01-NOV-12 5000 800
20
結論: 入力したデータベースには問題ありません。
2. PHP は oci
1 を介して oracle を動作させます。PHP の動作および環境は、Windows 2003 x86 Enterprise Edition 簡体字中国語+iis6.0+oracle instantclient-basic-win32-10.2.0.4.zip+ です。 fcgisetup_1 .5_rtw_x86.msi
2. 必要な環境をすべて構成した後、
phpinfo();
?>
をテストすると、すべてが正常であることがわかりました
3. oracle
echo oci_client_version ();
//header('Content-type: text/html; charset=ZHS16GBK');
//set NLS_LANG=American_America.ZHS16GBK
//export NLS_LANG=American_America.ZHS16GBK
//putenv("NLS_LANG=American_America.ZHS16GBK");
$conn = oci_connect('scott) ', 'tiger', '192.168.1.50/salesnew','ZHS16GBK');
if (!$conn) {
$e = oci_error();
trigger_error(htmlentities($e[' message'], ENT_QUOTES), E_USER_ERROR);
}
echo oci_server_version ($conn);
// ステートメントを準備します
$stid = oci_parse($conn, 'SELECT * FROM emp');
if (!$stid) {
$e = oci_error($conn);
trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}
// クエリのロジックを実行します
$r = oci_execute($stid);
if (!$r) {
$e = oci_error($stid);
trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}
// クエリの結果を取得します
print "
" . ($item !== null ? htmlentities($item, ENT_QUOTES) : " ") " | n";
oci_free_statement($stid);
oci_close($conn);
echo "テスト ページ自体の中国語表示";
?>
以下に示すように中国語部分が文字化けします。
10.2.0.4.0Oracle Database 10g Enterprise Editionリリース 10.2.0.3 .0 - パーティショニング、OLAP、およびデータ マイニング オプションを使用した運用
7777 Äã ºã 7709 01-NOV-12 5000 800 20 ê 8888 01-JAN-11 3000 5000 20
7369 SMITH CLERK 7902 17 -12月-80 800 20 男性 7698 22-FEB-81 1250 500 30
7566 ジョーンズマネージャー 7839 02-APR-81 2975 20
7654 マーティンセールスマン 7698 28-SEP-81 1250 1400 30 81 年 5 月 2850 30
7782 クラーク・マネージャー 7839 09-JUN-81 2450 10
7788 スコット・アナリスト 7566 19-APR-87 3000 20 8 08-SEP-81 1500 0 30
7876 アダムス・クラーク 7788 5月23日87 1100 20
7900 JAMES CLERK 7698 03-DEC-81 950 30
7934 MILLER CLERK 7782 23-JAN-82 1300 10
テストページ自体の中国語表示
これBaidu と Google は数日間この問題を解決できず、私は気が狂いました。
次の方法を試しました
1. PHP 環境が配置されているオペレーティング システム環境変数 NLS_LAGN=SIMPLIFIED CHINESE_CHINA.ZHS16GBK または NLS_LANG=American_America.ZHS16GBK を設定します。

負荷分散はセッション管理に影響しますが、セッションの複製、セッションの粘着性、集中セッションストレージで解決できます。 1。セッションレプリケーションサーバー間のセッションデータをコピーします。 2。セッションスティンネスは、ユーザーリクエストを同じサーバーに指示します。 3.集中セッションストレージは、Redisなどの独立したサーバーを使用してセッションデータを保存してデータ共有を確保します。

SESSIONLOCKINGISATECHNIQUESTOESUREAUSER'SSESSIONREMAINSEXCLUSIVETOONEUSATIME.ITISCRUCIALFORPREVENTINGDATACORTIONANDSECURITYBREACHESINMULTI-USERAPPLICATIONS.SESSIONLOCKINGISISIMPLEMENTEDUSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGSINGROCKINGSMECHANISMなど

PHPセッションの代替品には、Cookie、トークンベースの認証、データベースベースのセッション、Redis/Memcachedが含まれます。 1.Cookiesは、クライアントにデータを保存することによりセッションを管理します。 2.トークンベースの認証はトークンを使用してユーザーを検証します。これは非常に安全ですが、追加のロジックが必要です。 3.Databaseベースのセッションは、データベースにデータを保存します。これは、スケーラビリティが良好ですが、パフォーマンスに影響を与える可能性があります。 4. Redis/Memcachedは分散キャッシュを使用してパフォーマンスとスケーラビリティを向上させますが、追加のマッチングが必要です

SessionHijackingとは、ユーザーのSessionIDを取得してユーザーになりすましている攻撃者を指します。予防方法には、次のものが含まれます。1)HTTPSを使用した通信の暗号化。 2)SessionIDのソースの検証。 3)安全なSessionID生成アルゴリズムの使用。 4)SessionIDを定期的に更新します。

この記事では、PHPについて説明し、その完全なフォーム、Web開発での主要な使用、PythonとJavaとの比較、および初心者の学習のしやすさについて説明します。

PHPは、$ \ _ postおよび$ \ _を使用してフォームデータを処理し、検証、消毒、安全なデータベースインタラクションを通じてセキュリティを確保します。

この記事では、PHPとASP.NETを比較して、大規模なWebアプリケーション、パフォーマンスの違い、セキュリティ機能への適合性に焦点を当てています。どちらも大規模なプロジェクトでは実行可能ですが、PHPはオープンソースであり、プラットフォームに依存しませんが、ASP.NET、

PHPの症例感度は変化します:関数は鈍感であり、変数とクラスは感度があります。ベストプラクティスには、一貫した命名と、比較のためにケース非感受性関数を使用することが含まれます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

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

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ホットトピック









