How can I fix my Flask server‘s 405 error that includes OpenAi api?

**题意:**解决包含OpenAI API的Flask服务器中出现的405错误(Method Not Allowed,即方法不允许)

问题背景:

I'm trying to add an API to my webpage and have never used any Flask server before, I have never used Javascript too so this is a completely brand new learning experience. My problem is that I keep receiving a 405 error code saying that the method is not allowed. I keep on using the POST method but it isn't working, I am banking that my issue may be with my HTML code more than my Flask server because the code is extremely generic and simple.

我正在尝试将API添加到我的网页中,但我之前从未使用过任何Flask服务器,也从未使用过JavaScript,所以这对我来说是完全全新的学习体验。我的问题是,我不断收到405错误代码,表示方法不允许。我一直在使用POST方法,但它不起作用。我认为我的问题可能更多地出在我的HTML代码上,而不是Flask服务器,因为我的代码非常通用且简单。

python 复制代码
import openai
from flask import Flask, request, jsonify

app = Flask(__name__)

openai.api_key = '**my key is in here**'

@app.route('/', methods=['POST'])
def chat():
    data = request.get_json()
    message = data.get('message')
    
    response = openai.Completion.create(
        model="gpt-3.5-turbo",  
        prompt=message,
        max_tokens=50
    )

    return {'response': response.choices[0].text.strip()}

if __name__ == '__main__':
    app.run(port=5000)
python 复制代码
async function sendMessage() {
            const message = document.getElementById('message').value;
            document.getElementById('chat-box').innerHTML += `<div>You: ${message}</div>`;
            
            const response = await fetch('/', {
                method: "POST",
                body: JSON.stringify({ message }),
                headers: {
                    'Content-Type': 'application/json',
                },
            });

            const data = await response.json();
            document.getElementById('chat-box').innerHTML += `<div>Bot: ${data.reply}</div>`;
            document.getElementById('message').value = '';
        }

I tried changing up the structure of the code, I uninstalled Flask and reinstalled it again. I've also extensively used chatgpt to try and come up with better code but it just kept taking me in circles. I'm hoping someone can help with this. I even tried a simple server that just said hello world which worked, but I truly think the issue might be with my javascript. Also, I am a beginner and this is supposed to be one of my first coding projects so please take it easy on me if possible. Thanks.

我尝试更改代码的结构,卸载并重新安装了Flask。我还广泛使用了chatgpt来尝试编写更好的代码,但它只是让我在原地打转。我希望有人能帮忙解决这个问题。我甚至尝试了一个简单的服务器,它只是输出"hello world",这个是可以工作的,但我真的认为问题可能出在我的JavaScript上。另外,我是个初学者,这应该是我的第一个编程项目之一,所以如果可能的话,请对我宽容一些。谢谢。

问题解决:

You have to add a route for '/' to serve the html file. I also fixed the way you call the OpenAI API because you're using a deprecated one.

你需要添加一个针对'/'的路由来提供HTML文件。我还修复了你调用OpenAI API的方式,因为你正在使用一个已弃用的版本。

python 复制代码
import openai
from flask import Flask, request, jsonify, render_template

chat_client = OpenAI(api_key='....')


@app.route('/')
def index():
    return render_template('index.html')

@app.route('/', methods=['POST'])
def chat():
    data = request.get_json()
    message = data.get('message')
    
    response = chat_client.chat.completions.create(
        model="gpt-3.5-turbo",
        messages=[
            {"role": "user", "content": message}
        ],
        max_tokens=50
    )

    return jsonify({'reply': response.choices[0].message.content.strip()})

if __name__ == '__main__':
    app.run(port=5000, debug=True)

sample index.html that I tested with

我测试时使用的示例 index.html 文件

python 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Chat app</title>
    <script>
        async function sendMessage() {
            const message = document.getElementById('message').value;
            document.getElementById('chat-box').innerHTML += `<div>You: ${message}</div>`;
            
            const response = await fetch('/', {
                method: "POST",
                body: JSON.stringify({ message }),
                headers: {
                    'Content-Type': 'application/json',
                },
            });

            const data = await response.json();
            document.getElementById('chat-box').innerHTML += `<div>Bot: ${data.reply}</div>`;
            document.getElementById('message').value = '';
        }
    </script>
</head>
<body>
    <div id="chat-box"></div>
    <input type="text" id="message" placeholder="Type your message here...">
    <button onclick="sendMessage()">Send</button>
</body>
</html>

Directory structure 目录结构

python 复制代码
- app.py
- templates/
  - index.html
相关推荐
阿菜ACai14 小时前
Claude 和 Codex 在审计 Skill 上性能差异探究
ai·代码审计
A__tao15 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
研究点啥好呢16 小时前
Github热门项目推荐 | 创建你的像素风格!
c++·python·node.js·github·开源软件
SharpCJ16 小时前
Android 开发者为什么必须掌握 AI 能力?端侧视角下的技术变革
android·ai·aigc
午安~婉16 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
迷藏49416 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
明日清晨16 小时前
python扫码登录dy
开发语言·python
bazhange17 小时前
python如何像matlab一样使用向量化替代for循环
开发语言·python·matlab
哟哟耶耶17 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐17 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全