一.动态网页开发基础
1.动态网页:能跟用户进行交互的网页,能够处理用户请求的网页
2.B/S架构:浏览器;客户端零维护;与操作系统平台的关系最小化;在响应速度和安全性上需要花费更多设计成本
C/S架构:需要专门的客户端应用;客户端需要单独维护和升级;对客户端操作系统一般有限制;能充分发挥客户端处理能力,客户端响应快
3.URL:Uniform Resource Locator统一资源定位符
http://localhost:8080/xxxx
http:协议
localhost:8080代表IP:端口
xxxx:资源请求地址
4.Tomcat(Web服务器)
WebLogic
Ngnix
Resin
5.Tomcat:Web服务器,JSP/Servlet的容器
目录介绍:
/bin 存放各种平台下用于启动和停止Tomcat的脚本文件
/conf 存放Tomcat服务器的各种配置文件
/lib 存放Tomcat服务器所需的各种JAR文件
/logs 存放Tomcat的日志文件
/temp Tomcat运行时用于存放临时文件
/webapps 当发布Web应用时,默认情况下会将Web应用的文件存放于此目录中
/work Tomcat把由JSP生成的Servlet放于此目录下
启动方式:
/bin目录下:startup.bat启动脚本 shutdown.bat停止脚本
如果遇到闪退的问题则在上述两个文件中添加如下代码:
SET JAVA_HOME=D:\Java\jdk1.7 (java jdk目录)
SET TOMCAT_HOME=E:\tomcat-7.0 (解压后的tomcat文件目录)
配置环境变量:
添加系统变量,名称为CATALINA_HOME,值为Tomcat的安装目录,在Path系统变量中添加一个%CATALINA_HOME%\bin
6.Web工程:
Eclipse环境中新建一个Dynamic web project--->Target Runntime代表启动的web服务器----->Dynamic Web model version代表项目版本(3.0)--->点击Next直到
---->Generate web.xml xxxxx将此勾选上才在WEB-INFO文件夹下有web.xml文件
web.xml文件是web工程的配置文件,其中welcome-file-list代表首次访问的页面集合,welcome-file代表首次访问的页面
目录结构:
/ Web应用的根目录,该目录下所有文件在客户端都可以访问(JSP、HTML等)
/WEB-INF 存放应用使用的各种资源,该目录及其子目录对客户端都是不可以访问
/WEB-INF/classes 存放Web项目的所有的class文件
/WEB-INF/lib 存放Web应用使用的JAR文件
7.JSP页面:Java Server Pages(可以嵌入Java代码) 所有的JSP页面最终都会被WEB容器自动编写成.Java文件,编译成.class文件
组成内容:
page指令:<%@ page 属性1="属性值" 属性2="属性值1,属性值2"… 属性n="属性值n"%>
属性 描述 默认值
language 指定JSP页面使用的脚本语言 java
import 通过该属性来引用脚本语言中使用到的类文件 无
contentType 用来指定JSP页面所采用的编码方式 text/html, ISO-8859-1
小脚本:<%Java代码%>
表达式:<%=表达式%>
声明:<%!声明方法%>
注释:<!--注释-->;<%--注释,页面无法看见-->
第二章:JSP数据交互
1.JSP内置对象:JSP内置对象是 Web 容器创建的一组对象,不用通过手动new就可以使用
2.JSP9大内置对象:
对象名称 类型 全路径
request
response
out
session
application
page
pageContext
config
execption
3.JSP内置对象:out
<%
int[] value = { 60, 70, 80 };
for (int i : value) {
//将输出信息输出到控制台
System.out.println("控制台:"+i);
//out作为JSP最简单的内置对象,主要用于将信息输出到页面上
out.println(i);
}
%>
4.JSP内置对象:request:客户端向服务器端发送请求数据,我们通过request对象接收数据
<%
//获取数据之前解决乱码 解决表单POST提交方式的乱码
request.setCharacterEncoding("UTF-8");
//request用于获取客户端向服务器提交的数据
String username=request.getParameter("username");
String password=request.getParameter("password");
//获取表单组件对应多个值时的请求数据
String [] hobbys=request.getParameterValues("hobby");
for(int i=0;i<hobbys.length;i++){
//获取数据之前解决乱码 解决表单Get提交方式的乱码
/* hobbys[i]=new String(hobbys[i].getBytes("ISO-8859-1"),"UTF-8"); */
out.print(hobbys[i]);
}
out.println();
out.println(username+"\t"+password);
//性别
String sex=request.getParameter("sex");
out.println(sex);
//下拉框地址
String address=request.getParameter("address");
out.println(address);
%>
POST和GET的区别:
1.从安全角度考虑 post更安全一些 get不安全
2.post方式提交数据可以提交大概几GB的数据 get方式提交数据最大也就到几KB
5.解决乱码的方案:
post乱码解决:request.setCharacterEncoding("UTF-8");
get乱码解决: hobbys[i]=new String(hobbys[i].getBytes("ISO-8859-1"),"UTF-8");
6.HTTP状态码:
1** 信息,服务器收到请求,需要请求者继续执行操作
2** 成功,操作被成功接收并处理
3** 重定向,需要进一步的操作以完成请求
4** 客户端错误,请求包含语法错误或无法完成请求
5** 服务器错误,服务器在处理请求的过程中发生了错误
404和500错误状态码配置页面:
在当前项目的web.xml当中加入如下配置信息:
<error-page>
<error-code>500</error-code>
<location>/500.jsp</location>
</error-page>
<error-page>
<error-code>404</error-code>
<location>/404.jsp</location>
</error-page>
7.response:响应
转发(是在服务器内部进行,无法访问到除内部以外的资源):request.getRequestDispatcher("/response/welcome.jsp").forward(request, response);
重定向(全路径):response.sendRedirect("/Chap02/response/Login.jsp");
区别:1.转发是在服务器内部进行,重定向是客户端完成的,需要写入全路径,地址xxxxxxx
2.转发请求1次,其余的操作都是在服务器内部进行的;重定向请求至少2次,其余的请求命令客户端再次请求一个URL
3.转发可以携带这次请求的数据,重定向不带数据
8.session会话对象:
会话:在一段时间内,客户端和服务器建立连接的过程,只要会话时间不过期,只要会话不关闭,那么会话就一直存在,那么会话中保存的数据就一直存在
不同浏览器的会话是不相等的:
可以设置Session的会话时长:
1.session.setMaxInactiveInterval(秒数)
2.在项目web.xml当中去设置Session的实效时长:
<session-config>
<session-timeout>1</session-timeout>
</session-config>
手动设置Session实效:
session.invalidate();
会话保存数据:
session.setAttribute(String name, Object value);
Object value=session.getAttribute(String name);
删除会话当中保存的数据:
session.removeAttribute(String name);
9.incloud
<%@ include file="loginControl.jsp" %>
第三章:JSP的数据交互
1.application内置对象
application实现用户之间的数据共享
void setAttribute(String key,Object value) 以key/value的形式保存对象值
Object getAttribute(String key) 通过key获取对象值
String getRealPath(String path) 返回相对路径的真实路径
统计网站访问次数:
<%
//获取当前网站的访问次数
Integer count=(Integer)application.getAttribute("count");
if(count!=null){
count++;
}else{
count=1;
}
application.setAttribute("count", count);
%>
<%
out.print("当前网站访问次数:"+application.getAttribute("count"));
%>
2.作用域
从小到大:page(pageContext)--->request---->session---->application
page对象作用域只在当前页面有效
request作用域是在当前请求内有效
session作用域是在当前会话内有效
application对象的作用域是在应用上下文
3.cookie默认会存放一个session的id值