Form.action 値の転送の問題

Aug 31, 2016 am 08:41 AM

ブラウザのアドレスバーに URL を入力し、? を介してパラメータを渡してリソースをリクエストすると、? の後のパラメータは「クエリ文字列」と呼ばれ、バックグラウンド サーブレットの doGet() をトリガーします。ブラウザのアドレス バーは GET メソッドです。


パラメータの受け渡しに対するフォームのメソッド属性の影響を見てみましょう。

元のフォーム:








最初のケース:
上記フォームの action 属性が記述されていない場合、直接「Submit」ボタンをクリックすると、フォームの submit イベントがトリガーされます。この時点で、Firefox ブラウザのコンソールから確認できます:
メッセージ ヘッダーには次の重要な情報が含まれています: (1) リクエスト アドレスの後にパラメータを渡すための「?」が続きます (2) リクエスト メソッドは GET です。




パラメータ情報: クエリ文字列




フォームのメソッド属性を指定する場合:







2 番目のケース:
メッセージ ヘッダーには次の重要な情報が含まれます: (1) リクエストの背後アドレス パラメータは渡されません (2) リクエストメソッドは POST



パラメータ情報: フォームデータ




上記 2 つのメソッドの応答は、更新後に現在のページを表示することです。フォームには action 属性が指定されていないため、デフォルトの送信アドレスは現在のページです。

次に、action 属性を指定してサーブレットにアクセスし、method 属性について詳しく学習します。

TestServlet.java コア ソース コード:

@WebServlet("/servlet/TestServlet")
public class TestServlet extends HttpServlet {
private staticfinallongserialVersionUID = 1L;

protected void doGet(HttpServletRequest request, HttpServletResponse response) throwsサーブレット例外、IOException {
response.getWriter().print("doGet()");
}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException、IOException {
response.getWriter().print(" doPost( )");
}

}


3 番目のケース: Method="get" action="/test/servlet/TestServlet"








4 番目のケース: Method="post" action="/test/servlet/TestServlet"




< ;

上記のメッセージ ヘッダーとパラメーターは最初のケースと同じですが、バックグラウンドは doPost() で応答します。





TestServlet.java パラメータを取得するコードを追加します:
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String param = request.getParameter("type");
response.getWriter() .print ("doGet() get type="+param);
}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String param = request.getParameter("type");
response. getWriter( ).print("doPost() get type="+param);
}


5 番目のケース、method="get" は、アクションの後にパラメーター action = "/servlet/TestServlet?type=01" を渡します。 、同時にバックグラウンドサーブレットのパラメータを取得します

この時のブラウザのアドレスバー: http://localhost:8080/test/servlet/TestServlet?username=



バックグラウンドのdoGet()ではパラメータの型を取得できないことが分かります。
同時に「クエリ文字列」に型パラメータが追加されていないことが分かります






6 番目のケース、method="post" はアクションの後にパラメーター action = "/servlet/TestServlet?type=01" を渡し、同時にバックグラウンド サーブレットのパラメーターを取得します




バックグラウンドの doPost() がパラメーターの型を 取得できることがわかります。
同時に、パラメータ列は以前とは少し異なります:
「クエリ文字列」と「フォームデータ」の両方があります




したがって、上記は私たちに啓示を与えます。つまり、フォームのアクションの後にパラメーターを渡すときは、フォームのメソッド = "post" を手動で指定する必要があります。そうしないと、 ? の背後にあるパラメータ
誤解: 以前は、ブラウザのアドレス バーの URL を通じてパラメータを渡していましたが、?これを実現するには、最終的に doGet() メソッドを呼び出します。そのため、フォーム (デフォルトのメソッド = "get") のアクションを渡すことができると思いますか?高麗人参を伝えに来てください。


