извлекать данные из таблицы, используя REST API - PullRequest
0 голосов
/ 21 октября 2011

Я разрабатываю REST API с использованием Slim Framework.Я использую базу данных mySql.и я проектирую этот API в php.

Я пытаюсь получить данные о студенте из моей таблицы.

Я пытаюсь так: -

<?php
header('Content-type: application/json');
// Include the Slim library
require 'Slim/Slim.php';
// Instantiate the Slim class
$app = new Slim();
// Create a GET-based route
$app->get('/hello/:name', 'hello');

  function hello($name)
  {
     // here is code to access detail of $name 
     echo $name
     // how can i get detail if i have value of name=:kuntal  not name=kuntal
  }

  // Ready the routes and run the application
   $app->run();
 ?>

Iя пытаюсь эту функцию, используя этот URL: - 192.168.1.101/hello/:kuntal

мне нужно получить значение имени как kuntal , но в функции я получаю значение имени как : kuntal поэтому, пожалуйста, скажите мне, как я могу удалить это: (двоеточие) перед именем.

Другой способ сделать это.

Пожалуйста, дайте мне ваше предложение, если вызнать о тонких рамках, чтобы сделать REST API.Заранее спасибо.

Ответы [ 3 ]

0 голосов
/ 31 января 2012

Slim - это действительно отличная структура. До того, как я начал его использовать, у меня не было опыта работы с фреймворками, REST, пониманием HTTP ... Я все еще новичок, но Slim делает это забавным.

Ответ 1:

$app->get('/hello/:name', function($name) use ($app) {
    // Your mySQL code here
    // Process that information into output JSON?
    // echo json_encode($array);
});

Ответ 2:

Могу ли я добавить, что вы проверяете Идиорм / Париж для нужд вашей базы данных? В той же философии, что и Slim, меньше значит больше. Вот как может выглядеть код с Парижем.

class Friend extends Model {}

$app->get('/hello/:name', function($name) use ($app) {

    $friend = Model::factory('Friend')->find_many($name);  // Paris: all rows with name
    $friendAry = $friend->as_array('id', 'name');

    $response = $app->response();    // Slim Response object at work
    $response['Content-Type'] = 'application/json';

    echo json_encode($friendAry);    // Output
});

Хотя, вопрос (и, возможно, кто-то, кто знает больше о REST, может ответить). Это Ури действительно хороший? Из того, что я понимаю о REST, мы хотим указать людям на ресурсы. Я полагаю, существительные. Я не уверен, что Hello действительно будет означать в контексте REST. Почему бы не сделать ресурс пользователем или другом с идентификатором в качестве пули?

$app->get('/friend/:id', function($id) use ($app) {
    // Returns the friend with unique id
    $friend = Model::factory('Friend')->find_one($id);  // Name is already part of obj
    $friendAry = $friend->as_array('id', 'name');
    echo json_encode($friendAry);
}

Затем вы можете обработать эту информацию, упаковать ее с приветствием, что бы клиент ни ожидал. Вы можете передавать дополнительную информацию, такую ​​как имя, в параметры, например, так.

http://search.twitter.com/search?q=potato&count=10

Надеюсь, это поможет. Очень классные вещи. И кто-то дает мне обратную связь, чтобы сообщить мне, если мое мышление находится на правильной странице. Я тоже все еще учусь.

0 голосов
/ 15 апреля 2019
enter code here
    <?php
    error_reporting('E_NOTICE ^ E_ALL');
    include_once 'api_function.php';
    $con = new DB_con();
    function getCurrentURL()
    {
        $currentURL = (@$_SERVER["HTTPS"] == "on") ? "https://" : "http://";
        $currentURL .= $_SERVER["SERVER_NAME"];

        if($_SERVER["SERVER_PORT"] != "80" && $_SERVER["SERVER_PORT"] != "443")
        {
            $currentURL .= ":".$_SERVER["SERVER_PORT"];
        } 

            $currentURL .= $_SERVER["REQUEST_URI"];
        return $currentURL;
    }

    if($_POST['action']!="")
    {
    $action = $_POST['action'];

    }
    else
    {
    header("Content-type: application/json; charset=iso-8859-1");
    $inputdata = file_get_contents('php://input');
    $data = json_decode($inputdata, TRUE);
    $action = $data['action'];
    }
    /**********************select Detail API Starts here**********************/
    if($action == 'select')
    {
        $insert = $con->select("table_name",$data);

         $msg = array("result" => $insert);

             header('content-type: application/json');
             echo json_encode($msg,true);
    }
    /**********************delete Detail API Ends here************************/
   /*2nd file api_function.php*/
    error_reporting('E_NOTICE ^ E_ALL');
    define('DB_SERVER', 'localhost');
    define('DB_USER', 'username');
    define('DB_PASS', 'password');
    define('DB_NAME', 'db_name');
    class DB_con {
        protected $conn;
        function __construct() {
          $this->conn = mysqli_connec`enter code here`t(DB_SERVER, DB_USER, DB_PASS, DB_NAME) or die(mysqli_connection_error($this->conn));
            //mysql_select_db(DB_NAME, $conn);
        }
    /**********************select API Ends here**********************/
    public function select($ssTableName, $asFields) {
            if (strcmp($asFields['action'], "select") == 0) {


                if ($asFields['id'] != '') {
                $query_checklogin = mysqli_query($this->conn, "delete from  $ssTableName  where id='".$asFields['id']."'")or die(mysqli_error($this->conn));
               if ($query_checklogin != '') {
                     $msg = array('msg' => 'succesfully', 'statuscode' => '201');
                    return $msg;

                        }
                } else {
                    $deta = array();
                    $select = mysqli_query($this->conn, "SELECT * from $ssTableName ")or die(mysqli_error($this->conn)); 
                    while($row = mysqli_fetch_assoc($select)){
                        array_push($deta,$row);

                    }
                     $msg = array('msg' => 'Record does not exist', 'statuscode' => '202', 'detail'=>$deta);

                     return $msg;
                }
            } else {
                $msg = array('msg' => 'Something Error','statuscode' => '203');
                return $msg;
            }
        }
    /********************** API Ends here**********************/
    }
    ?>
0 голосов
/ 21 октября 2011

Попробуйте этот URL: 192.168.1.101/hello/kuntal Я думаю, что это определенно будет работать для вашего кода.

...