2017-02-12 71 views
-2

我想動態顯示用戶列表,但它不起作用。我自己測試了查詢,它工作得很好,但它仍然沒有顯示任何東西。這是腳本AJAX與Symfony3

<script> 
    function showUser() { 
       // code for IE7+, Firefox, Chrome, Opera, Safari 
       xmlhttp = new XMLHttpRequest(); 

      xmlhttp.onreadystatechange = function() { 
       if (this.readyState == 4 && this.status == 200) { 
        document.getElementById("user-list-div").innerHTML = xmlhttp.responseText; 
       } 
      }; 
      xmlhttp.open("GET","{{ path('ajax_update')}}",true); 
      xmlhttp.send(); 
     } 
</script> 

這是控制器的動作:

public function searchUsersAction(Request $request) 
{ 
    /*$em = $this->getDoctrine()->getManager(); 
    $request = $this->get('request');*/ 
    $projectName = $request->get('projectName'); 
    echo($projectName); 
    //$projectId=$this->getDoctrine()->getRepository('SocialProMeetingBundle:meetingUser')->findName($projectName); 
    //echo(count($projectId)); 
    //foreach($projectId as $pId) { 
     //$projectId->getPId(); 
     $pus = $this->getDoctrine()->getRepository('SocialProMeetingBundle:meetingUser')->findProjectUsers($projectName); 
    //} 
    $response = "<select class=\"select2_multiple form-control\" multiple=\"multiple\">"; 
    foreach($pus as $user){ 
     $response . "<option>" . $user . "</option>"; 
    } 
    $response = $response."</select> "; 
    return new Response($response); 
    //return($pus); 
    //call repository function 
} 

,這是查詢

public function findProjectUsers($projectName){ 
    $query=$this->getEntityManager() 
     ->createQuery(
      "SELECT u.firstName FROM SocialProDefaultBundle:User u, SocialProProjectBundle:Project p, SocialProProjectBundle:ProjectUser pu WHERE u.id = pu.user AND p.id=pu.project AND p.name='$projectName'"); 
    return $query->getResult(); 
} 
+0

請檢查您的Apache/Nginx/PHP日誌是否有錯誤。 –

+0

我不知道你在說什麼。我正在使用phpMyAdmin在wamp服務器上。我測試了查詢並返回了正確的結果@michail_w –

回答

0

您的查詢不正確。你需要像這樣連接$ projectName:

public function findProjectUsers($projectName){ 
    $query=$this->getEntityManager() 
     ->createQuery(
      "SELECT u.firstName 
       FROM SocialProDefaultBundle:User u, 
       SocialProProjectBundle:Project p, 
       SocialProProjectBundle:ProjectUser pu 
       WHERE u.id = pu.user AND p.id=pu.project AND p.name=:name" 
     )->setParameter('name', $projectName); 
    return $query->getResult(); 
} 

我不確定這是否能解決所有問題,但至少會使查詢正常工作。

+0

保持SQL注入是一個不錯的主意。 –

+0

@AlainTiemblo是什麼意思?你能添加更多細節嗎? –

+0

當然。 'AND p.name ='「。$ projectName。''」'。如果我注入''OR 1 --' –

0

我不是很清楚你的問題,但是看樓上的朋友說你的查詢有問題,所以我在想,你可以把控制器,查詢做斷點調試。然後錯誤精確鎖定位置。我解決問題的思路是如此普遍。