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

最近博主做一个项目,发现请求从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')

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
xiaoxingxing的头像xiaoxingxing管理团队
上一篇 2023年9月6日
下一篇 2023年9月6日

相关推荐