最後の理由: (個人的な要約) get メソッドでフォーム データを送信するとき、URL はフォーム データを「クエリ文字列」に組み立てて、アクションで指定された URL に送信するだけです。 URL は再編成後に失われるため、元の ? メソッドで渡されたパラメータは送信されません。

ただし、フォームがポストモードで送信されると、フォームデータと?以降のパラメータが別々に保存され、フォーム内のアクションで指定されたURLにまとめて送信されます。

(参考リソース) HTML フォーム: なぜアクションに get 値を含めることができないのですか?
http://stackoverflow.com/questions/3548795/html-form-why-action-cant-have-get-value-in -それ




このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

HTMLは初心者のために簡単に学ぶことができますか? HTMLは初心者のために簡単に学ぶことができますか? Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTML、CSS、およびJavaScriptの理解:初心者向けガイド HTML、CSS、およびJavaScriptの理解:初心者向けガイド Apr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTML、CSS、およびJavaScriptの役割:コアの責任 HTML、CSS、およびJavaScriptの役割:コアの責任 Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTML、CSS、およびJavaScript:Web開発者に不可欠なツール HTML、CSS、およびJavaScript:Web開発者に不可欠なツール Apr 09, 2025 am 12:12 AM

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

HTML:構造、CSS:スタイル、JavaScript:動作 HTML:構造、CSS:スタイル、JavaScript:動作 Apr 18, 2025 am 12:09 AM

Web開発におけるHTML、CSS、およびJavaScriptの役割は次のとおりです。1。HTMLは、Webページ構造を定義し、2。CSSはWebページスタイルを制御し、3。JavaScriptは動的な動作を追加します。一緒に、彼らは最新のウェブサイトのフレームワーク、美学、および相互作用を構築します。

HTMLの未来:ウェブデザインの進化とトレンド HTMLの未来:ウェブデザインの進化とトレンド Apr 17, 2025 am 12:12 AM

HTMLの将来は、無限の可能性に満ちています。 1)新機能と標準には、より多くのセマンティックタグとWebComponentsの人気が含まれます。 2)Webデザインのトレンドは、レスポンシブでアクセス可能なデザインに向けて発展し続けます。 3)パフォーマンスの最適化により、応答性の高い画像読み込みと怠zyなロードテクノロジーを通じてユーザーエクスペリエンスが向上します。

HTML対CSS対JavaScript:比較概要 HTML対CSS対JavaScript:比較概要 Apr 16, 2025 am 12:04 AM

Web開発におけるHTML、CSS、およびJavaScriptの役割は次のとおりです。HTMLはコンテンツ構造を担当し、CSSはスタイルを担当し、JavaScriptは動的な動作を担当します。 1。HTMLは、セマンティクスを確保するためにタグを使用してWebページの構造とコンテンツを定義します。 2。CSSは、セレクターと属性を介してWebページスタイルを制御して、美しく読みやすくします。 3。JavaScriptは、動的でインタラクティブな関数を実現するために、スクリプトを通じてWebページの動作を制御します。

HTML、CSS、およびJavaScriptの未来:Web開発動向 HTML、CSS、およびJavaScriptの未来:Web開発動向 Apr 19, 2025 am 12:02 AM

HTMLの将来の傾向はセマンティクスとWebコンポーネントであり、CSSの将来の傾向はCSS-in-JSとCSShoudiniであり、JavaScriptの将来の傾向はWebAssemblyとServerLessです。 1。HTMLセマンティクスはアクセシビリティとSEO効果を改善し、Webコンポーネントは開発効率を向上させますが、ブラウザの互換性に注意を払う必要があります。 2。CSS-in-JSは、スタイル管理の柔軟性を高めますが、ファイルサイズを増やす可能性があります。 CSShoudiniは、CSSレンダリングの直接操作を可能にします。 3. Webassemblyブラウザーアプリケーションのパフォーマンスを最適化しますが、急な学習曲線があり、サーバーレスは開発を簡素化しますが、コールドスタートの問題の最適化が必要です。

See all articles