XXX.php?id=について、XXX.phpの変数idが利用できる条件は何ですか?
私は PHP を初めて使用するので、現時点ではこの問題がよくわかりません。
<br /><?php <br /> include("conn.php"); <br /> if(!empty($_GET['id']))<br /> {<br /> $id=$_GET['id'];<br /> $sql="select * from `user` where `id`='$id'";<br /> $query=mysql_query($sql);<br /> $result=mysql_fetch_array($query);<br /> } <br /> if(!empty($_POST['sub']))<br /> {<br /> //$id=$_GET['id'];<br /> $title=$_POST['title'];<br /> $content=$_POST['content'];<br /> $id=$_POST['hid'];<br /> $sql="update `user` set `title` = '$title', `content` = '$content' where id='$id limit 1'";<br /> mysql_query($sql);<br /> echo "<script> alert('更新完成'); location.href='index.php'</script>";<br /> }<br />?><br /><form action="edit.php" method="post"><br /><input type="hidden" name="hid" value="<?php echo $result['id'] ?>"><br><br />标题<input type="text" name="title" value="<?php echo $result['title'] ?>"><br><br />内容<textarea rows="5" cols="50" name="content"><?php echo $result['content'] ?></textarea><br><br /><input type="submit" name="sub" value="提交"><br /></form><br /><br />
マイクロブログについて説明している php100 のビデオを見ました。ブログの編集機能を実装するには、次のように、index.php に編集リンクを配置します:
<br /><h2 id="php-nbsp-echo-nbsp-result-title-nbsp-br-a-nbsp-href-nbsp-nbsp-edit-php-id-php-nbsp-echo-nbsp-result-id-编辑-a-nbsp-br-a-nbsp-href-nbsp-nbsp-delete-php-id-php-nbsp-echo-nbsp-result-id-删除-a"><?php echo $result['title']; ?><br /> |<a href = "edit.php?id=<?php echo $result['id'];?>">编辑</a> <br /> <a href = "delete.php?id=<?php echo $result['id'];?>">删除</a>|</h2><br />
問題は、edit.php にある場合、2 番目のリンクを直接使用できないのはなぜでしょうか。 ? この ID を呼び出すとき (コード内のコメント行など、その場合、未定義のインデックス ID が報告され、編集は有効になりません)、フォームに非表示を再挿入する必要がありますか?
-----解決策---------
Edit
これはリスト ページから編集ページへの URL である必要があります。 は $_GET を使用して取得されており、コードは正しいです。
内容を変更したら、送信を押します。フォームのメソッドは$_POSTです。 $_GET['id'] には $_POST を使用して取得する必要があるため、当然データはありません。ただし、hidden を追加し、$id=$_POST['hid']; を使用して取得しました。
<br /> if(!empty($_POST['sub']))<br /> {<br /> //$id=$_GET['id'];<br /> $title=$_POST['title'];<br /> $content=$_POST['content'];<br /> $id=$_POST['hid'];<br /> $sql="update `user` set `title` = '$title', `content` = '$content' where id='$id limit 1'";<br /> mysql_query($sql);<br /> echo "<script> alert('更新完成'); location.href='index.php'</script>";<br /> }<br />
コードは次のように最適化できます:
<br />include("conn.php"); <br /><br />if(isset($_POST['sub'])){ // 判斷是否提交表單<br /> $title=$_POST['title'];<br /> $content=$_POST['content'];<br /> $id=$_POST['hid'];<br /> $sql="update `user` set `title` = '$title', `content` = '$content' where id='$id limit 1'";<br /> mysql_query($sql);<br /> echo "<script> alert('更新完成'); location.href='index.php'</script>";<br /> exit();<br />}else{ // 不是提交表單,表示是從列表頁過來<br /> $id=$_GET['id'];<br /> $sql="select * from `user` where `id`='$id'";<br /> $query=mysql_query($sql);<br /> $result=mysql_fetch_array($query);<br />}<br />?><br /><br /><form action="edit.php" method="post"><br /><input type="hidden" name="hid" value="<?php echo $result['id'] ?>"><br><br />标题<input type="text" name="title" value="<?php echo $result['title'] ?>"><br><br />内容<textarea rows="5" cols="50" name="content"><?php echo $result['content'] ?></textarea><br><br /><input type="submit" name="sub" value="提交"><br /></form><br />
-----解決策-------- -- ----------
edit.php には 2 つの異なる関数があり、Weibo を変更するプロセス中に 2 回実行されます
初回: edit.php?id= nnn
には url パラメータがあり、プログラムは if(!empty($_GET['id'])) true 分岐
クエリ データを完了します
フォームに記入します
2 番目のフォームを送信しますtime edit.php
url パラメータはありません。プログラムは if(!empty($_POST['sub'])) true 分岐
データの変更が完了したら、ディレクトリ ページにジャンプします
2 つの条件が同時に true になることはないため、
このプログラムには潜在的な問題があります:
Whenブラウザから edit.php に直接アクセスする場合、次の 2 つの理由により、どの条件も当てはまりません。フォームに入力するとエラーが発生し、サーバー レイアウトが表示されます
エラー チェックが無視される場合、これは新しい Weibo 入力になるはずです。ただし、edit.php には新しい Weibo 処理コード
が含まれておらず、これを変更すると ID がないため変更に失敗します。また、「アップデート完了」という誤った情報も提供します

thesecrettokeepingaphp-poweredwebsterunningsmootlyunderheavyloadinvolvesseveralkeystrategies:1)emform opcodecoduceSciptionexecutiontime、2)aatabasequerycachingwithiThing withiThistolessendavasoload、

コードをより明確かつ維持しやすくするため、依存関係が関心(DI)に注意する必要があります。 1)DIは、クラスを切り離すことにより、よりモジュール化されます。2)テストとコードの柔軟性の利便性を向上させ、3)DIコンテナを使用して複雑な依存関係を管理しますが、パフォーマンスの影響と円形の依存関係に注意してください。

はい、最適化されたAphPossibleandessention.1)CachingingusapCutoredatedAtabaseload.2)最適化、効率的なQueries、およびConnectionPooling.3)EnhcodeCodewithBultinctions、Avoididingglobalbariables、およびUsingopcodeching

keyStrategIestsoSificlyvoostphpappliceperformanceare:1)useopcodecachinglikeToreexecutiontime、2)最適化abaseの相互作用とプロペラインデックス、3)3)構成

aphpDependencyInjectionContaineriSATOULTAINATINAGECLASSDEPTINCIES、強化測定性、テスト可能性、および維持可能性。

SELECT DEPENTENCINGINOFCENT(DI)大規模なアプリケーションの場合、ServicElocatorは小さなプロジェクトまたはプロトタイプに適しています。 1)DIは、コンストラクターインジェクションを通じてコードのテスト可能性とモジュール性を改善します。 2)ServiceLocatorは、センター登録を通じてサービスを取得します。これは便利ですが、コードカップリングの増加につながる可能性があります。

phpapplicationscanbeoptimizedforspeedandEfficiencyby:1)enabingopcacheinphp.ini、2)PreparedStatementswithpordatabasequeriesを使用して、3)LoopswithArray_filterandarray_mapfordataprocessing、4)の構成ngincasaSearverseproxy、5)

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

WebStorm Mac版
便利なJavaScript開発ツール
