PHPの学習経験
リリース: 2016-06-23 14:31:47
【1】最新のPHPバージョンでは変数get、post、sessionがページ間で受け渡せないため、自動グローバル変数がオフになっているため、前のページから送信された変数を取得するには$_GET[を使用します。 ' foo'],$_POST['foo'],$_SESSION['foo'] を取得するには もちろん、自動グローバル変数を on に変更することもできます (php.ini は register_globals = On に変更されます)。互換性があるとしても、自分自身を強制する必要があります。新しい書き方に慣れておくことをお勧めします。 [2] Win32 で get メソッドを使用して中国語パラメータを apache2 に渡すとエラーが発生します test.php?a=Hello&b=Hello パラメータを渡すと内部エラーが発生します 解決策: "test.php?a=" 。 urlencode(Hello)."&b=".urlencode(Hello) ................................ 【3】win32でのセッションが正常に動作しない php.ini default session.save_path = /tmp これは明らかに Linux での設定です。PHP は win32 でセッション ファイルを読み書きできないため、セッションが使用できなくなります これを絶対パスに変更してください。たとえば、session.save_path = c:windows emp 【 4 】エラーメッセージを表示します php.iniのdisplay_errors = On、error_reporting = E_ALLの場合、エラー修正のためにデバッグ中にそれらをオンにするのが最善です。メッセージは主に将来に関するものです。変数が割り当てられる前に呼び出されると、プロンプトが表示されます。解決策は、$foo が表示されている場合は、if(isset($foo)) echo $foo または echo @$foo を実行することです。 【5】mail()はWin32でメールを送信できません Linuxで設定したSendmailはwin32で送信できます php.ini = ip //ipのSMTPを変更します。認証機能のないsmtpサーバー(インターネット上で見つけるのは難しい) phpでメールを送信する場合、サーバーを転送せずにソケットを使用して相手のメールサーバーに直接送信するのが最善の解決策です。 [6] パスワードを設定していない場合。 mysql の初期インストールでは、update mysql.user setpassword="yourpassword" where user= "root" を使用してください パスワードを変更します 【7】ヘッダーは既に送信されました このエラーは通常、HEADER を使用した場合に発生します。理由はいくつかあります。 1. HEADER を使用する前に PRING または ECHO を実行した 2. 現在のファイルの前に空行がある 3. ファイルを INCLUDE した可能性があり、ファイルの最後に空行があると、このエラーが表示されます。出力。 ! [8] php.iniを変更しても変化なし IISやApacheなどのWebサーバーを再起動すると、最新の設定が適用されます [9] PHPは2003にインストールされています(インストール方法ISAPI、専門家のアドバイスをお願いします) PHP4 の php4isapi.dll は 2003 と競合するようです。CGI モードでのみインストールできます。 ステップ 1: まず、http://www.php.net/ からインストール プログラムをダウンロードします。 php-4.2.3-installer.exe をインストールしました。php-4.2.3-installer.exe をインストールする前に、IIS6.0 が起動し、アクセスできることを確認してください。インストール後、デフォルトの Web サイトに移動します -> アプリケーション構成 ステップ 2: [Web サービス拡張機能] -> [新しい Web サービス拡張機能] をクリックします。 ステップ 3: [拡張機能] -> [php] を追加します ステップ 4: 検索php.exeへのパスを追加します。 ステップ 5: 確認するだけです。 ステップ 6: PHP サービス拡張機能を選択し、「許可」をクリックします。 【10】 SQL文が機能せず、データベース操作が失敗する場合があります。 最も簡単なデバッグ方法は、SQL文をエコーして変数の値が取得できるかどうかを確認することです。 【11】includeとの違い。と require には大きな違いはありません。インクルードするファイルが存在しない場合、 include はプロンプトを表示し、次のステートメントを実行し続けると致命的なエラーが発生して終了します。私のテストでは、win32 プラットフォームでは、最初にインクルードされてから実行されるため、インクルードされたファイルには、ディレクトリの混乱を引き起こすため、 include ステートメントや require ステートメントを含めないことをお勧めします。 *nux では状況が異なる可能性があります。まだテストしていません ファイルを複数回インクルードしたくない場合は、include_once または require_once## を使用してドキュメント データの読み取りと書き込みを行うことができます function r($file_name) { $filenum= @fopen($file_name,"r"); @flock($filenum,LOCK_SH);$file_data=@fread($filenum,filesize($file_name)); @fclose($filenum);return $file_data ; } function w($file_name,$data,$method="w"){ $filenum=@fopen($file_name,$method); flock($ filenum,LOCK_EX); $file_data=fwrite( $filenum,$data); fclose($filenum); return $file_data; } 【12】isset()とempty()の違い どちらも変数のテストに使用されます ただし、isset()は変数に値が代入されているかどうかをテストし、empty()は変数に値が代入されているかどうかをテストします値は空です 変数に値が割り当てられていない場合、PHP での参照は許可されますが、通知プロンプトが表示されます 変数に null 値が割り当てられている場合は、$foo="" または $foo=0または $foo=false の場合、empty ($foo) は true を返し、isset($foo) も true を返します。つまり、null 値を代入しても変数の登録は解除されません。 変数の登録を解除するには、unset($foo) または $foo=NULL を使用できます [13] mysql クエリ ステートメントにはキーワードが含まれています PHP が mysql にクエリを実行するとき、mysql テーブル名またはカラム名にキーワードが含まれる場合があります これクエリ内のエラーである可能性があります。たとえば、テーブル名が order の場合、クエリ中にエラーが発生します。簡単な方法は、SQL ステートメントのテーブル名または列名に `[タブ キーの上] を追加することです。たとえば、select です。 * `order` より [14] HTTP プロトコルを経由すると 複数のファイルをアップロードするには 2 つの方法があり、これらは同じメソッドの 2 つの実装です。特定のプログラムは自分で設計する必要があります 1. 次のように、フォームに複数のファイル入力ボックスを設定し、配列で名前を付けます:
このようにして、次のテストを実行します。サーバー側 echo "";<br />print_r($_FILES);<br />echo " "; 1. 次のように、複数のファイル入力ボックスを異なる名前で設定します。 <フォームアクション= ""メソッド=post><入力タイプ=ファイル名=usefile_a><入力タイプ=ファイル名=usefile_b> <入力タイプ=ファイル名=usefile_c> サーバー側で実行します 同じテスト: echo " ";<br>print_r($_FILES);<br>echo " ";
|
|
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
-
2024-10-22 09:46:29
-
2024-10-13 13:53:41
-
2024-10-12 12:15:51
-
2024-10-11 22:47:31
-
2024-10-11 19:36:51
-
2024-10-11 15:50:41
-
2024-10-11 15:07:41
-
2024-10-11 14:21:21
-
2024-10-11 12:59:11
-
2024-10-11 12:17:31