java request怎么定义_HttpServletRequest对象方法的用法小结

深入体验JavaWeb开发内幕——关于HttpServletRequestRequest对象

HttpServletRequest对象代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP请求头中的所有信息都封装在这个对象中,开发人员通过这个对象的相关方法,即可以获得客户的这些信息。

一、通过request常用方法获得相关信息:

1、通过request常用方法获得客户机信息

getRequestURL方法返回客户端发出请求时的完整URL。

getRequestURI方法返回请求行中的资源名部分。

getQueryString 方法返回请求行中的参数部分。

getRemoteAddr方法返回发出请求的客户机的IP地址

getRemoteHost方法返回发出请求的客户机的完整主机名

getRemotePort方法返回客户机所使用的网络端口号

getLocalAddr方法返回WEB服务器的IP地址。

getLocalName方法返回WEB服务器的主机名

getMethod得到客户机请求方式

例如在Request.Java中加入如下代码:

//返回相关请求的信息

String uri=request.getRequestURI();

Stringrad = request.getRemoteAddr();

Stringrh = request.getRemoteHost();

Stringru = request.getRemoteUser();

intrp = request.getRemotePort();

Stringcp = request.getContextPath();

Stringla = request.getLocalAddr();

Stringce = request.getCharacterEncoding();

Stringgm = request.getMethod();

Stringqs = request.getQueryString();

System.out.println(uri);

System.out.println(rad);

System.out.println(rh);

System.out.println(ru);

System.out.println(rp);

System.out.println(cp);

System.out.println(la);

System.out.println(ce);

System.out.println(gm);

System.out.println(qs);

即可获取相关信息。

2、通过request常用方法获得客户机请求头信息

getHead(name)方法

getHeaders(String name)方法

getHeaderNames方法

如:

private void getRequestValue(HttpServletRequest request) {

//获得客户机请求头及请求头的值

System.out.println(request.getHeader("method"));

Enumeration e = request.getHeaderNames();

while(e.hasMoreElements()){

String name = (String)e.nextElement();

String value = request.getHeader(name);

System.out.println(name+":"+value);

}

}

3.获得客户机请求参数(客户端提交的数据)

getParameter(name):获取指定名称的参数值。这是最为常用的方法之一。

getParameterValues(String name):获取指定名称参数的所有值数组。它适用于一个参数名对应多个值的情况。如页面表单中的复选框,多选列表提交的值。

getParameterNames():返回一个包含请求消息中的所有参数名的Enumeration对象。通过遍历这个Enumeration对象,就可以获取请求消息中所有的参数名

getParameterMap():返回一个保存了请求消息中的所有参数名和值的Map对象。Map对象的key是字符串类型的参数名,value是这个参数所对应的Object类型的值数组。

二、request的常见应用

1、 各种表单输入项数据的获取

如可以获取form表单中的text、password、radio、checkbox、 file、select、textarea、 hidden、image、button等组件的值进行数据库操作或其他处理操作。

来看一个具体应用:

bc6f8a99526e76669ee4efd5f5c41b5b.png

界面代码主体部分如下:

Register.html

Register.html

用户名:

密码:

性别:男

籍贯:

河北

湖北

山西

简历:

&nsp;

爱好:

唱歌

跳舞

读书

看报

上传头像:

然后,定义一个RequestLogin.java类通过request对象获取表单中组件的值:

如调用自定义方法:

private void getInformation(HttpServletRequest request)

