0

データベースを照会/変更できるように、Java プログラム内からいくつかの PHP スクリプトを呼び出そうとしています。私はデータベースにまったく慣れていないので、何が起こっているのかわかりません。

Java内から次のスクリプトを呼び出そうとしています。

脚本

<?php
include('test.php');

define("HOST", "localhost");

define("USERNAME", "xxxx");

define("PASSWORD", "xxxx");

define("DATABASE", "project_database");

mysql_connect(HOST, USERNAME, PASSWORD);

mysql_select_db(DATABASE);

?>

Java コード

 public static String excutePost(String targetURL, String urlParameters)
    {
      URL url;
      HttpURLConnection connection = null;  
      try {
        //Create connection
        url = new URL(targetURL);
        connection = (HttpURLConnection)url.openConnection();
        connection.setRequestMethod("POST");
        connection.setRequestProperty("Content-Type", 
             "application/x-www-form-urlencoded");

        connection.setRequestProperty("Content-Length", "" + 
                 Integer.toString(urlParameters.getBytes().length));
        connection.setRequestProperty("Content-Language", "en-US");  

        connection.setUseCaches (false);
        connection.setDoInput(true);
        connection.setDoOutput(true);

        //Send request
        DataOutputStream wr = new DataOutputStream (
                    connection.getOutputStream ());
        wr.writeBytes (urlParameters);
        wr.flush ();
        wr.close ();

        //Get Response  
        InputStream is = connection.getInputStream();
        BufferedReader rd = new BufferedReader(new InputStreamReader(is));
        String line;
        StringBuffer response = new StringBuffer(); 
        while((line = rd.readLine()) != null) {
          response.append(line);
          response.append('\r');
        }
        rd.close();
        return response.toString();

      } catch (Exception e) {

        e.printStackTrace();
        return null;

      } finally {

        if(connection != null) {
          connection.disconnect(); 
        }
      }
    }

ターゲット URL は??

4

2 に答える 2

3

新しいプロセスを呼び出す場合は、java.lang.Processを参照してください。

ただし、JavaはJDBCを介してデータベースと直接通信することができ、それが私が強くお勧めするアプローチです。新しいプロセスを作成したり、複数の言語でソリューションを実装したりする必要はありません。また、多数のJDBC関連のフレームワークを利用して人生をやり直すことができます。データベースへのアクセスがかなり簡単になります。

于 2013-02-07T17:36:33.533 に答える
0

ページのリンクを指定する必要があります。「/localhost/yourPageInPhp.php」のようになります。

スクリプトを実行して、Java内でその出力を表示する必要があると思います

于 2013-02-07T17:38:43.313 に答える