Проблемы с почтовым запросом в интерфейсе Flutter / Dart с Go backend - PullRequest
0 голосов
/ 24 мая 2018

Я новичок в Flutter / Dart, Go и мобильной разработке в целом.Я в настоящее время кодирую страницу аутентификации входа во флаттере, которая соединяется с бэкэндом, написанным на go.Чтобы проверить, все ли работает, я хотел распечатать куки, которые мой сервер отправляет обратно в консоль.К сожалению, я получаю ошибки, не знаю, что делать.

РЕДАКТИРОВАТЬ: я смог прочитать файл cookie, должен ли я сохранить файл cookie в формате «session = UUID» или просто «UUID»?Я хочу отправить этот cookie обратно в заголовок для будущих запросов на получение.Мой код Go проверит наличие cookie-файла с именем «session», но я не уверен, верна ли его отправка в этом формате.

Flutter code (я читал в другом сообщении stackoverflowиспользовать 10.0.2.2 в качестве локального хоста при использовании эмулятора Android):

РЕДАКТИРОВАТЬ: После игры с кодом я смог прочитать cookie в заголовке, но он имеет имя какну не только UUID.

import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'dart:convert';



class Login extends StatefulWidget {
  @override
  State<StatefulWidget> createState(){
    return new LoginState();
  }
}


class LoginState extends State <Login> {

  final formKey = GlobalKey<FormState>();
  String _email, _password;
  String cookie;



  void loginApi(){
    var form = formKey.currentState;
    var url = "http://10.0.2.2:8080";
      if (form.validate()) {
        form.save();
        var body = { "Email":_email, "Pass":_password};
        http.post(url,body:json.encode(body)).then((response){
          print(response.headers['set-cookie']);
        });
      }
  }

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      appBar: new AppBar(
        title: new Text("Login"),
        backgroundColor: Colors.white,
      ),
      body: new Container(
        alignment: Alignment.center,
        child: Form(
            key: formKey,
            child: Column(
              children: <Widget>[

                TextFormField(
                  autocorrect: false,
                  decoration: InputDecoration(
                    labelText: "Email:",
                  ),
                  validator: (str) =>
                  !str.contains('@') ? "Not a Valid Email!" : null,
                  onSaved: (str) =>  _email = str,
                ),

                TextFormField(
                  autocorrect: false,
                  decoration: InputDecoration(
                    labelText: "Password:",
                  ),
                  validator: (str) =>
                  str.length <= 7 ? "Not a Valid Password!" : null,
                  onSaved: (str) => _password = str,
                  obscureText: false,
                ),

                RaisedButton(
                  child: Text("Submit"),
                  onPressed:loginApi,
                ),
              ],
            )
        ),
      ),


    );
  }
}

Код Голанга (РЕДАКТИРОВАТЬ: вставил отсутствующую фигурную скобку после ошибки паники и удалил фигурную скобку в конце кода):

package main

import (
    "encoding/json"
    "html/template"
    "net/http"

    uuid "github.com/satori/go.uuid"
    "golang.org/x/crypto/bcrypt"
)

type user struct {
    UserName string //Same as email
    Password []byte
}

type logindata struct {
    Email string
    Pass  string
}

var tpl *template.Template
var dbUsers = map[string]user{}
var dbSess = map[string]string{}

func init() {
    bs, _ := bcrypt.GenerateFromPassword([]byte("password"), bcrypt.MinCost)
    dbUsers["test@test.com"] = user{"test@test.com", bs}
}

func main() {
    http.HandleFunc("/", login)
    http.Handle("/favicon.ico", http.NotFoundHandler()) //Don't have favicon
    http.ListenAndServe(":8080", nil)
}

func login(w http.ResponseWriter, req *http.Request) {
    var data logindata

    decoder := json.NewDecoder(req.Body)
    err_decode := decoder.Decode(&data)
    if err_decode != nil {
        panic(err_decode)
    }
    u, ok := dbUsers[data.Email]
    if !ok {
        http.Error(w, "Username and/or password do not match", http.StatusForbidden)
        return
    }

    err_compare := bcrypt.CompareHashAndPassword(u.Password, []byte(data.Pass))
    if err_compare != nil {
        http.Error(w, "Username and/or password do not match", http.StatusForbidden)
        return
    }

    // create session
    sID, _ := uuid.NewV4()
    c := &http.Cookie{
        Name:  "session",
        Value: sID.String(),
    }
    http.SetCookie(w, c)
    dbSess[c.Value] = data.Email
    return

}

Вывод из консоли для кода флаттера (после того, как я введу имя пользователя и пароль и нажму "отправить", имя пользователя будет "test@test.com", пароль - "пароль"):

Performing hot reload...
Reloaded 0 of 489 libraries in 544ms.
I/flutter ( 3778): session=db3690d6-db6e-4658-8b5b-5f2d3f908a65

Я также пошел на localhost: 8080 в моем браузере ожидал показать пустую страницу, но на нем отображалось «страница не работает», и мой терминал выдал следующую ошибку, я думаю, потому что я к ней обращалсяс браузером, и я не был сенв данных JSON, не уверен:

