java vue怎么在后端配置跨域
时间: 2023-12-16 08:25:30 浏览: 130
在后端配置跨域,可以通过 Spring Boot 和 Vue.js 的组合进行实现。
下面是一个简单的 Spring Boot 配置跨域的示例:
```java
@Configuration
public class CorsConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedOrigins("*")
.allowedMethods("*")
.allowedHeaders("*")
.allowCredentials(true)
.maxAge(3600);
}
}
```
上述代码中,`@Configuration` 注解表示这是一个配置类,`CorsConfig` 类实现了 `WebMvcConfigurer` 接口。在 `addCorsMappings` 方法中,通过调用 `CorsRegistry` 对象的方法来配置跨域。
具体来说,`.addMapping("/**")` 表示配置所有的请求都支持跨域访问,`.allowedOrigins("*")` 表示所有的来源都可以访问,`.allowedMethods("*")` 表示所有的方法都可以访问,`.allowedHeaders("*")` 表示所有的头信息都可以访问,`.allowCredentials(true)` 表示允许发送 Cookie,`.maxAge(3600)` 表示缓存时间为 3600 秒。
在 Vue.js 中,可以通过在 `vue.config.js` 文件中配置代理来实现跨域。
以下是一个示例代码:
```javascript
module.exports = {
devServer: {
proxy: {
'/api': {
target: 'http://localhost:8080',
changeOrigin: true,
pathRewrite: {
'^/api': ''
}
}
}
}
}
```
以上代码中,`'/api'` 表示需要代理的路径,`target: 'http://localhost:8080'` 表示代理到的地址,`changeOrigin: true` 表示开启跨域,`pathRewrite` 表示重写路径。在 Vue.js 中发送请求时,只需要将请求路径的前缀改为 `/api` 即可,例如 `/api/user`。这样就可以实现跨域访问了。
阅读全文