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

知名高端网站建设网站开发怎么样

知名高端网站建设,网站开发怎么样,wordpress 新网页打开,手机网站素材网简介 出于安全方面考虑,浏览器发起请求时,会先检查同源策略(协议、主机、端口是否与当前页面相同),不匹配则认为是跨域请求。 CORS (Cross-Origin Resource Sharing) CORS是一种机制,允许服务器声明哪些…

简介

出于安全方面考虑,浏览器发起请求时,会先检查同源策略(协议、主机、端口是否与当前页面相同),不匹配则认为是跨域请求。

CORS (Cross-Origin Resource Sharing)

CORS是一种机制,允许服务器声明哪些域(origin)可以访问其资源,从而绕过同源策略的限制。浏览器会发送预检请求(Preflight Request)以确定是否允许跨域访问。

Preflight请求

Preflight请求是跨域资源共享(CORS)中的一种机制,用于在实际请求之前发送一个预检请求。浏览器在发送某些类型的跨域请求(例如带有自定义标头的请求)之前,会自动发送一个OPTIONS请求,以获取目标服务器是否允许实际请求的权限。

预检请求包含一组查询信息,询问服务器是否允许实际请求。这些查询信息包括:

  • Access-Control-Request-Method: 表示实际请求中将使用的 HTTP 方法(例如 GET、POST)。
  • Access-Control-Request-Headers: 表示实际请求中将使用的自定义 HTTP 标头。

服务器收到预检请求后,会检查这些信息,然后决定是否允许实际请求。如果服务器允许,它会在响应中包含相应的 CORS 头(例如 Access-Control-Allow-Origin、Access-Control-Allow-Methods 等)。

这个预检请求机制有助于确保安全,因为它防止了潜在的恶意跨域请求。如果服务器支持并验证了预检请求,浏览器才会允许实际请求。

以下是一个预检请求的示例:

请求:

OPTIONS /example/resource HTTP/1.1
Host: example.com
Access-Control-Request-Method: POST
Access-Control-Request-Headers: Content-Type, Authorization

响应:

HTTP/1.1 200 OK
Access-Control-Allow-Origin: http://example.com
Access-Control-Allow-Methods: GET, POST
Access-Control-Allow-Headers: Content-Type, Authorization

Spring MVC跨域设置

浏览器发起Preflight请求,SpringMVC的处理流程为:
DispatcherServlet#doDispatch -> HttpRequestHandlerAdapter#handle -> AbstractHandlerMapping#handleRequest -> DefaultCorsProcessor#processRequest
DefaultCorsProcessor会根据当前配置的跨域规则,检查当前资源你是否允许发起的域访问,检查不通过时直接返回403 Forbidden,body为Invalid CORS request。

注解方式
可以在类,或者方法上使用@CrossOrigin(origins = "*", methods = {RequestMethod.GET, RequestMethod.POST, RequestMethod.OPTIONS})

Filter模式
对于使用了Spring-Web而没有使用SpringMVC的项目,可以使用Spring提供的CorsFilter,它会拦截的Servlet请求,并添加一些允许跨域的头,以下是允许所有请求跨域的示例

@Configuration
public class CorsConfig {@Beanpublic CorsFilter corsFilter() {UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();CorsConfiguration config = new CorsConfiguration();config.addAllowedOrigin("*");config.addAllowedMethod("*");config.addAllowedHeader("*");source.registerCorsConfiguration("/**", config);return new CorsFilter(source);}
}

测试

可以使用以下html进行跨域测试

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>POST Request Form</title>
</head>
<body><h1>POST Request Form</h1><form id="postForm"><label for="url">URL:</label><input type="text" id="url" name="url" value="http://xxx" style="width: 100%; margin-bottom: 10px;"><label for="postData">POST Data:</label><textarea id="postData" name="postData" style="width: 100%; height: 100px; margin-bottom: 10px;">
{}</textarea><button type="button" onclick="sendPostRequest()">Send POST Request</button>
</form><script>
function sendPostRequest() {var url = document.getElementById("url").value;var postData = document.getElementById("postData").value;fetch(url, {method: 'POST',headers: {'Content-Type': 'application/json',},body: postData,}).then(response => response.json()).then(data => {console.log('Success:', data);alert('POST request sent successfully!');}).catch((error) => {console.error('Error:', error);alert('Error sending POST request!');});
}
</script></body>
</html>
http://www.yayakq.cn/news/606984/

相关文章:

  • 网站排名优化服务商郑州做网站公司排
  • 广州建设交易中心网站首页华北建设招标网官方网站
  • 做电影网站怎么样广州宣传片拍摄制作的公司
  • 沈阳网站推广¥做下拉去118cr网站设计书怎么写
  • 网站开发需要大学吗简易app制作平台
  • 能免费做微信群推广的网站米拓建站免费模板
  • 绵阳做网站优化北京网络优化推广公司
  • 温州商城网站建设做网站应该掌握的技术
  • 网站提交入口如何更新单位网站
  • 南昌网站建设专业公司网站建设吧
  • 网站建设需要怎么做在网站建设中遇到的问题
  • 邯郸网站建设多少钱网络设计需求分析
  • 招聘网站毕业设计修改备案网站信息
  • 做海淘的网站商城网站备案能通过吗
  • 河南响应式建站外包公司能去吗
  • 网站正在建设模板四川省住房建设厅官方网站
  • 前端网站开发项目经验电梯网站建设
  • 如何做php网站建设typo3和wordpress
  • 电商网站怎么做与众不同肥城网站建设流程
  • 爱站seo工具包免费版2019建设什么网站好运营
  • 有什么网站有教师招聘考试题目做网站开发语言开发
  • 微山网站建设多少钱河北项目网官网
  • 校园网站建设硬件采购知识库wordpress插件
  • 外贸商城网站制作wordpress水平菜单
  • h5 php mysql网站开发做教育类网站
  • 东莞常平做网站公司粤语seo是什么意思
  • 网站开发过程总结logo在线设计制作工具
  • 网站建设设计合同书seo推广平台服务
  • 十大招标网站排行榜设计科技公司官网
  • 网站建设备案费用会员卡管理系统软件哪个好用