当前位置: 首页 > news >正文

用asp做网站流程公司网站维护一般需要做什么

用asp做网站流程,公司网站维护一般需要做什么,马鞍山网站建设公,网站的管理包括⛰️个人主页: 蒾酒 🔥系列专栏:《spring boot实战》 🌊山高路远,行路漫漫,终有归途。 目录 1.前言 2.何为跨域 3.跨域问题出现特征 4.方式一:使用 CrossOrigin 注解 5.方式二:自定义…

⛰️个人主页:     蒾酒

🔥系列专栏:《spring boot实战》

🌊山高路远,行路漫漫,终有归途。


目录

1.前言

2.何为跨域

3.跨域问题出现特征

4.方式一:使用 @CrossOrigin 注解

5.方式二:自定义 WebMvcConfigurer

6.方式3:使用 Filter 进行跨域配置

7.最后


1.前言

本文介绍了spring boot中三种解决跨域问题的方式,坚持看完相信对你有帮助。

同时欢迎订阅springboot系列专栏,持续分享spring boot的使用经验。

2.何为跨域

跨域问题是指在 Web 开发中,一个网页的 JavaScript 代码通过 AJAX 请求后端服务器接口时,如果请求的目标地址当前页面的地址不在同一个域(域名端口协议任何一项不同),就会产生跨域问题。这种情况下,根据浏览器的安全机制(同源策略)就会会限制页面的跨域请求,以防止恶意网站对其他网站的访问和操作,保护用户信息安全。

3.跨域问题出现特征

1.没有状态码信息

如果你看到某个请求似乎“失败了”,但并没有具体的HTTP状态码,这可能是因为浏览器出于安全原因阻止了对响应的访问。在开发者工具的网络(Network)面板中,这样的请求可能会被标记为“cancelled”或者没有显示状态码。

2.控制台报错

浏览器通常会在控制台(Console)中打印一条错误消息,说明因为CORS策略,请求被阻止了

4.方式一:使用 @CrossOrigin 注解

这是最直接简单的方式,可以精确控制所有接口

使用方法:在你的控制器类或者控制器方法上添加 @CrossOrigin 注解,可以精确控制某个控制器类、以及下面的某个方法的允许跨域的来源、允许的请求头、允许的请求方法等配置。

示例代码:

@RestController
@RequestMapping("/user")
@CrossOrigin(origins = "*")//允许所有来源的请求跨域
@Tag(name = "用户模块")
public class UserController {private final UserService userService;public UserController(UserService userService) {this.userService = userService;}@PostMapping("/login")@Operation(summary = "用户登录")public UserLoginVO login(@RequestBody @Validated UserLoginDTO userLoginDTO) {return userService.login(userLoginDTO);}}

这种方式解决跨域需要在每个控制器上加注解,属于重复劳动对于不需要精确控制的场景属于重复劳动。可以看下下面方式

5.方式二:自定义 WebMvcConfigurer

通过实现 WebMvcConfigurer 接口来自定义 WebMvc 配置,并覆盖 addCorsMappings 方法以配置全局跨域规则。

示例代码:

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;/*** @author mijiupro*/
@Configuration
public class WebConfig implements WebMvcConfigurer {@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/**") // 对所有路径生效.allowedOrigins("*") //允许所有源地址// .allowedOrigins("https://mijiupro.com","https://mijiu.com ") // 允许的源地址(数组).allowedMethods("GET", "POST", "PUT", "DELETE") // 允许的请求方法.allowedHeaders("*"); // 允许的请求头}
}

这种方式实现了全局的配置,但是无法细腻到控制某个方法

6.方式3:使用 Filter 进行跨域配置

创建一个跨域过滤器,在其中设置允许的跨域规则,并将该过滤器添加到 Spring Boot 的过滤器链中。

示例代码:

import jakarta.servlet.*;
import jakarta.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Component;import java.io.IOException;/*** @author mijiupro*/
@Component
public class CorsFilter implements Filter {@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {// 将 ServletResponse 转换为 HttpServletResponseHttpServletResponse httpResponse = (HttpServletResponse) response;// 设置允许跨域请求的源地址httpResponse.setHeader("Access-Control-Allow-Origin", "https://mijiupro.com");// 设置允许的请求方法httpResponse.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");// 设置允许的请求头httpResponse.setHeader("Access-Control-Allow-Headers", "*");// 继续执行 Filter 链chain.doFilter(request, response);}
}

7.最后

这三种spring boot中解决跨域的方式通常第二种跟第一种使用的最多,对于不需要细腻控制到某个接口方法的推荐使用第二种全局配置解决。

http://www.yayakq.cn/news/803261/

相关文章:

  • 电子商务网站建设与维护的考试黄金网站app大全
  • 机械类毕业设计代做网站推荐node.js做企业网站
  • 肥乡县建设局网站百度指数网
  • 我的世界服务器如何做充钱网站加工平台用什么材料
  • 网站建设需要投资多少长沙网站设计公司推荐
  • 工业信息部网站备案网站公司网站建设
  • 那个网站做代买中国商标网注册官网
  • 网站建设费如何会计处理什么是网络营销网络营销与电商营销有什么区别
  • 服务器上网站建设成都plc培训机构哪家最好
  • 伪静态 网站如何扫描网站建设天地心
  • django网站开发实例源码成都网站建设服务
  • 常州溧阳网站建设wordpress三主题公园
  • 如何百度搜索到自己的网站小说网站建设吧
  • 网站代建设费用吗网站分类页标题加长
  • 上海网站建设外贸网页设计基础代码
  • 黄冈网站建设与推广哪家好建设厅企业锁在哪个网站登录
  • 网站首页轮播图怎么做小企网站建设解决方案
  • 昆明企业建网站多少钱灵犀科技+网站开发佼佼者
  • 网上做平面设计兼职不错的网站怎么百度推广
  • 无锡网站建设无锡网络推广四川城乡建设厅官方网站
  • 秦皇岛网站建设找汉狮图纸设计软件手机版
  • 如何上传模板到网站手机上设计logo的app
  • wordpress多条件过滤东营做网站优化
  • 十大知名博客网站做旅游的网站在哪里做
  • 广东深圳建设工程信息网站轻量应用服务器装Wordpress
  • 腾讯官方网站做书签济源网站建设济源
  • 手机网站开发 速度男女做那些事免费网站
  • 海南网站建设方案唐山网站建设电话
  • 网站上做旅游卖家要学什么软件网站首屏
  • 唐山网站建设费用品牌营销咨询公司是做什么的