※ 1. 客户端向服务器发请求并且传参(get/post)
客户端向服务器发送请求可以是get方式也可以是post方式
(1. 哪些方式的请求属于get/post方式
※ get方式:
a. 浏览器中输入地址(URL)然后回车
b. 超链接
c. 页面中引入的css样式文件
d. 页面中引入的js的文件(javascript)
e. <img src="image/a.jpg"/>
f. form表单中method=“get”
g. ajax中可以设置异步提交请求的方式为get
h. 其他
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<!--css样式-->
<link rel="stylesheet"
type="text/css" href="css/test.css"/>
<!-- 引入一个js文件 -->
<script type="text/javascript" src="js/test.js"></script>
</head>
<body>
<img id="img" src="images/test.png">
<button onclick="max()">放大</button><br>
<!--超链接-->
<a href="test.html">点击</a>
</body>
</html>
※ post方式:
a. from表单中method=“post”
b. ajax中可以设置同步提交请求的方式为post
c. 其他
(2. get和post的特点及其区别
它们各自的特点及其区别主要是体现在所传递的参数上面。
※ a. get方式参数
参数是直接放在要求url后面的
例如:
url?参数名=参数值&参数名=参数值
要请求的url为:
http://ip:port/WebTest/firstServlet
传参:
.../firstServlet?name=tom
.../firstServlet?name=tom&age=20
这种方式传参的特点:
1.参数直接放在url后面
2.从浏览器的地址栏里面可以直接看到所传的参数
3.参数的长度有限制,不能把一个很长的数据通过get方式传参(与浏览器种类有关)
※ b. post方式传参
参数是放在请求的体部的。
(浏览器发送的请求可以大致的分为请求头+请求体)
这种方式传参的特点:
1.参数放在请求的体部而不是url后面。
2.浏览器的地址栏中看不到所传的参数。
3.因为参数不用出现在地址栏里面,所有参数长度不限。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<!-- get提交数据拼接在请求资源名称后面
拼接?拼接,参数地址栏可见
get方式拼接参数有大小限制
,多个参数&拼接
action指向的是资源名称,资源名称
前面没有斜杠,资源名称替换
最后一个斜杠的内容
registerSer?name=&passwd=
如果action前面加斜杠,资源拼接在
端口号后面
注意:如果将来请求访问的是Servlet类
,url-pattern必须和项目名字后面的内容
匹配
post方式提交数据,参数拼接在
http请求的体部,参数之间拼接用
&
-->
<form action="registerSer"
method="post">
<!-- <form action="registerSer" method="get"> -->
姓名:<input type="text" name="name"/><br>
密码:<input type="text" name="passwd"/><br>
<!-- hoby=0&hoby=1&hoby=2&hoby=3 -->
爱好:<input type="checkbox" name="hoby" value="0"/>篮球
<input type="checkbox" name="hoby" value="1"/>足球
<input type="checkbox" name="hoby" value="2"/>羽毛球
<input type="checkbox" name="hoby" value="3"/>橄榄球<br>
<input type="submit" value="注册"/>
</form><br>
<!--
http://127.0.0.1:8888/jd1812_web/user/form.html
http://127.0.0.1:8888/jd1812_web/user/user/registerSer
http://127.0.0.1:8888/jd1812_web/user/registerSer
http://127.0.0.1:8888/jd1812_web/user/registerSer?hoby=0&hoby=1&hoby=%E4%B8%AD
-->
<a href="registerSer?hoby=0&hoby=1&hoby=中">点击</a><br>
</body>
</html>
package com.briup.web.Servelt;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.ServerSocket;
import java.net.Socket;
/*
* 接受HTTP协议请求
* 请求行(请求方式 资源名称 协议)
*
* 请求头(key: value)
*
* 请求体
*/
public class TomcatSer {
public static void main(String[] args) {
try {
ServerSocket server=
new ServerSocket(8888);
Socket socket=server.accept();
BufferedReader br=
new BufferedReader(
new InputStreamReader(
socket.getInputStream()));
String str=null;
//请求行
str=br.readLine();
System.out.println("请求行");
System.out.println(str);
System.out.println("请求头");
while((str=br.readLine())!=null){
System.out.println(str);
if(str.trim().length()==0){
break;
}
}
char[] c=new char[100];
int len=0;
while((len=br.read(c))!=-1){
System.out.println(new String(c,0,len));
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
※ 2. servlet中接收客户端传过来的参数
客户端都是以这样的形式传参的:
参数名字=参数值
所有在servlet中我们需要的参数名字来拿到参数值:
String value=request.getParameter("key");
其中key就是参数名字,value是参数值,不管传的值本身是什么类型,servlet中接收到以后只能是字符串类型或者字符串类型数组。
如果客户端同的多选框,这个时候传过来的参数就要用一个字符串数组来接收:
String [] like=req.getParameterValues("like");
在表单中,参数值就是用户所填写的内容或者所选的选项的value属性值,参数名字就是每个input或者其他输入元素的name属性的值。
例如:
<input type="text" name="username">
参数名字就是name属性的值:username
参数的值就是将来用户所填内容。
在servlet中,不管是get方式提交的时候还是post方式提交的时候,来到servlet里面以后,都是用相同的方式来取得数据。
rpquest.getParameter("key");
request.getParameterValues("key");//多个重复的