1. spring 中的***

请求到达控制器之前,先经过***,才到达控制器

Filter 过滤器接口
HandlerInterceptor ***接口

  1. 编写***
@Component
public class Interceptor1 implements HandlerInterceptor {

    // 在控制器方法执行前被调用, 返回 true 放行请求, 如果返回 false 拦截请求(不会前进了)
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("==========> 进入了 Interceptor1 preHandle");
        return true;
    }

    // 在控制器方法执行后被调用
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("==========> 进入了 Interceptor1 postHandle");
    }

    // 在控制器和视图都完成后被调用
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("==========> 进入了 Interceptor1 afterCompletion");
    }
}
  1. 配置***
<!-- 某个*** -->
<mvc:interceptor>
    <!-- ***要匹配的路径 -->
    <mvc:mapping path="/hello" />

    <!-- 要调用的*** -->
    <ref bean="interceptor1"/>
</mvc:interceptor>

2. 对 json 数据的支持

var xhr = new XMLHttpRequest(); 可以在页面不刷新的情况下与服务器进行交互

xhr.onload = function() {
    var json = xhr.responseText;
    JSON.parse(json); // 把json字符串转为 js 对象
};

xhr.open("get|post", url, true|false);
xhr.send();

2.1 @ResponseBody 注解

加在控制器方法上,将控制器方法的返回结果转换为json字符串,并写入响应

2.2 @RestController 注解

加在控制器类上,表示所有控制器方法都加了 @ResponseBody 注解

2.3 其他注解

@RequestMapping // 不区分 get,post

@GetMapping // 专门匹配 get 请求 等价于 @RequestMapping(method=RequestMethod.GET)
@PostMappping // 专门匹配 post 请求
@DeleteMapping // 专门匹配 delete 请求
@PutMapping // 专门匹配 put 请求

get 一般对应查询操作 select
post 一般对应新增操作 insert
delete 对应删除操作 delete
put 对应修改操作 update

2.4 @RequestBody

把请求中的json 字符串,转换为java 对象
服务器端代码:

@PostMapping("/json4")
// @RequestBody 作用是把请求体中的 json 字符串,转为 java 中的对象
public void json4(@RequestBody Student student) {
    System.out.println(student);
    System.out.println("ok");
}

客户端代码:

function sendStudent() {
    var student = {"id": 2, "name":"李四"}; // {id: 2, name:"李四"}
    var xhr = new XMLHttpRequest();
    xhr.open("post", "/json4", true);
    // 设置请求体的格式为 json 格式
    xhr.setRequestHeader("content-type", "application/json");

    // 将 js 对象 转为为 json 字符串, 并作为请求体, 发送给服务器
    xhr.send( JSON.stringify(student) );
}

2.5 ajax 请求跨域(源)

两个应用程序,ip 地址不一样或是端口号不一样,就称之为跨域

localhost:8080 提供控制器,返回json数据, 通过 cors 的技术运行其他域的机器访问我的数据
@CrossOrigin(“允许访问我的数据的ip地址”)

@CrossOrigin("http://192.168.9.3") // 只允许9.3 访问
@CrossOrigin("http://192.168.9.3,http://192.168.9.4,http://192.168.9.5") //允许多个ip访问
@CrossOrigin("*") // 允许所有域访问

可以加在方法上,表示只有此方法允许跨域
还可以加在控制器类上,表示此控制器中的所有方法都允许跨域

localhost:9090 ajax 获取 localhost:8080 的json数据, 默认情况没有权限访问

3. 重定向请求

@RequestMapping("/test1")
public String test1() {
    // 重定向到 /test2 控制器
    return "redirect:/test2";
}

@RequestMapping("/test2")
public void test2() {
    //...
}