为啥通过MSIE判断浏览器信息
生活随笔
收集整理的這篇文章主要介紹了
为啥通过MSIE判断浏览器信息
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
看到這么一段代碼:
?
@RequestMapping(value="/download")public ResponseEntity<byte[]> download(HttpServletRequest request,@RequestParam("filename") String filename,@RequestHeader("User-Agent") String userAgent,//這里之所以需要請求頭,是因為請求頭中包含瀏覽器信息Model model)throws Exception{// 下載文件路徑String path = request.getServletContext().getRealPath("/upload/");System.out.println("path="+path);// 構建FileFile file = new File(path+File.separator+ filename);// ok表示Http協議中的狀態 200BodyBuilder builder = ResponseEntity.ok();// 內容長度builder.contentLength(file.length());// application/octet-stream : 二進制流數據(最常見的文件下載)。builder.contentType(MediaType.APPLICATION_OCTET_STREAM);// 使用URLDecoder.decode對文件名進行解碼filename = URLEncoder.encode(filename, "UTF-8");// 設置實際的響應文件名,告訴瀏覽器文件要用于【下載】、【保存】attachment 以附件形式// 不同的瀏覽器,處理方式不同,要根據瀏覽器版本進行區別判斷if (userAgent.indexOf("MSIE") > 0){// 如果是IE,只需要用UTF-8字符集進行URL編碼即可builder.header("Content-Disposition", "attachment; filename=" + filename);}else{// 而FireFox、Chrome等瀏覽器,則需要說明編碼的字符集// 注意filename后面有個*號,在UTF-8后面有兩個單引號!builder.header("Content-Disposition", "attachment; filename*=UTF-8''" + filename);}return builder.body(FileUtils.readFileToByteArray(file));}}?
為啥這個視圖函數中包含了User-Agent這種請求頭呢?貌似刪除后也可以正常運行啊。
這是因為請求頭中包含了瀏覽器信息。
這里的MSIE的意思是:Microsoft Internet Explorer.
?
?
if (userAgent.indexOf("MSIE") > 0)
這句代碼的意思是:
判斷請求頭的瀏覽器信息中包含IE瀏覽器的信息。
?
?
?
總結
以上是生活随笔為你收集整理的为啥通过MSIE判断浏览器信息的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: springboot抑制log中的inf
- 下一篇: HTML 文档的字符编码未声明。如果该文