• <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解决前端跨域问题小结

        时间:2023-12-11
      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字符串的转换。

                  上一篇:深入了解Java核心类库–Math类 下一篇:在Java编程中定义方法

                  相关文章

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

                      <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>

                    1. <tfoot id='2UmX7'></tfoot>
                    2. <small id='2UmX7'></small><noframes id='2UmX7'>