一、Cookie总结
保存在客户端;中文文件下载:针对浏览器类型,对文件名字做编码处理Firefox(Base64)、IE、Chrome…使用的是URLEncoder.
/*
* 如果文件的名字带有中文,那么需要对这个文件名进行编码处理
* 如果是IE ,或者 Chrome (谷歌浏览器) ,使用URLEncoding 编码
* 如果是Firefox , 使用Base64编码
*/
//获取来访的客户端类型
String clientType = request.getHeader(“User-Agent”);
if(clientType.contains("Firefox")){
fileName = DownLoadUtil.base64EncodeFileName(fileName);
}else{
//IE ,或者 Chrome (谷歌浏览器) ,
//对中文的名字进行编码处理
fileName = URLEncoder.encode(fileName,"UTF-8");
}
二、重定向与请求转发的区别
(1) 重定向的路径可以是任意路径,是两次请求次数,参数即跳转的位置,两种写法:
//1、以前的写法
response.setStatus(302);
response.setHeader(“Location”, “login_success.html”);
//2、重定向写法: 重新定位方向 参数即跳转的位置
response.sendRedirect("login_success.html");
//1. 地址上显示的是最后的那个资源的路径地址
//2. 请求次数最少有两次, 服务器在第一次请求后,会返回302 以及一个地址, 浏览器在根据这个地址,执行第二次访问。
//3. 可以跳转到任意路径。 不是自己的工程也可以跳。
//4. 效率稍微低一点, 执行两次请求。
//5. 后续的请求,没法使用上一次的request存储的数据,或者 没法使用上一次的request对象,因为这是两次不同的请求。
(2)请求转发:一次请求,路径只能是本项目下的路径,参数即为要跳转的位置
request.getRequestDispatcher(“login_success.html”).forward(request, response);
//1. 地址上显示的是请求servlet的地址。 返回200 ok
//2. 请求次数只有一次, 因为是服务器内部帮客户端执行了后续的工作。
//3. 只能跳转自己项目的资源路径 。
//4. 效率上稍微高一点,因为只执行一次请求。
//5. 可以使用上一次的request对象。
概念:饼干,其实就是一份小数据,是服务器给客户端,并且存储在客户端上的一份小数据(在客户端上)。使用场景,自动登录、浏览记录、购物车。
cookie的作用:http的请求是无状态的,客户端与服务器在通讯的时候,是无状态的,其实就是客户端在第二次来访的时候,服务器根本就不知道这个客户端以前有没有来访问过。为了更好的用户体验,更好的交互【自动登录】,其实从公司层面讲,就是为了更好的收集用户习惯【大数据】。
1、添加Cookie给客户端:
//1-1、在响应的时候添加cookie;
Cookie cookie=new Cookie(“aa”,“bb”);
//1-2给响应添加一个cookie
response.addCookie(cookie);
//2、客户端接收的信息里面,响应头中多了一个字段set-Cookie
//3、获取客户端带过来的cookie
Cookie[] cookies=request.getCookies();
if(cookies!=null){
for(Cookie c:cookies){
String cookieName=c.getName();
String cookieValue=c.getValue();
System.out.println(cookieName+"="+cookieValue);
}
}
2、cookie的有效期:
//关闭浏览器后,cookie就没有了。 —> 针对没有设置cookie的有效期。
// expiry: 有效 以秒计算。
//正值 : 表示 在这个数字过后,cookie将会失效。
//负值: 关闭浏览器,那么cookie就失效, 默认值是 -1
cookie.setMaxAge(60 * 60 * 24 * 7);
//赋值新的值
//cookie.setValue(newValue);
//用于指定只有请求了指定的域名,才会带上该cookie
cookie.setDomain(".itheima.com");
//只有访问该域名下的cookieDemo的这个路径地址才会带cookie
cookie.setPath("/CookieDemo");
JSP中的定义变量:
//全局变量
<%! int a=99; %>
//局部变量
<% int b=999; %>
3、清除cookie
删除cookie是没有什么delete方法的,只有设置maxAge为0。
Cookie cookie=new Cookie(“history”,"");
cookie.setMaxAge(0);//设置立即删除
cookie.setPath("/CookieDemo02");
response.addCookie(cookie);
Cookie的安全问题:由于Cookie会保存在客户端,所以有安全隐患问题。还有一个问题,Cookie的大小与个数有限制,为了解决这个问题——》Session。
Session
保存在服务器端
概念:会话,Session是基于Cookie的一种会话机制,Cookie是服务器返回一小份数据给客户端,并且存放在客户端上,Session是数据存放在服务器端。
常用API:
//得到会话ID
string id=session.getId();
//存值
session.setAttribute(name,value);
//取值
session.getAttribute(name);
//移除值
session.removeAttribute(name);
//强制干掉会话,里面存放的数据都没有
session.invalidate();
Session的创建:如果有在servlet里面调用了request.getSession();Session的销毁:关闭浏览器、session会话时间过期,有效期过了,默认有效期30分钟。
session是存放在服务器的内存中的一份数据,可以持久化,Redis。即使关了浏览器,session也不会销毁。
ServletContext总结
Servlet配置方式:
1、全路径配置:以/开始 /a/aa/bb—localhost:8080/项目名/aa/bb
2、路径匹配,前半段匹配:以/开始,但是以结束 /a//----localhost:8080/项目名/aa/bb
3、以扩展名匹配:没有/ ,以开始 *.aa *.bb
ServletContext:servlet上下文,每个web工程都只有一个ServletContext对象。说白了也就是不管在那个servlet里面,获取到这个类的对象都是同一个。
//获取对象
ServletContext context=getServletContext();
Java在web页面上的编码解码处理及中文URL乱码解决
pdf
0星
超过10%的资源
242KB
下载
作用:1、获取全局变量;2、获取web工程中的资源;3、存取数据,servlet间共享数据域对象。
可以获取web应用中的资源:
//1. 获取资源在tomcat里面的绝对路径
// 先得到路径,然后自己new InpuStream
context.getRealPath("") //这里得到的是项目在tomcat里面的根目录。
//D:\tomcat\apache-tomcat-7.0.52\apache-tomcat-7.0.52\wtpwebapps\Demo03\
String path = context.getRealPath(“file/config.properties”);
//D:\tomcat\apache-tomcat-7.0.52\apache-tomcat-7.0.52\wtpwebapps\Demo03\file\config.properties
//2、getResourceAsStream 获取资源流对象
//直接给相对的路径,然后获取流对象。
ServletContext的创建与销毁:服务器启动的时候,会为托管的每一个web应用程序,创建一个ServletContext;从服务器移除托管,或者是关闭服务器
作用范围:只要在这个项目里面,都可以取。A项目存,B项目取,是取不到的,ServletContext的对象不同。
HtttpServletRequest总结
这个对象封装了客户端提交过来的一切数据
获取数据:
//单个数据
String name=request.getParameter(“name”);
//多个数据
Map<String,String[]> map=request.getParameterMap();
Set keySet = map.keySet();
Iterator iterator = keySet.iterator();
while (iterator.hasNext()) {
String key = (String) iterator.next();
System.out.println(“key=”+key + “–的值总数有:”+map.get(key).length);
String value = map.get(key)[0];
String value1 = map.get(key)[1];
String value2 = map.get(key)[2];
System.out.println(key+" ======= "+ value + "=" + value1 + "="+ value2);
}
1
2
获取中文数据:客户端提交数据给服务器端,如果带有中文的话会出现乱码现象。
GET方式:
String username=request.getParameter(“username”);
String password=request.getParameter(“password”);
System.out.println(“userName=”+username+"==password="+password);
//get请求过来的数据,在url地址栏上就已经经过编码了,所以我们取到的就是乱码,
//tomcat收到了这批数据,getParameter 默认使用ISO-8859-1去解码
//先让文字回到ISO-8859-1对应的字节数组 , 然后再按utf-8组拼字符串
username = new String(username.getBytes(“ISO-8859-1”) , “UTF-8”);
System.out.println(“userName=”+username+"==password="+password);
//直接在tomcat里面做配置,以后get请求过来的数据永远都是用UTF-8编码。
//可以在tomcat里面做设置处理conf/server.xml加上URIEncoding=“utf-8”
Post方式:
request.setCharacterEncoding(“utf-8”);
//这行设置一定要写在getParameter之前
HttpServletResponse总结
负责返回数据给客户端
输出数据到页面上
//以字符流的方式写数据
response.getWriter().write(“
hello response…
”);
//以字节流的方式写数据
response.getOutputStream().write("hell0 response222… ".getBytes());
//1. 指定输出到客户端的时候,这些文字使用UTF-8编码
response.setCharacterEncoding(“UTF-8”);
//2. 直接规定浏览器看这份数据的时候,使用什么编码来看。
response.setHeader(“Content-Type”, “text/html; charset=UTF-8”);
response.getWriter().write(“我爱黑马训练营…”);
//指定浏览器看这份数据使用的码表
response.setHeader(“Content-Type”,“text/html;charset=utf-8”);
//指定输出的中文用的码表
response.getOutputStream().write(“ccc”.getBytes(“UTF-8”));