拦截
下来,从而实现一些特殊的功能。通用
的操作,比如: 权限控制、统一编码处理、敏感字符处理等等.1.定义类,实现Filter接口,并重写其所有方法
public class FilterDemo implements Filter {
public void init(FilterConfig filterConfig)
public void doFilter(ServletRequest request)
public void destroy(){}
}
@WebFilter("/*")
public class FilterDemo implements Filter {}
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("Filter....");
//放行
filterChain.doFilter(servletRequest,servletResponse);
}
会
放行后逻辑
Filter拦截路径配置
@WebFilter("/*")
/index.jsp
:只有访问index.jsp时才会被拦截。/user/*
:访问/user下的所有资源,都会被拦截*.jsp
:访问后缀名为jsp的资源,都会被拦截/*
:访问所有资源,都会被拦截过滤器链
package com.huanglei.web.Filter;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@WebFilter("/*")
public class loginFilter implements Filter {
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain) throws IOException, ServletException {
//1. 首先进行强转HttpServlet
HttpServletRequest req = (HttpServletRequest) servletRequest;
//添加有些不需要登陆就可以放行的页面
String[] urls = {"/login.jsp","/loginServlet","/css/","/img/","/register.jsp","/registerServlet"};
//获取到url
String url = req.getRequestURL().toString();
for (String u : urls) {
if (url.contains(u)){
//表示出现了该放行人员,进行放行
chain.doFilter(req,servletResponse);
return;
}
}
//2. 通过req来获取到session对象,因为session里面存储着用户信息
HttpSession session = req.getSession();
//3.获取里面是否含有登录信息
Object user = session.getAttribute("user");
//4. 判断是否为空
if (user != null){
//已经登录到页面
chain.doFilter(req,servletResponse);
}else {
//没有登陆,跳转到登陆页面,并且将错误信息返回
req.setAttribute("login_msg","还未登录请先登录!!");
req.getRequestDispatcher("/login.jsp").forward(req, servletResponse);
}
}
@Override
public void init(FilterConfig filterConfig) {
}
@Override
public void destroy() {
}
}
监听器分类 | 监听器名称 | 作用 |
---|---|---|
ServletContext监听 | ServletContextListener | 用于对ServletContext对象进行监听(创建、销毁) |
ServletContext监听 | ServletContextAttributeListener | 对ServletContext对象中属性的监听(增删改属性) |
Session监听 | HttpsessionListener | 对Session对象的整体状态的监听(创建、销毁) |
Session监听 | HttpSessionAttributeListener | 对Session对象中的属性监听(增删改属性) |
Session监听 | HttpSessionBindingListener | 监听对象于Session的绑定和解除 |
Session监听 | HttpSessionActivationListener | 对Session数据的钝化和活化的监听 |
Request监听 | ServletRequestListener | 对Request对象进行监听(创建、销毁) |
Request监听 | ServletRequestAttributeListener | 对Request对象中属性的监听(增删改属性) |
public class ContextLoaderListener implements ServletContextListener {
/**
* ServletContext对象被创建:整个web应用发布成功
* @param sce
*/
public void contextInitialized(ServletcintextEvent sce){}
/*
* ServletContext对象被销毁:整个web应用卸载
* @param sce
*/
public void contextDestroyed(ServletContextEvent sce){}
}
package com.itheima.web.Linstener;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.annotation.WebListener;
@WebListener
public class ContextLoaderListener implements ServletContextListener {
@Override
public void contextInitialized(ServletContextEvent servletContextEvent) {
System.out.println("ContextLoaderListener.....");
}
@Override
public void contextDestroyed(ServletContextEvent servletContextEvent) {
}
}
概念
: AJAX(Asynchronous JavaScript And XML): 异步的JavaScript和XML
AJAX作用:
- 与服务器进行数据交换:通过AJAX可以给服务器发送请求,并获取服务器响应的数据
使用了AJAX和服务器进行通信,就可以使用HTML+AJAX来替换JSP页面了\- 异步交互:可以在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页的技术,如:搜索联想、用户名是否可用校验,等等…
编写AjaxServlet,并使用response输出字符串
创建XMLHttpRequest 对象:用于和服务器交换数据
var xmlhttp;
if (window.XMLHttpRequest) {
//code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp = new XMLHttpRequest();
}else {
//code for lE6,IE5
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","url");
xmlhttp.send();//发送请求
xmlhttp.onreadystatechange = function () {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200){
alert(xmlhttp.responseText)
}
};
Axios对原生的AJAX进行封装,简化书写
官网
: Axios官网
<script src="jslaxios-0.18.0.js"</script>
axios({
method:"get",
url:"http://localhost:8080/brand-dome/axiosServlet?username=zhangsan"
}).then(function (resp){
alert(resp.data);
});
axios({
method:"post",
url:"http://localhost:8080/brand-dome/axiosServlet",
data:"username=zhangsan"
}).then(function (resp){
alert(resp.data);
});
axiosServlet
package com.itheima.web.Servlet;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet("/axiosServlet")
public class AxiosServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("get!!");
//获取数据
String username = req.getParameter("username");
System.out.println(username);
//回响数据
resp.getWriter().write("hello axios !!!!!");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("Post……");
this.doGet(req, resp);
}
}
Axios请求方式别名
方法名 | 作用 |
---|---|
get(url) | 发起GET方式请求 |
post(url,请求参数) | 发起POST方式请求 |
方法名 | 作用 |
---|---|
get(url) | 发起GET方式请求 |
post(url,请求参数) | 发起POST方式请求 |
示范:
axios.get("http://localhost:8080/brand_dome/axiosServlet?username=zhangsan")
.then(function (resp){
alert(resp.data)
})
axios.post("http://localhost:8080/brand_dome/axiosServlet","username=zhangsan")
.then(function (resp){
alert(resp.data)
})
概念
:JavaScript Object Notation。JavaScript 对象表示法
定义:
var 变量名 ={
"key1": value1,
"key2": value2,
...
};
value的数据类型为:
数字 (整数或浮点数)
字符串 (在双引号中)
逻辑值 (true或false)
数组 (在方括号中)
对象 (在花括号中)
null
示例
var json ={
"name": "zhangsan",
"age": 23,
"addr":["厦门","四川","广州"]
};
获取数据:
变量名.key
json.name
请求数据
:JSON字符串转为Java对象
响应数据
:Java对象转为JSON字符串
使用:
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.62</version>
</dependency>
String jsonStr = JSON.toJSONString(obj);
User user = JSON.parseObject(jsonStr,User.class);
package com.huanglei.web.json;
import com.alibaba.fastjson.JSON;
public class jsondemo1 {
public static void main(String[] args) {
User user = new User("zhangsan","123456",11,21);
//将对象转化为字符串
String json = JSON.toJSONString(user);
System.out.println(json);
//将json字符串转化为对象
User user = JSON.parseObject(json, User.class);
System.out.println(user);
}
}
前端框架
,免除原生JavaScript中的DOM操作,简化书写MVVM
(Model-View-ViewModel)思想,实现数据的双向绑定
,将编程的关注点放在数据上官网
: https://cn.vuejs.org<script src="js/vue.js"></script>
new Vue({
el:"#app",
data(){
return{
username:""
}
}
});
<div id ="app">
<input name= "username" v-model="username">
{{username}}
</div>
<div id="app">
<input type="text" name="username" v-model="username">
{{username}}
</div>
<script src="https://cdn.staticfile.org/vue/2.2.2/vue.min.
<script>
new Vue({
el:"#app",
data(){
return {
username:""
}
}
});
</script>
常用指令:
指令 | 作用 |
---|---|
v-bind | 为HTML标签绑定属性值,如设置 href,css样式等 |
V-model | 在表单元素上创建双向数据绑定 |
V-on | 为HTML标签绑定事件 |
v-if | 条件性的渲染某元素,判定为true时渲染,否则不渲染 |
v-else | 条件性的渲染某元素,判定为true时渲染,否则不渲染 |
V-else-if | 条件性的渲染某元素,判定为true时渲染,否则不渲染 |
V-show | 根据条件展示某元素,区别在于切换的是display属性的值 |
V-for | 列表渲染,遍历容器的元素或者对象的属性· |
v-bind:
<div id="app">
<input type="text" name="url" v-model="url">
<a v-bind:href="url">百度一下</a>
<a :href="url">百度两下</a>
</div>
<script src="https://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script>
<script>
new Vue({
el:"#app",
data(){
return {
username:"",
url:""
}
}
});
</script>
v-on:
<input type="submit" value="不要点我" v-on:click="show()">
</div>
<script src="./js/vue.js"></script>
<script>
new Vue({
el:"#app",
data:{
username:"",
url:""
} ,
methods:{
show(){
alert("不要玷污了我")
}
}
}) ;
v-for:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--v-model v-bind(可以省略) v-on(可以用@来代替)v-if v-if-else v-else v-show v-for-->
<div id="app">
<input name="username" v-model="username" >
{{username}}
<input name="url" v-model="url" >
<input name="count" v-model="count" >
<a v-bind:href="url">小小点击跳转</a>
<input type="submit" value="不要点我" v-on:click="show()">
<div v-if="count == 1"> 北京</div>
<div v-else-if="count == 2"> 陕西</div>
<div v-if="count == 3"> 四川</div>
<div v-for="addr in address">
{{addr}}
<br>
<hr>
</div>
<div v-for="(addrs,i) in address">
{{i}} ----- {{addrs}}
<br>
<hr>
</div>
</div>
<script src="./js/vue.js"></script>
<script>
new Vue({
el:"#app",
data:{
username:"",
url:"" ,
address:["北京" , "上海"] ,
count:3
} ,
methods:{
show(){
alert("不要玷污了我")
}
}
}) ;
</script>
</body>
</html>
状态 | 阶段周期 |
---|---|
beforeCreate | 创建前 |
created | 创建后 |
beforeMount | 载入前 |
mounted | 载完成 |
beforeUpdate | 更新前 |
updated | 更新后 |
beforeDestroy | 销毁前 |
destroyed | 销毁后 |
发送异步请求,加载数据
用法:
new Vue({
el:"#app",
mounted:{
alert("Vue加载完毕 , 进行异步请求加载数据")
}
});
自己写的小练习:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<input name="username" v-model="username" >
{{username}}
<input name="url" v-model="url" >
<input name="count" v-model="count" >
<a v-bind:href="url">小小点击跳转</a>
<input type="submit" value="不要点我" v-on:click="show()">
<div v-if="count == 1"> 北京</div>
<div v-else-if="count == 2"> 陕西</div>
<div v-if="count == 3"> 四川</div>
<div v-for="addr in address">
{{addr}}
<br>
<hr>
</div>
<div v-for="(addrs,i) in address">
{{i}} ----- {{addrs}}
<br>
<hr>
</div>
</div>
<script src="./js/vue.js"></script>
<script>
new Vue({
el:"#app",
data:{
username:"",
url:"" ,
address:["北京" , "上海"] ,
count:3
} ,
methods:{
show(){
alert("不要玷污了我")
}
},
mounted(){
alert("Vue加载完毕 , 进行异步请求加载数据")
}
}) ;
</script>
</body>
</html>
<script src="vue.js"></script>
<script src="element-ui/lib/indexjs"></script>
<link rel="stylesheet" href="element-ui/lib/theme-chalk/index.css">
<script>
new Vue({
el:"#app"
})
</script>
Element中有两种布局方式