如何将flatter连接到localhost mysql数据库

如何将flatter连接到localhost mysql数据库,mysql,dart,flutter,Mysql,Dart,Flutter,我想将一个localhost mysql数据库连接到flatter,但我没有这样做。我使用以下连接尝试了mysql1: ConnectionSettings( host: '10.0.2.2', port: 3306, user: 'root', password: "root", db: 'company' 我试着用“localhost”替换主机,但没有成功。有什么帮助吗?我没有使用模拟器。直接连接MySQL(或

我想将一个localhost mysql数据库连接到flatter,但我没有这样做。我使用以下连接尝试了mysql1:

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

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

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

现在,如果出于任何原因,您仍然希望直接连接到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";
    } 
?>

你能解释一下“它不起作用”是什么意思吗?您是否有任何错误消息?是的,抱歉,以下是错误:未处理的异常:SocketException:OS错误:连接被拒绝,errno=111,address=localhost,port=51782请您帮助我了解我的URL?……我在哪里可以找到一些php模板代码?请查看这一个Hii,@nike,我可以用java而不是php来做同样的操作吗?@Bhupesh_decoder是的,您可以使用在您的系统中运行的任何语言server@HusseinAl-Mosawi直接连接到数据库,一旦任何客户端应用程序具有写访问权限,您将无法保护数据存储。如何实现API安全性将取决于传输的数据类型。最好的方法可能是托管一台服务器,该服务器提供对数据库的访问(例如:可以使用Express-Node.js),同时将API公开给flatter以发出请求。
void post() async {
    var result = await http.post(
        "http://{your url}/index.php",
         body: {
           "value": "Test DB Connection"
         }
    );
    print(result.body);
}