throws UnsupportedEncodingException {

//取出参数值

String name = request.getParameter("username");

String pass = request.getParameter("password");

String sex = request.getParameter("sex");

String city = request.getParameter("city");

String intro = request.getParameter("intro");

String [] hobbies = request.getParameterValues("hobbies");

String hobby ="";

//hobbies!=null对所取值为空时进行设置

for(int i=0;hobbies!=null&&i

{ String hovalue = hobbies[i]; hobby += hovalue; }

//获取头像信息 // String image = request.getParameter("image");

System.out.println("username:"+name);

System.out.println("password:"+pass);

System.out.println("sex:"+sex); System.out.println("city:"+city);

System.out.println("intro:"+intro); System.out.println("hobby:"+hobby);}

即可获取表单中组件的值。

2、请求参数的中文乱码问题

前面我们提到了Response对象中出现乱码问题及相应的解决措施,那么在Request中如何解决编码问题呢?

下面来看具体的例子:

例如我想将一个form表单中的信息提取到并在控制台输出如图:

7e7aa8a522ad4b9ef24d576c61384eaf.png

假设在服务端并未Request对象给指定编码时即服务器端接收请求的字符编码为ISO8859-1,这时你在客户端添加信息如:

f59a13b228e8a5bf211a6d162638fc7c.png

当填入的信息有中文时,假设设置表单的提交方式为post方式提交

则在服务端输出如下:

8998b508d61528c222c392fa89e4a7d4.png

此时输出结果出现乱码。

客户端主体代码同上:

Register.html

用户名:

密码:

性别:男

籍贯:

河北

湖北

山西

简历:

&nsp;

爱好:

唱歌

跳舞

读书

看报

上传头像:

服务端主体代码如下:

RequestLogin.java

package net.csdn.request;

import java.io.IOException;

import java.io.PrintWriter;

importjava.io.UnsupportedEncodingException;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

importjavax.servlet.http.HttpServletRequest;

importjavax.servlet.http.HttpServletResponse;

public class RequestLogin extendsHttpServlet

{

public void doGet(HttpServletRequest request,HttpServletResponse response)

throws ServletException, IOException

{

getInformation(request);

}

private voidgetParameter(HttpServletRequest request)

throws UnsupportedEncodingException

{

private voidgetInformation(HttpServletRequest request)

throws UnsupportedEncodingException {

//取出参数值

String name =request.getParameter("username");

String pass =request.getParameter("password");

String sex =request.getParameter("sex");

String city =request.getParameter("city");

String intro = request.getParameter("intro");

String [] hobbies =request.getParameterValues("hobbies");

String hobby ="";

//hobbies!=null对所取值为空时进行设置

for(inti=0;hobbies!=null&&i

{ String hovalue = hobbies[i]; hobby +=hovalue; }

//获取头像信息 // String image = request.getParameter("image");

System.out.println("username:"+name);

System.out.println("password:"+pass);

System.out.println("sex:"+sex);System.out.println("city:"+city);

System.out.println("intro:"+intro);System.out.println("hobby:"+hobby);}

public void doPost(HttpServletRequestrequest, HttpServletResponse response)

throws ServletException, IOException{doGet(request, response);}}

这里会出现乱码问题,是因为你在RegisterLogin.java中并没有给Request对象设置编码集,而Request对象的默认编码集是ISO8859-1是不支持汉字的,所以你只需要在此类中为其指明相应的编码即可:

改正:在doGet方法中加入如下代码指明接收请求的编码方式:

request.setCharacterEncoding("utf-8");

即可输出:

825c4c2c7bda48df92c98b5161c1d39d.png

但是这种修改方式只在提交方式为post时才有效。当提交方式为get时是不起作用的。

即;

时即便在

RequestLogin.java

中再设置

request.setCharacterEncoding("utf-8");

也不会起任何作用了程序还会输出如图所示信息:

1665cf96478592e37d3bb3d2eb1f295c.png

这时就需要在

RequestLogin.java

中含有中文的地方进行如下设置了即在doGet方法中加入如下代码:

String username = new String(name.getBytes("iso8859-1"),"utf-8");

String introduction = new String(intro.getBytes("iso8859-1"),"utf-8");

System.out.println("username:"+username);

System.out.println("password:"+introduction);

此时再度测试时就OK了!如图

ec1bffb6ad22e76f99813931999b8972.png

好了到这里,你大概已经知道该如何对Response和Request对象中的乱码问题进行操作了吧!

3、防盗链

所谓的防盗链就是当你以一个非正常渠道去访问某一个Web资源的时候,服务器会将你的请求忽略并且将你的当前请求变为按正常渠道访问时的请求并返回到相应的页面,用户只有通过该页面中的相关操作去访问想要请求的最终资源。

例如,你有一个访问某资源的网址,但是你事先不知道这个网址是有防盗链的,那么当你输入该网址时你可能会发现,并没有马上跳转到你想要的资源页面而是一些无关的信息页面,但是就是在这些信息页面中你发现有一个超链接或是其他操作可以跳转到你所访问的最终资源页面。

这就是防盗链技术了,好了来看一个具体应用:

Rquest.java

public class Request extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {getDoorChain(request, response);}

private void getDoorChain(HttpServletRequest request,

HttpServletResponse response) throws IOException {

//通过request获取请求头参数

String referer = request.getHeader("referer");

if(referer==null || !referer.endsWith("http://localhost:8080/Request/index.jsp")){

response.sendRedirect("http://localhost:8080/Request/index.jsp");

return;

}

response.setCharacterEncoding("utf-8");

response.setContentType("text/html;charset =utf-8");

PrintWriter pw = response.getWriter();

pw.write("喜剧片《东成西就》");

}

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

doGet(request, response);

}

}

index.jsp部分的主体代码:

这里是防盗链技术的应用检测!

喜剧片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值