• <small id='EKjdy'></small><noframes id='EKjdy'>

    <tfoot id='EKjdy'></tfoot>
      <bdo id='EKjdy'></bdo><ul id='EKjdy'></ul>
  • <legend id='EKjdy'><style id='EKjdy'><dir id='EKjdy'><q id='EKjdy'></q></dir></style></legend>

        <i id='EKjdy'><tr id='EKjdy'><dt id='EKjdy'><q id='EKjdy'><span id='EKjdy'><b id='EKjdy'><form id='EKjdy'><ins id='EKjdy'></ins><ul id='EKjdy'></ul><sub id='EKjdy'></sub></form><legend id='EKjdy'></legend><bdo id='EKjdy'><pre id='EKjdy'><center id='EKjdy'></center></pre></bdo></b><th id='EKjdy'></th></span></q></dt></tr></i><div id='EKjdy'><tfoot id='EKjdy'></tfoot><dl id='EKjdy'><fieldset id='EKjdy'></fieldset></dl></div>

        springboot+jsonp解决前端跨域问题小结

        下面是“springboot+jsonp解决前端跨域问题小结”的详细攻略。
      1. <tfoot id='VfKK6'></tfoot>
        <i id='VfKK6'><tr id='VfKK6'><dt id='VfKK6'><q id='VfKK6'><span id='VfKK6'><b id='VfKK6'><form id='VfKK6'><ins id='VfKK6'></ins><ul id='VfKK6'></ul><sub id='VfKK6'></sub></form><legend id='VfKK6'></legend><bdo id='VfKK6'><pre id='VfKK6'><center id='VfKK6'></center></pre></bdo></b><th id='VfKK6'></th></span></q></dt></tr></i><div id='VfKK6'><tfoot id='VfKK6'></tfoot><dl id='VfKK6'><fieldset id='VfKK6'></fieldset></dl></div>

            <tbody id='VfKK6'></tbody>

                  <bdo id='VfKK6'></bdo><ul id='VfKK6'></ul>
                  <legend id='VfKK6'><style id='VfKK6'><dir id='VfKK6'><q id='VfKK6'></q></dir></style></legend>

                  <small id='VfKK6'></small><noframes id='VfKK6'>

                  下面是“springboot+jsonp解决前端跨域问题小结”的详细攻略。

                  前言

                  在开发前后端分离的应用时,常常会遇到前端请求后端时跨域的问题。这个时候,可以采用jsonp方式来解决跨域问题。

                  引入依赖

                  在我们使用springboot+jsonp的时候,需要引入一下两个依赖:

                  <dependency>
                      <groupId>org.springframework.boot</groupId>
                      <artifactId>spring-boot-starter-web</artifactId>
                      <version>2.4.5</version>
                  </dependency>
                  
                  <dependency>
                      <groupId>com.alibaba</groupId>
                      <artifactId>fastjson</artifactId>
                      <version>1.2.75</version>
                  </dependency>
                  

                  配置SpringMVC

                  我们需要配置SpringMVC,允许jsonp的请求。我们需要在WebMvcConfigurer中注册我们的拦截器:

                  @Configuration
                  public class MvcConfiguration implements WebMvcConfigurer {
                  
                      /**
                       * 注册自定义拦截器,允许jsonp的请求
                       *
                       * @param registry
                       */
                      @Override
                      public void addInterceptors(InterceptorRegistry registry) {
                          registry.addInterceptor(new JsonpInterceptor()).addPathPatterns("/**");
                      }
                  }
                  

                  其中,我们的 JsonpInterceptor 的实现如下:

                  /**
                   * 自定义拦截器,允许jsonp请求
                   */
                  public class JsonpInterceptor implements HandlerInterceptor {
                  
                      @Override
                      public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
                          String callback = request.getParameter("callback");
                          if (callback != null) {
                              response.setContentType("text/javascript");
                              try {
                                  response.getWriter().write(callback + "(");
                              } catch (IOException e) {
                                  e.printStackTrace();
                              }
                          }
                          return true;
                      }
                  
                      @Override
                      public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
                              ModelAndView modelAndView) throws Exception {
                          String callback = request.getParameter("callback");
                          if (callback != null) {
                              try {
                                  response.getWriter().write(")");
                              } catch (IOException e) {
                                  e.printStackTrace();
                              }
                          }
                      }
                  }
                  

                  编写Controller

                  完成了以上配置后,我们就可以开始编写Controller了。下面展示两个示例说明:

                  返回 JSON

                  @RestController
                  @RequestMapping("/api")
                  public class ApiController {
                  
                      @GetMapping("/user")
                      public Map<String, Object> getUser(@RequestParam String name) {
                          Map<String, Object> map = new HashMap<>();
                          map.put("name", name);
                          map.put("age", 18);
                          return map;
                      }
                  }
                  

                  该Controller返回的是一个Map类型,其中包含了 nameage 两个属性,我们可以直接通过浏览器访问该Controller,获取相应的JSON数据:

                  http://localhost:8080/api/user?name=Tom
                  

                  返回结果:

                  {"name":"Tom","age":18}
                  

                  返回 JSONP

                  如果我们需要返回JSONP类型的数据,只需要在Controller的方法上添加 @ResponseBody@RequestMapping 注解,并使用FastJson进行JSONP字符串的转换:

                  @RestController
                  @RequestMapping("/api")
                  public class ApiController {
                  
                      @GetMapping("/jsonp")
                      @ResponseBody
                      public String getUserJsonp(@RequestParam String name, @RequestParam String callback) {
                          Map<String, Object> map = new HashMap<>();
                          map.put("name", name);
                          map.put("age", 18);
                          return callback + "(" + JSON.toJSONString(map) + ")";
                      }
                  }
                  

                  该Controller返回的是一个JSONP字符串,其中使用了 callback 参数来指定回调函数。我们可以通过以下URL进行测试:

                  http://localhost:8080/api/jsonp?name=Tom&callback=handleResponse
                  

                  返回结果:

                  handleResponse({"name":"Tom","age":18});
                  

                  总结

                  我们通过配置SpringMVC,实现了jsonp跨域请求。如果需要返回JSONP类型的数据,只需要在Controller方法上添加相关注解,并使用FastJson进行JSONP字符串的转换。

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Lambda表达式是Java 8中引入的新特性之一,它是一个匿名函数,可以捕获参数并表现为一个代码块,而不像方法一样需要一个固定的名称。它主要用于传递行为或代码块以及事件处理等操作。
                  下面为您详细讲解基于Java的回调函数。
                  在Java中,equals()是用来比较两个对象是否相等的函数。equals()方法是Object类中的方法,因此所有Java类都包含equals()方法。在默认情况下,equals()方法比较对象的引用地址是否相同,即两个对象是否是同一个实例。但是,我们可以覆盖equals()方法,来定义自
                  JavaWeb是Java在Web领域的应用,是目前非常热门的技术之一。但是JavaWeb涉及到的技术非常广泛,初学者很容易迷失方向。本文总结了JavaWeb的基础知识,为初学者提供了一份学习笔记分享,希望能够帮助大家快速入门。
                  在Java编程中,字符串操作是很常见的,而替换字符串是其中常用的操作之一。Java提供了三种函数用于替换字符串:replace、replaceAll和replaceFirst。这篇文章将为您详细介绍它们的用法。
                  进制是数学中一种表示数值大小的方法,常见的进制有10进制、2进制、16进制等。

                      • <bdo id='2UmX7'></bdo><ul id='2UmX7'></ul>
                          <tbody id='2UmX7'></tbody>

                          <i id='2UmX7'><tr id='2UmX7'><dt id='2UmX7'><q id='2UmX7'><span id='2UmX7'><b id='2UmX7'><form id='2UmX7'><ins id='2UmX7'></ins><ul id='2UmX7'></ul><sub id='2UmX7'></sub></form><legend id='2UmX7'></legend><bdo id='2UmX7'><pre id='2UmX7'><center id='2UmX7'></center></pre></bdo></b><th id='2UmX7'></th></span></q></dt></tr></i><div id='2UmX7'><tfoot id='2UmX7'></tfoot><dl id='2UmX7'><fieldset id='2UmX7'></fieldset></dl></div>
                          <legend id='2UmX7'><style id='2UmX7'><dir id='2UmX7'><q id='2UmX7'></q></dir></style></legend>

                          • <tfoot id='2UmX7'></tfoot>
                          • <small id='2UmX7'></small><noframes id='2UmX7'>