2018/05/24 23:29:38 http: panic serving [::1]:40010: EOF
goroutine 6 [running]:
net/http.(*conn).serve.func1(0xc82001a280)
    /usr/lib/go-1.6/src/net/http/server.go:1389 +0xc1
panic(0x76c6c0, 0xc82000a160)
    /usr/lib/go-1.6/src/runtime/panic.go:443 +0x4e9
main.login(0x7f96c9a848b8, 0xc82012c000, 0xc8201121c0)
    /home/daniel/Desktop/Workspace/Genesis/main.go:43 +0x176
net/http.HandlerFunc.ServeHTTP(0x8a8688, 0x7f96c9a848b8, 0xc82012c000, 0xc8201121c0)
    /usr/lib/go-1.6/src/net/http/server.go:1618 +0x3a
net/http.(*ServeMux).ServeHTTP(0xc820013020, 0x7f96c9a848b8, 0xc82012c000, 0xc8201121c0)
    /usr/lib/go-1.6/src/net/http/server.go:1910 +0x17d
net/http.serverHandler.ServeHTTP(0xc82001a100, 0x7f96c9a848b8, 0xc82012c000, 0xc8201121c0)
    /usr/lib/go-1.6/src/net/http/server.go:2081 +0x19e
net/http.(*conn).serve(0xc82001a280)
    /usr/lib/go-1.6/src/net/http/server.go:1472 +0xf2e
created by net/http.(*Server).Serve
    /usr/lib/go-1.6/src/net/http/server.go:2137 +0x44e
2018/05/24 23:29:38 http: panic serving [::1]:40012: EOF
goroutine 18 [running]:
net/http.(*conn).serve.func1(0xc82011c080)
    /usr/lib/go-1.6/src/net/http/server.go:1389 +0xc1
panic(0x76c6c0, 0xc82000a160)
    /usr/lib/go-1.6/src/runtime/panic.go:443 +0x4e9
main.login(0x7f96c9a848b8, 0xc8201161a0, 0xc820154000)
    /home/daniel/Desktop/Workspace/Genesis/main.go:43 +0x176
net/http.HandlerFunc.ServeHTTP(0x8a8688, 0x7f96c9a848b8, 0xc8201161a0, 0xc820154000)
    /usr/lib/go-1.6/src/net/http/server.go:1618 +0x3a
net/http.(*ServeMux).ServeHTTP(0xc820013020, 0x7f96c9a848b8, 0xc8201161a0, 0xc820154000)
    /usr/lib/go-1.6/src/net/http/server.go:1910 +0x17d
net/http.serverHandler.ServeHTTP(0xc82001a100, 0x7f96c9a848b8, 0xc8201161a0, 0xc820154000)
    /usr/lib/go-1.6/src/net/http/server.go:2081 +0x19e
net/http.(*conn).serve(0xc82011c080)
    /usr/lib/go-1.6/src/net/http/server.go:1472 +0xf2e
created by net/http.(*Server).Serve
    /usr/lib/go-1.6/src/net/http/server.go:2137 +0x44e
2018/05/24 23:29:43 http: panic serving [::1]:40016: EOF
goroutine 7 [running]:
net/http.(*conn).serve.func1(0xc82001a380)
    /usr/lib/go-1.6/src/net/http/server.go:1389 +0xc1
panic(0x76c6c0, 0xc82000a160)
    /usr/lib/go-1.6/src/runtime/panic.go:443 +0x4e9
main.login(0x7f96c9a848b8, 0xc82012c1a0, 0xc8201122a0)
    /home/daniel/Desktop/Workspace/Genesis/main.go:43 +0x176
net/http.HandlerFunc.ServeHTTP(0x8a8688, 0x7f96c9a848b8, 0xc82012c1a0, 0xc8201122a0)
    /usr/lib/go-1.6/src/net/http/server.go:1618 +0x3a
net/http.(*ServeMux).ServeHTTP(0xc820013020, 0x7f96c9a848b8, 0xc82012c1a0, 0xc8201122a0)
    /usr/lib/go-1.6/src/net/http/server.go:1910 +0x17d
net/http.serverHandler.ServeHTTP(0xc82001a100, 0x7f96c9a848b8, 0xc82012c1a0, 0xc8201122a0)
    /usr/lib/go-1.6/src/net/http/server.go:2081 +0x19e
net/http.(*conn).serve(0xc82001a380)
    /usr/lib/go-1.6/src/net/http/server.go:1472 +0xf2e
created by net/http.(*Server).Serve
    /usr/lib/go-1.6/src/net/http/server.go:2137 +0x44e

1 Ответ

0 голосов
/ 24 мая 2018

В вашем коде

    http.post(url,body:json.encode(body)).then((http.Response response){
      cookie = response.headers['session'];
    });
    debugPrint(cookie);

строка

debugPrint(cookie);

выполняется перед

cookie = response.headers['session'];

, поэтому ожидается, что cookie - это null при печати.По какой-то странной причине debugPrint(null) выдает исключение о "slit on null"

Попробуйте вместо

    http.post(url,body:json.encode(body)).then((http.Response response){
      cookie = response.headers['session'];
      debugPrint(cookie);   
    });
...