mysql - 如何连接flutter到localhost mysql数据库

标签 mysql dart flutter

我想将本地主机 mysql 数据库连接到 flutter,但我没有这样做。我用这些连接尝试了 mysql1:

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

我尝试用“localhost”替换主机,但没有成功。有什么帮助吗?我没有使用模拟器。

最佳答案

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

现在,如果出于任何原因您仍然想直接连接到 MySQL,请记住,在这种情况下,任何客户端应用程序都可以使用写入权限访问您的数据库(这在所有!)仅作为测试示例,您可以尝试创建一个 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上发出请求的flutter部分

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

关于mysql - 如何连接flutter到localhost mysql数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56118535/

相关文章:

Python - 重新格式化从 MySQL 返回的元组列表

php - 快速插入会导致数据丢失

javascript - 如何使实时源列表仅在事件选项卡上更新或在选项卡再次变为事件状态时更新?

dart - 在Flutter中按下“设备后退”按钮时,如何转到上一个选项卡?

dart - 使用Flutter导航和路线时如何保持BottomNavigationBar

python - 查询中的 PyMySQL 变量

flutter - Flutter Auth(BLoC模式和rxDart)?

flutter - 如何在 Flutter 中更改 CupertinoSlidingSegmentedControl 的宽度

npm - 如何在 dart 代码中使用 npm 包?

dictionary - 有没有办法在map/forEach中标识当前索引