### 第一节 分页
##### 1.为什么分页
数据库大数据可能是成千上万的,不可能一次性的都显示到浏览器上,一般根据每行数据在页面上所占的空间每页显示若干行
#### 1.2 分页实现的思路
假如一个表里有100调数据,第一页取钱20条,第二页取21~40条记录
select * from 表名 order by id limit 0,20 ;
select * from 表名 order by id limit 20,20;
select * from 表名 order by id limit 40,20;
**pageSize每页显示多少条记录**
**pageIndex 当前页数**
**limit((pageIndex-1)*pageSize,pageSize)**
代码:
int pageIndex=1;//默认他是第一页
int pageSize=5;//每页的最大条数
String sname=request.getParameter("sname");//"i"
int countNum=service.getCount(sname).intValue();//总记录数 12
int pageMax=(countNum+pageSize-1)/pageSize;//最大页数 3
String pageIndexParam = request.getParameter("pageIndex");//“2”
//由于有两种情况,
// 第一种情况是用户第一次进来,他肯定不会传pageIndex,此时使用默认值1
//二:当用户点击分页按钮,传了pageIndex过来,那么我们必须要以用户传的为准
if(!(pageIndexParam == null||"".equals(pageIndexParam))){
pageIndex=Integer.parseInt(pageIndexParam);
}
System.out.println(pageIndex+"==================================");
//不能让用户一直点上一页,使pageIndex值小于1
if(pageIndex<=1){
pageIndex=1;
}
//同样的道理,总共只有3页数据,用户一直点击下一页怎么?
//找出最大页数
if(pageIndex>=pageMax){
pageIndex=pageMax;
}
List<Student> list = service.getList(sname,pageIndex,pageSize);
//controller开始发挥控制资源的作用
//拿到list集合之后,我们需要跳转到index.jsp,并且将list给jsp进行渲染
//转发和重定向 要不也要带值过去?
request.setAttribute("list1", list);
//将pageIndex传到前端界面进行展示,使用户知道这是第几页
request.setAttribute("pageIndex",pageIndex);
request.setAttribute("pageMax",pageMax);
request.setAttribute("sname",sname);
request.getRequestDispatcher("index.jsp").forward(request, response);
### 第二节 乱码问题
#### 2.1 GET中文乱码
在Tomcat7及以下客户端以UTF-8的编码传输数据到服务器端,而服务器端的request对象使用的是ISO8859-1这个字符编码来接收数据,服务器和客户端沟通的编码不一致因此才会产生中文乱码的。解决办法:在接收到数据后,先获取request对象以ISO8859-1字符编码接收到的原始数据的字节数组,然后通过字节数组以指定的编码构建字符串,解决乱码问题。
String name=request.getParameter("name");
name=new String(name.getBytes("ISO-8859-1"),"UTF-8");
Tomcat8的版本中GET基本就不会乱码了,因为服务器对url的编码格式可以进行自动转换
#### 2.2 Post中文乱码问题
由于客户端是以UTF-8字符编码将表单数据传输到服务器端的,因此服务器也需要设置以UTF-8字符编码进行接收,要想完成此操作,服务器可以直接使用从ServletRequest接口继承而来的"setCharacterEncoding(charset)"方法进行统一的编码设置。
//设置请求参数的编码格式--对GET无效
request.setCharacterEncoding("UTF-8");
#### 2.3 Servlet输出中文
浏览器识别不到返回的中文是什么编码格式,就会默认使用GB2312,如果返回的是UTF-8格式的那么在浏览器上就会显示乱码的问题
response.setContentType("text/html;charset=UTF-8");
response.setCharacterEncoding("UTF-8");//输出一个完整的网页
## 总结
遇到乱码问题时,你首先要确认是不是从数据库中读取,如果读取数据库时没有乱码,就可以确定是浏览器和服务器之间的传输出现乱码
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
如果是数据库中读取出现乱码
确定数据库编码方式,然后在url?setCharacterEncoding=utf-8
如果是tomcat7出现get乱码,那就另说
name=new String(name.getBytes("ISO-8859-1"),"UTF-8");
### 第三节Cookie
#### 3.1 什么是Cookie(曲奇饼干)
浏览器行为,浏览器保存服务器给予客户端数据的一种方式
1. Cookie数据都是键值对形式,并且保存的数据都是字符串
2. Cookie数据不能保存中文
3. Cookie数据有大小限制,一般在4KB ~ 8KB
4. Cookie数据会根据浏览器内核不同,支持的Cookie数量是不同的
5. Cookie数据会根据访问不同的网络资源,自行选择对应的Cookie发送给服务器
Cookie技术用的方法
构造方法:
Cookie(); 在服务器端创建一个Cookie
成员方法:
setValue(String value);
setMaxAge(int sec);
setPath(String url);
服务器需要发送Cookie数据给予浏览器保存
通过HttpServletResponse对象调用addCookie(Cookie cookie)
【注意】
Cookie数据中不支持空格
会出现500错误
Invalid Character [32] ==> space
#### 3.2 Cookie的有效时间设置
整数表示当前Cookie在浏览器本地保存数据的时间,已秒为单位
cookie.setMaxAge(20);
当前浏览器打开状态下有效,如果浏览器关闭,cookie信息立即销毁
cookie.setMaxAge(-1);
销毁对应name的Cookie信息
cookie.setMaxAge(0);
#### 3.3 Cookie路径约束
当前Cookie有效范围是整个Tomcat服务器
cookie.setPath("/");
默认是当前Servlet对应URL路径Cookie有效
【缺省】cookie.setPath("/Day32_SL");
可以设置指定路径,指定资源下使用对应的Cookie信息,超出范围无法使用
cookie.setPath("/Day32_SL/user");
#### 3.4 获取Cookie数据
通过HttpServletRequest对象获取Cookie数据
Cookie[] cookies = request.getCookies();
getName();
getValue();
## 总结:
cookie是如何解决无状态性:
1.当浏览器第一次发送请求给服务器,服务器会生成一个密码在内存中保存,并且将密码通过response响应给浏览器
2.浏览器拿到这个密码之后,他会存储在浏览器内部(Ctrl+shift+del),这个叫cookie
3.当同一个浏览器去访问同一个服务器时,那么浏览器回去解读访问的url,会去本地找哪一个cookie中存储了url(项目名)
4.此时如果找到了,那么他会将cookie封装到这一次请求的request中去,服务器拿到了request就能拿到cookie,cookie中有密码,然后完成比对,得知这两次请求是同一个人
代码演示:
<%@ page contentType="text/html;charset=UTF-8" language="java" pageEncoding="utf-8" %>
<html>
<head>
<title>$Titlelt;/title>
</head>
<body>
<%
Cookie c=new Cookie("name","zhangsan");
response.addCookie(c);
%>
</body>
</html>
<%@ page contentType="text/html;charset=UTF-8" language="java" pageEncoding="UTF-8" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
Cookie[] cookies = request.getCookies();
for(Cookie c:cookies){
if("name".equals(c.getName())){
System.out.println("来了 "+c.getValue());
}
}
%>
</body>
</html>