B/S 架构:浏览器 / 服务器 。
C/S 架构:客户端 / 服务器 。
- 修改Tomcat域名:
- 第一步:可以通过修改Tomcat文件下的conf/server.xml文件,找到<Host>,里面有name属性,可以自定义去修改,如www.cwx.com,不要去修改<Engine>里的localhost,这是引擎不能乱动!
- 第二步:在C盘下的windows/system32/drivers/etc/hosts文件下,添加127.0.0.1 www.cwx.com,保存后即可通过访问http://www.cwx.com8080访问Tomcat主页面。
网站是如何访问的?
- 第一步:输入一个域名,回车。
- 第二步:检查本机的C:\Windows\System32\drivers\etc\hosts文件中是否有这个域名映射。
- 如果有:直接返回对应的IP地址,这个地址中有我们需要访问的web程序
- 如果没有:则会去DNS服务器里面去找,找到的话就返回,找不到就返回找不到该网页。
Tips:DNS服务器是全球范围内的域名管理服务器。
- http默认端口:80,https(安全的)默认端口:443
- http1.0:客户端可以与web服务器连接后,只能获得一个web资源,在断开连接。
- http1.1:客户端可以与服务器连接后,可以获得多个web资源。
- 状态码:
- 200:请求响应成功。
- 3xx:请求重定向(让用户重新定位到自己设置的地址)。
- 404:找不到网页,403:被禁止。
- 5xx:服务器代码错误,502:网关错误。
Maven的核心思想:约定大于配置(有约束,不要去违反)
Servlet
- 简介:servlet是sun公司提供开发动态web的一门技术。
- Sun在这些API中提供了一个接口servlet,想要开发一个Servlet程序,只需要完成两个步骤:
- 编写一个类,实现servlet接口
- 把开发好的Java类部署到web服务器中
- Sun公司提供了两个默认的实现了servlet接口的类:HttpServlet,GenericServlet,我们可以直接继承这个HttpServlet类。要实现doGet()和doPost()方法,两方法之间可以互相调用,只是请求方式不一样,业务逻辑是一样的。
- 编写Servlet的映射(在web.xml中)
- 为什么需要映射:我们写的是java程序,但是要通过浏览器访问,而浏览器需要连接web服务器,所以我们需要在web服务器中注册我们写的Servlet,还需要给他一个访问路径。
<!-- 注册servlet--> <servlet> <servlet-name>hello(要与下面的name一致才能被找到)</servlet-name> <servlet-class></servlet-class> </servlet> <!--Servlet的请求路径--> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello</url-pattern><!--这是请求的路径,访问该路径才能实现自己写的Servlet的功能--> </servlet-mapping>
Tips:这里写路径可以用*通配符,但是它前面不能加任何东西。只能写
*hello
,不能写成hello*
。
Servlet原理
- 流程:首先浏览器发送http请求,到web容器(相当于Tomcat服务器)中,此时web容器会产生两个对象request、response,这两个对象会调用service(ServletRequest rq,ServletResponse rp)方法,request会从service方法中拿到请求并把请求之后的响应传给response,web容器就会读取响应信息,读到后就将信息响应到浏览器。
ServletContext
web容器在启动的时候,它会为每一个web程序都创建一个对应的ServletContext对象,这个对象就代表了每个web应用。这样有什么作用?
- 共享数据(不常用这种方法,经常使用session等其他方式实现):我们在这个Servlet中保存的数据,可以在另外一个Servlet中拿到(相当于每个web应用都有一个小的ServletContext,但是还有一个全局的ServletContext,这里面包含所有的数据)。
public class helloServlet extends HttpServlet {
@Override
protected void doGet(HttpServletResponse resp,HttpServletRequest req ) throws servletException, IOException {
ServletContext context = this.getServletContext();
String name = "cwx";
context.setAttribute("name",name);//数据保存在ServletContext中,名字为name,值为cwx
}
@Override
protected void doGet(HttpServletResponse resp,HttpServletRequest req ) throws servletException, IOException {
doGet(resp,req);
}
}
读取的方法操作这个类似,在另一个servlet中调用context.getAttribute("设置的名称")
- 获取初始化参数(很少用)
<!--配置一些web应用初始化参数-->
<context-param>
<param-name>url</param-name>
<param-value>这是初始化的参数</param-value>
</context-param>
protected void doGet(HttpServletResponse resp,HttpServletRequest req ) {
ServletContext context = this.getServletContext();
String url = context.getInitParameter("url");
resp.getWriter().print(url);
}
- 请求转发(一般我们会使用request方法转发,而不用context.getRequestDispatcher("/xxx").forward(resp,req)方法,这里作为了解)。
Tips:转发只是页面变成了我们想要转发的页面,URL地址不会变,重定向则会改变URL。
转发和重定向的区别:例如,A想获得C的资源,但是A不能直接访问到C,这时A通知B自己的请求,B再获得C资源,再给A,A只和B发生了交流这是转发。重定向是A要获得C资源,先向B请求,B再通知A到C里拿资源,A和B和C都发生了交流,这是重定向。
- 读取资源文件
- Properties文件
- 在java目录下新建properties(需要在pom文件<build>中设置扫描的路径)
- 在resources目录下新建properties(不需要在<bulid>中设置,默认有的)
发现:这些properties文件都被打包到了同一个路径下:classes,我们俗称这个路径为classpath(类路径);
//例子: 通过ServletContext获得properties资源文件
protected void doGet(HttpServletResponse resp,HttpServletRequest req ) {
ServletContext context = this.getServletContext();
InputStream in = context.getResourceAsStream("/WEB-INF/classes/db.properties")//将文件变成流,想要获得文件就必须通过流来连接
Properties propertie = new Properties();
propertie.load(in);
ptopertie.getProperty("name");//获得文件里name的值
}
中文乱码的问题
- 后台写的数据有中文,传到页面上出现乱码
//这里是在实现Servlet类的类中写的,主要是记住哪两个方法 response.setContextType("text/html"); response.setCharacterEncoding("utf-8");
- 请求的数据中有中文,传到后台出现乱码
request.setCharacterEncoding("utf-8");
HttpServletResponse(响应)
- 下载文件:
1.获取文件下载的路径 ,下载的文件名是啥?
2.让浏览器支持下载我们的文件
3.获取下载文件的输入流
4.创Buffer建缓冲区,获取OutputStream对象
5.将FileOutputStream流写入到buffer缓冲区
6.使用OutputStream将缓冲区里的数据输出到客户端protected void doGet(HttpServletResponse resp,HttpServletRequest req )throws IOException { // 1.获取文件下载的路径 ,下载的文件名是啥? String realPath = "文件的绝对地址"; String fileName = realPath.substring(realPath.lastIndexOf("//") + 1);//获得文件名,通过获得最后一个'/'后面的数据作为文件名 // 2.让浏览器支持下载我们的文件 resp.setHeader("Content-Disposition","attachment;filename="+ URLEncoder.encode(fileName,"utf-8"));//防止中文名出现乱码 // 3.获取下载文件的输入流 FileInputStream in = new FileInputStream(realPath); // 4.创Buffer建缓冲区,获取OutputStream对象 int len=0; byte[] buffer = new byte[1024]; // 5.将FileOutputStream流写入到buffer缓冲区,使用OutputStream将缓冲区里的数据输出到客户端 ServletOutputStream out = new resp.getOutputStream(); while ((len=in.read(buffer))!=-1){ out.write(buffer,0,len); } in.close(); out.close(); }
- 验证码功能
protected void doGet(HttpServletResponse resp,HttpServletRequest req )throws IOException { resp.setHeader("reflesh","3");//实现三秒刷新一次网页 //内存中创建一个图片,长80,宽20 BufferImage image = new BufferImage(80,20,BufferImage.TYPE_INT_RBG); Graphics2D g = (Graphics2D ) image.getGraphics();//g 就相当于笔,用于画图 //设置图片的颜色 g.setColor(Color.white); //填充白色背景颜色 g.fillRect(0,0,80,20); //给图片写数据 g.setColor(Color.bule); g.setFont(new Font(null,Font.BLOD,20)); g.draw(makeNum(),0,20);//开始画数字 //告诉浏览器用图片方式打开 resp.setContentType("image/jpg"); //网站存在缓存,取消网站的缓存 resp.setDateHeader("expries",-1); resp.setHeader("Cache-Control","no-cache"); resp.setHeader("Pragma","no-cache"); //把这个图片写入到浏览器中 ImageIO.write(image,"图片",resp.getOurputStream); } //生成四位随机数方法 private String makeNum(){ Random random = new Random(); String num = random.nextInt("9999")+"";//随机生成四位数 StringBuffer sb = new StringBuffer(); for(int i=0; i<4-random.length();i++){ num.append("0");//当位数不够使自动将0填满 } num= sb.toString()+num; return num; }
- 实现重定向
- 常见场景:用户登录
//实现重定向的原理 /* resp.setHeader("Location","/xxx");//设置重定向的URL地址 resp.setStatus(302);//设置重定向的状态码 */ resp.sendRedirect("/xxx"); //调用重定向的方法
HttpServletRequest(请求)
- jsp中利用
{pageContext.request.getContextPath()}
获得当前URL地址,req.getParmeter("名称")
获得发送请求的参数req.getParmeterValues("名称")
获得多个参数。
Cookie、Session
-
Session(会话):用户打开一个浏览器,点击了很多超链接,访问了多个web资源,关闭浏览器,这个过程可称之为会话,会话是服务器技术,数据存储在服务端。
- 服务器会为每一个用户(浏览器)创建一个Session,只要浏览器没关Session就存在,例如:用户登录某个网站后,不论访问哪个页面都会显示用户处于登录状态,说明Session保存了用户信息。
- 获得session:
Session session = req.getSession()
- 添加session:
session.setArttribute(name,object)
- 设置session的有效时间:在
<session-config>
中的<session-timeout>
设置(web.xml中)。 - 销毁session:
session.removeAttribute("name");session.invalidate();
- Cookie:客户端技术,数据只会存储在客户端。
//举例:在客户端设置一个cookie记录上次访问网站的时间
protected void doGet(HttpServletResponse resp,HttpServletRequest req )throws IOException {
Cookie[] cookies = req.getCookies();
if(cookies!=null){
resp.getWriter().print("你上一次访问的时间是:");
for(int i=0; i<cookies.length(); i++){
Cookie cookie=cookies[i];
if(cookie.getName().equals("lastLoginTime")){
long lastLoginTime = long.parseLong(cookie.getValue());
Date date = new Date(lastLoginTime);
resp.getWriter().print(date.toLocaleString());//将时间类型转换为字符串类型
}
}
}else
{
resp.getWriter().print("这是你第一次访问该网站!");
}
//服务器给客户端响应一个cookie
Cookie cookie =new Cookie("lastLoginTime",System.currentTimeMillis()+"")//cookie只能存字符串类型!
//设置cookie的一天有效时间
cookie.setMaxage(24*60*60);
resp.addCookie(cookie);//response 响应给客户端
}
- 一个网站cookie是否存在上限?
1.一个web站点可以给浏览器发送多个cookie,最多存放为20个。
2.整个浏览器最多存放300个cookie
3.每个cookie限制大小为4kb