后端获取URL和参数

一:获取URL

1.Request.getRequestURL

    返回的是请求的全部,包括http协议、端口号、servlet名字和映射路径,但不包含请求参数。

     结果:http://localhost:8080/jqueryWeb/resources/request.html

2.Request.getRequestURI

    返回的是url的部分,即相对路径。

     结果/jqueryWeb/resources/request.html


二: 获取参数列表

1.getQueryString()

    只适用于GET,比如客户端发送http://localhost/testServlet?a=b&c=d&e=f,

通过request.getQueryString()得到的是a=b&c=d&e=f。之后再根据字符串切割获取想要的参数值。


2.getParameter()

    GET和POST都可以使用,获取的是括号里的参数对应的值。

但如果是POST请求要根据<form>表单提交数据的编码方式来确定能否使用。
当编码方式是(application/x- www-form-urlencoded)时才能使用。
这种编码方式(application/x-www-form-urlencoded)虽然简单,但对于传输大块的二进制数据显得力不从心。
对于传输大块的二进制数这类数据,浏览器采用了另一种编码方式("multipart/form-data"),这时就需要使用下面的两种方法。

3.getInputStream()


4.getReader()

    上面两种方法获取的是Http请求包的包体,因为GET方式请求一般不包含包体.所以上面两种方法一般用于POST请求获取参数。


需要注意的是:
request.getParameter()、 request.getInputStream()、request.getReader()这三种方法是有冲突的,因为流只能被读一次。
比如:
    当form表单内容采用 enctype=application/x-www-form-urlencoded编码时,先通过调用request.getParameter()方法得到参数后,
再调用request.getInputStream()或request.getReader()已经得不到流中的内容,
因为在调用 request.getParameter()时系统可能对表单中提交的数据以流的形式读了一次,反之亦然。

当form表单内容采用 enctype=multipart/form-data编码时,即使先调用request.getParameter()也得不到数据,
所以这时调用request.getParameter()方法对 request.getInputStream()或request.getReader()没有冲突,
即使已经调用了 request.getParameter()方法也可以通过调用request.getInputStream()或request.getReader()得到表单中的数据,

而request.getInputStream()和request.getReader()在同一个响应中是不能混合使用的,如果混合使用就会抛异常。


上述部分来源于:https://www.cnblogs.com/xiancheng/p/5524338.html

猜你喜欢

转载自blog.csdn.net/weixin_42456466/article/details/80689025