javaweb之request_response

1、可以通過request API 獲取客戶機的信息
e.g.:獲取當前訪問資源路徑 : request.getRequestURI().substring(
request.getContextPath().length());
獲取請求方式:request.getMethod();

2、獲取信息頭內容

// 獲得所有頭信息內容 ---- 獲得所有頭信息名稱
        Enumeration<String> enumeration = request.getHeaderNames();
        while (enumeration.hasMoreElements()) {
            String name = enumeration.nextElement(); // name 就是一個頭信息名字
            System.out.println(name + ":" + request.getHeader(name));
        }

這裏寫圖片描述

3、通過頭信息進行防盜鏈

// 通過getHeader 獲得referer頭信息
        String referer = request.getHeader("referer");
        // 判斷頭信息 可以知道是不是盜鏈
        response.setContentType("text/html;charset=utf-8");
        if (referer == null || !referer.startsWith("http://localhost")) {
            // 是盜鏈
            response.getWriter().println("是盜鏈");
        } else {
            // 不是盜鏈
            response.getWriter().println("這個真不是盜鏈!");
        }

4、可以獲取jsp或html提交的請求參數

5、獲取打印form表單提交的全部數據

// 打印所有請求提交參數
        // 方式一 : 先獲得所有參數 name ,然後通過name 獲得value
        Enumeration<String> names = request.getParameterNames();
        while (names.hasMoreElements()) {
            String name = names.nextElement();// 獲得每一個參數名稱
            System.out.println(name + ":"
                    + Arrays.toString(request.getParameterValues(name)));
        }


        System.out.println("----------------------------");
        // 方式二 :通過request.getParameterMap
        Map<String, String[]> parameterMap = request.getParameterMap();
        Set<String> keys = parameterMap.keySet();
        for (String key : keys) { // key是參數 name
            System.out.println(key + ":"
                    + Arrays.toString(parameterMap.get(key)));
        }

6、轉發與重定向
區別:轉發是到新的頁面處理同一請求,請求域的數據仍可以使用。重定向是實現了不同的請求,請求的地址也相應的發生變化。

轉發:通過forward方法實現轉發
RequestDispatcherdispatcher=request.getRequestDispatcher(“/b”);
dispatcher.forward(request, response);

重定向:通過sendRedirect方法實現重定向
response.sendRedirect(“/day06/welcome.html”);

7、實現自動跳轉功能

// 通過refresh 頭信息完成跳轉
response.setHeader("refresh","3;url=/day06/response/demo3/result.html");
response.setContentType("text/html;charset=utf-8");// 設置響應編碼
response.getWriter().println("3秒後 將跳轉 result.html頁面!");

8、通過Servlet禁止 緩存

// 禁用瀏覽器緩存
response.setHeader("Cache-Control", "no-cache");
response.setHeader("Pragma", "no-cache");
// 設置expires 因爲日期格式很複雜
// response.setHeader("Expires", "Thu, 01 Dec 1994 16:00:00 GMT");
// 通過 setDateHeader 爲 expires設置 毫秒值 --- 從19701100:00:00毫秒
response.setDateHeader("expires", -1); // 已經過期

9、實現文件下載

response.setContentType(getServletContext().getMimeType(filename));// 設置MIME類型
// tomcat/conf/web.xml
response.setHeader("Content-Disposition", "attachment;filename="
        + filename);

// 下載 讀取目標文件,通過response 將目標文件內容寫到客戶端
// 絕對磁盤路徑 讀取文件
String fullFilename = getServletContext().getRealPath(
        "/response/demo6/" + filename);
    InputStream in = new FileInputStream(fullFilename);
    OutputStream out = response.getOutputStream();
    int b;
    while ((b = in.read()) != -1) {
        out.write(b);
    }
    in.close();
    out.close();

10、編碼與解碼

String s = " +/?%&#";
String s1 = URLEncoder.encode(s, "utf-8");//編碼過程
System.out.println(s1);
String s2 = URLDecoder.decode(s1, "utf-8");//解碼過程
System.out.println(s2);

輸出內容如下:
+%2B%2F%3F%25%26%23
+/?%&#

11、解決輸出到瀏覽器的亂碼問題

//兩行代碼解決亂碼問題:使請求和響應的編碼一致
request.setCharacterEncoding("utf-8");
response.setContentType("text/html; charset=utf-8");
發佈了46 篇原創文章 · 獲贊 3 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章