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設置 毫秒值 --- 從1970年1月1日 00: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");