前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PHP允许前端跨域请求的相关请求头设置、文件下载

PHP允许前端跨域请求的相关请求头设置、文件下载

作者头像
房东的狗丶
发布2023-02-17 13:58:57
1.7K0
发布2023-02-17 13:58:57
举报
文章被收录于专栏:友人a的笔记丶

CORS 请求分成两类:简单请求(simple request)和非简单请求(not-so-simple request)。

PHP中的 header 函数用于设置响应头。

当POST数据为JSON,必须允许请求头才能跨域访问,因为Content-type:application/json; 默认是不允许跨域的。

如何允许跨域?

1.允许跨域名访问

代码语言:javascript
复制
header('Access-Control-Allow-Origin: *');

2.允许请求方式

代码语言:javascript
复制
header('Access-Control-Allow-Methods: *');

3.允许请求头

代码语言:javascript
复制
header('Access-Control-Allow-Headers: *');

输出一个文件

请求头中的文件名尽量使用urlcode编码,因为部分浏览器无法处理直接的中文名文件;

代码语言:javascript
复制
<?php
$file = 'test.zip';
header('content-type:application/octet-stream');
header('content-disposition:attachment; filename='.basename($file));
header('content-length:'.filesize($file));
echo file_get_contents($file);

跨域的验证码

JS无法读取设置为httponly的cookie,跨域名设置cookie会失败(默认是当前请求的接口的域名,跨域名需要单独设置指定域名)

图片如果没有开启防盗链,是不受跨域限制的,在PHP输出验证码的时候 验证码会正常展示,

但由于跨域名的原因Cookie不会被正常保存。导致后端Session无法获取到会话中的验证码。

当跨域请求需要携带cookie时,请求头中需要设置Access-Control-Allow-Credentials:true。设置之后代表接口跨域的cookie

Access-Control-Allow-Credentials值为true时,Access-Control-Allow-Origin必须有明确的值,不能是通配符(*);axios需要进行如下的设置:

代码语言:javascript
复制
// `withCredentials` 表示跨域请求时是否需要使用凭证
  withCredentials: false, // default
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-11-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 如何允许跨域?
    • 1.允许跨域名访问
      • 2.允许请求方式
        • 3.允许请求头
        • 输出一个文件
        • 跨域的验证码
        相关产品与服务
        验证码
        腾讯云新一代行为验证码(Captcha),基于十道安全栅栏, 为网页、App、小程序开发者打造立体、全面的人机验证。最大程度保护注册登录、活动秒杀、点赞发帖、数据保护等各大场景下业务安全的同时,提供更精细化的用户体验。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档