0

使用 Flask 和 BlueMix 部署 Web 应用程序。有一些我似乎无法弄清楚的 js 问题。我在浏览器控制台中不断收到相同的错误。我不知道任何js,所以任何帮助将不胜感激!

jquery-1.11.1.min.js:4 POST http://newfla.mybluemix.net/ 405 (Method Not  Allowed)
send @ jquery-1.11.1.min.js:4
m.extend.ajax @ jquery-1.11.1.min.js:4 
(anonymous function) @ demo.js:66
m.event.dispatch @ jquery-1.11.1.min.js:3
r.handle @ jquery-1.11.1.min.js:3

这是假定的(匿名函数)

 $.ajax({
  type: 'POST',
  data: {
    text: $content.val()
  },
  url: '/',
  dataType: 'json',
  success: function(response) {
    $loading.hide();

    if (response.error) {
      showError(response.error);
    } else {
      $results.show();
      showTraits(response);
      showTextSummary(response);
      showVizualization(response);
    }

  }

更新:我尝试了一些与您的建议相匹配的不同方法。这是我现在的位置,有什么想法吗?

consumer_token = 'aaaaaaaaaaaaaaaaaaaaaaaaa' #substitute values from twitter     website 
consumer_secret = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
access_token = '3473558363-aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
access_secret = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'

auth = tweepy.OAuthHandler(consumer_token,consumer_secret)
auth.set_access_token(access_token,access_secret)

api  = tweepy.API(auth)

class PersonalityInsightsService:
"""Wrapper on the Personality Insights service"""

def __init__(self, vcapServices):
"""
Construct an instance. Fetches service parameters from VCAP_SERVICES
runtime variable for Bluemix, or it defaults to local URLs.
"""


self.url = "https://gateway.watsonplatform.net/personality-insights/api"
self.username = "aaaaaa-vvvv-1111-2222-mmmmmmmm"
self.password = "password"

if vcapServices is not None:
    print("Parsing VCAP_SERVICES")
    services = json.loads(vcapServices)
    svcName = "personality_insights"
    if svcName in services:
        print("Personality Insights service found!")
        svc = services[svcName][0]["credentials"]
        self.url = svc["url"]
        self.username = svc["username"]
        self.password = svc["password"]
    else:
        print("ERROR: The Personality Insights service was not found")
def getProfile(self, text):
    """Returns the profile by doing a POST to /v2/profile with text"""

    if self.url is None:
        raise Exception("No Personality Insights service is bound to this app")
    response = requests.post(self.url + "/v2/profile",
                      auth=(self.username, self.password),
                      headers = {"content-type": "text/plain"},
                      data=text
                      )
    try:
        return json.loads(response.text)
    except:
        raise Exception("Error processing the request, HTTP: %d" % response.status_code)

class DemoService(object):
    """
    REST service/app. Since we just have 1 GET and 1 POST URLs,
    there is not even need to look at paths in the request.
    This class implements the handler API for cherrypy library.
    """

    screen_name = "realDonaldTrump"
    maxnumtweets= 500

    saveFile = open("static/public/text/en.txt",'a')
    saveFile.seek(0)
    saveFile.truncate()


    for status in     tweepy.Cursor(api.user_timeline,id=screen_name).items(maxnumtweets): 
    print status.text[0:2] + '\n'
    saveFile = open("static/public/text/en.txt",'a')

    textyt = status.text

    texty = ''.join(i for i in textyt if ord(i)<128)
    saveFile.write(texty.encode('utf-8')+'\n'+'\n')
    saveFile.close()

def __init__(self, service):
    self.service = service
    self.defaultContent = None

    try:
        contentFile = open("static/public/text/en.txt", "r")
        self.defaultContent = contentFile.read()
    except Exception as e:
        print "ERROR: couldn't read text file: %s" % e
    finally:
        contentFile.close()

def GET(self):
   return render_template('newin.html', content= self.defaultContent)




def POST(self, text=None):
    """
    Send 'text' to the Personality Insights API
    and return the response.
    """
    try:
        profileJson = self.service.getProfile(text)
        return json.dumps(profileJson)
    except Exception as e:
        print "ERROR: %s" % e
        return str(e)


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

@app.route('/getpost', methods=['GET', 'POST'])
def new():
    personalityInsights = PersonalityInsightsService(os.getenv("VCAP_SERVICES"))
c = DemoService(personalityInsights)
if request.method == 'GET':
    return c.GET()
elif request.method == 'POST':
    return c.POST()
4

1 回答 1

4

这不是 Javascript 问题。为根 URL 提供服务的视图函数未配置为接受POST请求。响应代码 405 是METHOD NOT ALLOWED(这里的方法POSTGET, PUT, DELETE, OPTIONS, HEAD, 等相反...

我可以用一个非常简单的 hello world Flask 应用程序重新创建它

应用程序.py:

from flask import Flask

app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello World'

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

从命令行运行应用程序(将在 提供http://localhost:5000/):

python app.py

然后尝试从另一个终端发布反对它(使用requests库):

import requests

response = requests.post('http://localhost:5000/', data='')

打印响应将产生:

<Response [405]>

请注意405- 您收到的相同响应代码,不允许的方法。您需要通过更新装饰器显式定义除GET您希望 Flask 视图使用之外的任何方法:app.route

@app.route('/', methods=['GET', 'POST'])
def hello_world():
    return 'Hello World'

POST但是,通常,如果客户端执行 a而不是 a ,您将希望实现不同的功能GET。您可以通过查看request.method(您还需要 import request)来做到这一点:

from flask import Flask, request

app = Flask(__name__)

@app.route('/', methods=['GET', 'POST'])
def hello_world():
    if request.method == 'GET':
        return 'You GOT hello world'
    elif request.method == 'POST':
        return 'You POSTed hello world'

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

如果您想了解更多有关不同 HTTP 方法的信息,请在此处定义它们。

于 2015-11-07T19:06:09.870 回答