如何将Flutter连接到localhost MySQL数据库

时间:2019-05-13 19:10:41

标签: mysql dart flutter

我想将localhost mysql db连接起来但无法执行。我通过以下连接尝试了mysql1:

ConnectionSettings(
        host: '10.0.2.2',
        port: 3306,
        user: 'root',
        password: "root",
        db: 'company'

,我尝试用'localhost'代替主机,但没有用。有什么帮助吗?我没有使用模拟器。

1 个答案:

答案 0 :(得分:0)

除了Firebase以外,直接连接到MySQL(或直接从客户端进行任何其他数据库访问)的连接不是一个好主意。 如果要与MySql db交互,更好的解决方案是创建服务器应用程序并公开一些HTTP REST API(使用node.js,php等)。使用API​​,您还可以为客户端提供令牌,以访问您的数据。 您可以发出HTTP请求https://api.dartlang.org/stable/1.24.3/dart-io/HttpClient-class.html

现在,如果出于任何原因仍要直接连接到MySQL,请记住,在这种情况下,任何客户端应用程序都可以使用 write 权限访问您的数据库(这不是一个好习惯全部!)仅作为测试示例,您可以尝试创建php文件:

//连接并插入数据示例

<?php 
    if (isset($_POST["value"])) {
        $servername = "localhost";
        $user = "username;
        $pw = "password";
        $db = "data";
        #Connect to Server
        $con = new Mysqli($servername, $user, $pw, $db) or die(Mysqli_errno());

        $value =htmlspecialchars(stripslashes(trim($_POST["value"])));

        $sql = $con->prepare("INSERT INTO tableName (value) VALUES ('$value')");
        $result = $sql->execute();
        if ($result) {
            echo "Success";
        }
        else {
            echo "Failed";
        }
        $con->close();
    } 
    else {
       echo "Not found";
    } 
?>

还需要在http.post上编写发出请求的颤动部分

void post() async {
    var result = await http.post(
        "http://{your url}/index.php",
         body: {
           "value": "Test DB Connection"
         }
    );
    print(result.body);
}
相关问题