阅读目录
- Q1: JavaSE JavaEE JavaME 的区别?
- Q2: Servlet 的作用?
- Q3: WEB中 Servlet < load-on-startup >1</ load-on-startup >标签代表什么意思
- Q5: 如何获取访问的设备类型
- Q6: 如何固定时间自动跳转页面
- Q7: 如何设置一个下载页面
- Q8:如何设置防盗链
- Q9:如何利用 Cookie 判断首次登陆
- Q10: Session
<a id="1">Q1: JavaSE JavaEE JavaME 的区别?</a>
- JavaSE 标准版本
- JavaEE 企业版本
- JavaME 移动版本
<a id="2">Q2: Servlet 的作用?</a>
<a id="3">Q3: WEB中 Servlet < load-on-startup >1</ load-on-startup >标签代表什么意思</a>
- 伴随服务器的启动,启动Servlet
- 标签值中大于0或等于0的表示伴随服务器的启动,自动启动Servlet
- 标签值小于0或者没有标签的表示,选择时再启用
- 其中数值表示优先级,在很多需要启动的 Servlet 中数值越小优先级越大
<a id="4">Q4: 获取文件的真实路径</a>
在做文件处理的情况下,不能把路径写成绝地路径,因为我们最后需要搭建到服务器上,所以把路径写到相对路径上就会省去不必要的麻烦
String realPath=request.getServletContent.getRealPath("");
<a id="5">Q5: 如何获取访问的设备类型</a>
String from=request.getHeader("User-Agent");
if(from.indexOf("Windows")>0){
userFrom ="来自Windows的用户!";
}else if(from.indexOf("Macintosh")>0){
userFrom ="来自 Mac 的用户!";
}else if(from.indexOf("Android")>0){
userFrom ="来自 Android 的用户!";
}else if(from.indexOf("IPhone")>0){
userFrom ="来自 IPhone 的用户!";
}
indexOf(str) 获取第一次出现的字符串索引
<a id="6">Q6: 如何固定时间自动跳转页面</a>
response.setHeader("Refresh","2,URL=路径");
<a id="7">Q7: 如何设置一个下载页面</a>
- 获取文件名称
- 获取文件路径
- 创建文件对象,并判断是否存在
- 设置游览器的的类型为应用下载(application/x-msDownload)
- 设置游览器的下载方式
//获取下载名称
String filename=request.getParameter("filename");
//获取路径名称
String downloadPath=this.getServletContext().getRealPath("/")+"WEB-INF\\Logs\\";
if(file.exists()){
//对游览器进行下载设置
response.setContentType("application/x-msDownload");
//对游览器进行设置,将下载的内容作为附件,并指定文件名
response.setHeader("Content-Disposition", "attachment;filename=\""+filename+"\"");
//打开输入输出流
InputStream inputStream=new FileInputStream(file);
ServletOutputStream servletOutputStream=response.getOutputStream();
//开始进行文件读写
byte[] b=new byte[1024];
int n;
while((n=inputStream.read(b))!=-1){
servletOutputStream.write(b, 0, n);
}
inputStream.close();
servletOutputStream.close();
}else{
//下载不存在
PrintWriter out=response.getWriter();
out.print("下载文件不存在....");
out.flush();
out.close();
}
<a id="8">Q8:如何设置防盗链</a>
referer:当访客访问网页时,HTTP来源地址是前一个网页的URL。
String referer=request.getHeader("referer");
String sitePart="http://"+request.getServerName();
System.out.println(referer+"\n"+sitePart);
if(referer!=null&& referer.startsWith(sitePart)){
if(file.exists()){
//对游览器进行下载设置
response.setContentType("application/x-msDownload");
//对游览器进行设置,将下载的内容作为附件,并指定文件名
response.setHeader("Content-Disposition", "attachment;filename=\""+filename+"\"");
//打开输入输出流
InputStream inputStream=new FileInputStream(file);
ServletOutputStream servletOutputStream=response.getOutputStream();
//开始进行文件读写
byte[] b=new byte[1024];
int n;
while((n=inputStream.read(b))!=-1){
servletOutputStream.write(b, 0, n);
}
inputStream.close();
servletOutputStream.close();
}else{
//下载不存在
PrintWriter out=response.getWriter();
out.print("下载文件不存在....");
out.flush();
out.close();
}
}else{
//跳转到自己的页面
request.getRequestDispatcher("自己的现在地址").format(request,response);
}
<a id="9">Q9:如何利用 Cookie 判断首次登陆</a>
添加 Cookies
Cookie cookie=new Cookie("key",value);
//创建 Cookie 对象,获取出现的 Cookie 的值
Cookie lastCookie=null;
//创建 Cookie 数组用来获取游览器中的所有 Cookie
Cookie[] cookies=request.getCookies();
//遍历所有 cookies
for(int i=0;cookies!=null && i<cookies.length;i++){
if("以前添加键".equals(cookies[i].getName())){
lastCookie=cookies[i].getValue();
break;
}
}
if(lastCookie==null){
response.getWriter.print("欢迎新用户");
}else{
response.getWriter.print("欢迎老用户");
}
Q10: <a id="10">Session</a>
// 获取 Session
HttpSession session=request。getSession();
//存放对象
session.setAttribute("key",value);
网友评论