关于request的细节使用,解决中文乱码问题

关于防盗链


Referer
    String ref=request.getHeader("Referer");
    //判断请求头中的referer是否为空或者没东西或者不来自163网站,那么就是盗链行为,直接重定向到原网页
    if(ref==null||"".equals(ref)||!ref.startsWith("http://www.163.com"));
   response.sendRedirect(request.getContextPath()+"index.jsp");

获取客户机的信息
    getRequestURL方法返回客户端发出请求完整URL
    getRequestURI方法返回请求行中的资源名部分
    getQueryString 方法返回请求行中的参数部分
    getRemoteAddr方法返回发出请求的客户机的IP地址
    getMethod得到客户机请求方式
    getContextPath 获得当前web应用虚拟目录名称


遍历jsp页面的所以请求参数

Enumeration<String> enumeration=request.getParameterNames();
while(enumeration.hasMoreElements)
{
String name=enumeration.nextElement();
String values=request.getParameter(name);
System.out.println(name+":"+value);
}



[中文乱码问题]
获取请求参数 
//在JSP页面上模拟响应头,设置字符编码为UTF-8
<meta http-equiv="content-type" content="text/html;charset=UTF-8">
乱码问题:
利用request获取的请求参数,是根据打开jsp页面的浏览器用的什么编码读取,那么
就用什么编码传输,模拟响应头的话相当于固定设置浏览器的读取编码格式
但是在服务器上,默认解析编码的是用的ISO8859-1,
这样就会导致解析中文字节出现乱码。
//通过设置服务器的解析编码方式为UTF-8,这样就可以避免乱码了

request.setCharacterEncoding("UTF-8");
(这只是适用在post请求,因为post请求的请求参数在实体内容当中;get请求不在实体内容当中,在URL后面)



对于get请求方式,出现乱码的话,只能手动解决。
假设前端获取的 usename是乱码 ,
username =new String (username.getBytes("iso8859-1"),"utf-8");
先把从服务器上错误解析的乱码username通过iso8859-1的方式重新解析回去;
在利用utf-8的编码格式去重新解析它。这样就可以达到手动解析,解决乱码了。


response.getWriter().write("中文XX");
这种情况输出会有乱码的话,就需要设置
①response.setContentType("text/html;charset=utf-8");
但是这种情况务必把①放在write内容前面!!!!!


以下这种使用OutputStreamwrite输出,设置放在前后都可以
response.getOutputStream().write("中文国歌".getBytes("utf-8"));
response.setContentType("text/html;charset=utf-8");


request的请求转发

this.getServletContext().getRequestDispatcher("/RequestTest2").forward(request, response);
request.getRequestDispatcher("/RequestTest2").forward(request, response);



request的请求包含
request.getRequestDispatcher("/RequestTest2").include(request, response);


请求转发的话,当前的servlet的输出信息是只能进入服务器的缓冲区,但是一旦执行转发
时,就会清除掉实体内容,请求头信息不会清除,但是这样当前的servlet的信息就输出不了
;而使用请求包含的话就可以顺带输出当前servlet的东西。


 

posted on 2022-11-08 07:36  小目标青年  阅读(238)  评论(0编辑  收藏  举报