文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

py脚本curl报错解决方法curl: (1) Received HTTP/0.9 when not allowed

2023-09-12 14:19

关注

最近博主做一个项目,发现请求从PHP的句柄请求py脚本,老是获取不到返回数据。

所以,我直接去服务器采用curl访问,结果就报错curl: (1) Received HTTP/0.9 when not allowed

  1. 一开始我以为是我php的句柄方法中的问题,但是我用其访问另外其它系统对接的curl接口,并没有报错。

  1. 也以为是curl的错误,各种搜索以及升级curl版本,仍然解决不了。

  1. 偶然我把这个访问直接放在本地去访问,结果报错如下,有经验的大佬一看就明白,这很显然是跨域错误。

引荐来源网址政策: strict-origin-when-cross-origin

一般来说,我们常见的跨域错误都是前后端时,这种情况下,只要在任意一段加入解决跨域错误的固定代码即可,类似的 比如tp5或者vue前端,为了以后再遇到这个坑不会再踩雷,特此记录下来。

#自定义处理程序,用于处理HTTP请求class TestHTTPHandler(BaseHTTPRequestHandler):#处理GET请求    def do_GET(self):        parsed =urlparse(self.path)        ids=parsed.query.split('=')        contract,contract_pay=read_data()        if len(ids)>1:            ids=ids[1].split(',')            ids=list(map(lambda x:int(x),ids))            print('ids长度>1的时候')# =============================================================================#             print(ids)#             print('contract')#             print(contract)#             print('contract_pay')#             print(contract_pay)#             print('engine')#             print(engine)# =============================================================================            status=update_finance(contract,contract_pay,engine,ids)            print('ids长度>1的时候返回的status的值')            print(status)        else:            print('ids长度<=1的时候')            status=update_finance(contract,contract_pay,engine)        self.protocal_version = 'HTTP/1.1'        self.send_response(200) #设置响应状态码        self.send_header('Access-Control-Allow-Origin', '*')        self.send_header('Access-Control-Allow-Methods', 'GET')        self.send_header('Access-Control-Allow-Headers', 'Access-Control-Allow-Headers, Origin, Accept, X-Requested-With, Content-Type, Access-Control-Request-Method, Access-Control-Request-Headers')        self.end_headers()        self.wfile.write(json.dumps(status).encode()) #输出响应内容 bytes("hello".encode('utf-8'))def start_server(port):    http_server = HTTPServer(('0.0.0.0', int(port)), TestHTTPHandler)    print('http_server')    http_server.serve_forever()#设置一直监听并接收请求if __name__=='__main__':    start_server(2187)#启动服务,监听2187端口

最重要的一点

self.send_header('Access-Control-Allow-Origin', '*')self.send_header('Access-Control-Allow-Methods', 'GET')self.send_header('Access-Control-Allow-Headers', 'Access-Control-Allow-Headers, Origin, Accept, X-Requested-With, Content-Type, Access-Control-Request-Method, Access-Control-Request-Headers')

来源地址:https://blog.csdn.net/u011242029/article/details/128706391

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