在localhost上,我已经下载了Flask-Cors。我尝试向烧瓶服务器发送一些请求,因为整个代码下面的代码在github上。
遗憾的是,我无法使用POST请求获取任何数据。
这是我的ELM代码。
module Update exposing (update)
import Http
import Json.Decode exposing (..)
import Types exposing (..)
update : Msg -> Model -> (Model, Cmd Msg)
update msg model =
case msg of Username str -> ({ model | loginUserName = str}, Cmd.none)
Password str -> ({ model | loginPassword = str}, Cmd.none)
Login -> (model, login model.loginUserName model.loginPassword)
LoginResult (Ok username) -> ({ model | user = LoggedInUser { userName = username}},
Cmd.none)
LoginResult (Err _) -> (model, Cmd.none)
Logout -> (model, Cmd.none)
login : String -> String -> Cmd Msg
login username password =
let url = "http://0.0.0.0:8080/api/user/login"
request = Http.get url decodeLogin
in Http.send LoginResult request
decodeLogin: Decoder String
decodeLogin = at ["username"] string
-- Or
--decodeLogin : Decoder String
--decodeLogin = decodeString (field "username" string)
其余代码位于Github
这是我的API
的Flask端点@app.route("/api/user/login/", methods=["GET", "POST"])
def login(*args, **kwargs):
print 'Got request for login'
print args
print kwargs
print request.args
print request.args.get("username")
print request.values.get("username")
print request.method
print request.form['username']
response = {'username': 'Erik'}
dict = request.args
for key in dict:
print 'form key ' + dict[key]
return jsonify(response)
此代码的其余部分也是at this link
。
答案 0 :(得分:2)
我只想补充一点,虽然您可以在IP地址0.0.0.0
处指示请求,但这不是您的烧录应用正在侦听的地址。 0.0.0.0
表示烧瓶应用正在侦听所有可用的IP地址(不包括0.0.0.0
,因为它是为此目的而保留的)。您可以通过127.0.0.1
和localhost
答案 1 :(得分:1)
看起来您的服务器期望POST的主体采用多种key=val
格式,而不是JSON格式。您可以使用multipartBody
来实现此目的:
import Http exposing (..)
login : String -> String -> Cmd Msg
login username password =
let url = "http://0.0.0.0:8080/api/user/login"
body =
multipartBody
[ stringPart "username" username
, stringPart "password" password
]
request = Http.post url body decodeLogin
in Http.send LoginResult request