דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. בקשת cURL לnginx שעובדת מהקונסול אבל לא מתוך PHP

בקשת cURL לnginx שעובדת מהקונסול אבל לא מתוך PHP

מתוזמן נעוץ נעול הועבר תכנות
20 פוסטים 4 כותבים 769 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • yossizY מנותק
    yossizY מנותק
    yossiz
    כתב ב נערך לאחרונה על ידי yossiz
    #6

    @chagold מי אחראי על ה-index.php שרץ בפורט 200? האם תוכל לודא שה-PHP מקבל את הבקשה?
    האם תוכל להדפיס את הבקשה ש-index.php מקבל ולבדוק אם יש הבדלים בין הבקשה מ-PHP לבקשה מפקודת curl או מכרום?

    📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

    תגובה 1 תגובה אחרונה
    1
    • chagoldC מנותק
      chagoldC מנותק
      chagold
      כתב ב נערך לאחרונה על ידי chagold
      #7

      לכאו' הוא לא מקבל את הבקשה בכלל. (הדפסתי ללוג ובבקשה הרלוונטית הוא לא מדפיס, ובבקשות האחרות כן).

      תגובה 1 תגובה אחרונה
      0
      • yossizY מנותק
        yossizY מנותק
        yossiz
        כתב ב נערך לאחרונה על ידי yossiz
        #8

        יש לך לוג של php-fpm?
        ההדפסה ללוג הוא מיד בהתחלה של התוכנה?

        📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

        תגובה 1 תגובה אחרונה
        1
        • chagoldC מנותק
          chagoldC מנותק
          chagold
          כתב ב נערך לאחרונה על ידי chagold
          #9

          רק עכשיו הצלחתי להבין מה הסיבה לכל שורה בלוגים של הnginx.

          כשאני פונה מהURL (=בגוגל כרום, מה שחוזר תקין) יוצא מה שכתוב בשורה 1 ו-2. (לא יודע למה הוא מדפיס 2 שורות כאילו זה 2 בקשות).
          שורה 4 זה הבקשה בצורה ש@dovid אמר לי לעשות באמצעות file_get_contents, ושורה 5 זה הבקשה באמצעות curl.
          לא יודע למה בשורה 1,4,5 הוא לא כותב את כל הדומיין אלא מתחיל מה-index.php.

          127.0.0.1 - - [24/Dec/2024:23:36:44 +0200] "GET /index.php?format=json&p=chack_token_to_sp&Module=sub_projects&token_sub_project=kjsadouewio&token_user=AIAvo7yAhWqMrQJl271P&nick=administrator HTTP/1.1" 200 104 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36" "-"
          127.0.0.1 - - [24/Dec/2024:23:36:45 +0200] "GET /favicon.ico HTTP/1.1" 200 38672 "http://g-in.com:200/index.php?format=json&p=chack_token_to_sp&Module=sub_projects&token_sub_project=kjsadouewio&token_user=AIAvo7yAhWqMrQJl271P&nick=administrator" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36" "-"
          
          127.0.0.1 - - [24/Dec/2024:23:37:56 +0200] "GET /index.php?format=json&p=chack_token_to_sp&Module=sub_projects&token_sub_project=kjsadouewio&token_user=AIAvo7yAhWqMrQJl271P&nick=administrator HTTP/1.1" 499 0 "-" "-" "-"
          127.0.0.1 - - [24/Dec/2024:23:38:06 +0200] "GET /index.php?format=json&p=chack_token_to_sp&Module=sub_projects&token_sub_project=kjsadouewio&token_user=AIAvo7yAhWqMrQJl271P&nick=administrator HTTP/1.1" 499 0 "-" "PHP/cURL" "-"
          

          @yossiz איפה אני מוצא את הלוגים של php-fpm? בתיקיית PHP אין לי בכלל תיקיית משנה של logs.

          yossizY תגובה 1 תגובה אחרונה
          0
          • yossizY מנותק
            yossizY מנותק
            yossiz
            השיב לchagold ב נערך לאחרונה על ידי yossiz
            #10

            @chagold כתב בבקשת cURL לnginx שעובדת מהקונסול אבל לא מתוך PHP:

            כשאני פונה מהURL (=בגוגל כרום, מה שחוזר תקין) יוצא מה שכתוב בשורה 1 ו-2. (לא יודע למה הוא מדפיס 2 שורות כאילו זה 2 בקשות).

            זה באמת שתי בקשות
            שורה 1 זה העיקר, שורה 2 הוא סתם כי כרום מנסה לבקש favicon להציג אייקון של האתר

            @chagold כתב בבקשת cURL לnginx שעובדת מהקונסול אבל לא מתוך PHP:

            לא יודע למה בשורה 1,4,5 הוא לא כותב את כל הדומיין אלא מתחיל מה-index.php.

            גם ב-2 זה מתחיל ככה. תמיד בקשת HTTP הוא ככה (הדומיין נמצא ב-header בשם host). השדה השני שכולל כל הדומיין הוא ה-referrer (ככה זה מוגדר בברירת מחדל. אפשר לשנות את הפורמט של הלוג בהגדרות)

            @chagold כתב בבקשת cURL לnginx שעובדת מהקונסול אבל לא מתוך PHP:

            איפה אני מוצא את הלוגים של php-fpm? בתיקיית PHP אין לי בכלל תיקיית משנה של logs.

            אני לא יודע אצלך אם זה מוגדר עם php-fpm או עם משהו אחר, אני גם לא יודע איפה אתה יכול לחפש לוגים

            📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

            תגובה 1 תגובה אחרונה
            1
            • chagoldC מנותק
              chagoldC מנותק
              chagold
              כתב ב נערך לאחרונה על ידי
              #11

              זה מוגדר עם php-fpm.

              image.png

              אבל הוא לא כותב ללוגים שלו כלום.
              לא בבקשה מהURL ולא מהPHP.

              תגובה 1 תגובה אחרונה
              0
              • chagoldC מנותק
                chagoldC מנותק
                chagold
                כתב ב נערך לאחרונה על ידי chagold
                #12

                רק עכשיו הצלחתי לגרום לו לכתוב את הלוגים של php-fpm.
                תכלס, הלוג מדפיס רק את הבקשה של @dovid את שלי הוא לא מדפיס.
                אבל במה שהוא מדפיס נוסף טקסט 'amp;' כמה פעמים.

                [26-Dec-2024 07:52:20 UTC] PHP Warning:  file_get_contents(http://g-in.com:200/index.php?format=json&p=chack_token_to_sp&Module=sub_projects&token_sub_project=kjsadouewio&token_user=AIAvo7yAhWqMrQJl271P&nick=administrator): Failed to open stream: HTTP request failed! in C:\xampp\file.php on line 339
                [26-Dec-2024 07:52:20 UTC] API call failed: Failed to get contents
                
                
                yossizY תגובה 1 תגובה אחרונה
                0
                • chagoldC מנותק
                  chagoldC מנותק
                  chagold
                  כתב ב נערך לאחרונה על ידי chagold
                  #13

                  אבל לא התוים הנוספים הם הסיבה. כי עשיתי טסט בלי פרמטרים בכלל. ועדיין..

                  [26-Dec-2024 08:08:38 UTC] PHP Warning:  file_get_contents(http://g-in.com:200/index.php): Failed to open stream: HTTP request failed! in C:\xampp\file.php on line 340
                  [26-Dec-2024 08:08:38 UTC] API call failed: Failed to get contents
                  
                  תגובה 1 תגובה אחרונה
                  0
                  • yossizY מנותק
                    yossizY מנותק
                    yossiz
                    השיב לchagold ב נערך לאחרונה על ידי
                    #14

                    @chagold כתב בבקשת cURL לnginx שעובדת מהקונסול אבל לא מתוך PHP:

                    אבל לא התוים הנוספים הם הסיבה. כי עשיתי טסט בלי פרמטרים בכלל. ועדיין..

                    [26-Dec-2024 08:08:38 UTC] PHP Warning:  file_get_contents(http://g-in.com:200/index.php): Failed to open stream: HTTP request failed! in C:\xampp\file.php on line 340
                    [26-Dec-2024 08:08:38 UTC] API call failed: Failed to get contents
                    

                    יש לך שני אתרי PHP אם הבנתי נכון, ואתה מנסה לעשות קריאה מאחד לשני
                    הלוג פה מראה רק את הקריאה של file_get_contents
                    האם אתה בטוח שהאתר השני (g-in.com:200) גם עובר דרך php-fpm?

                    אם לא, אז מה כן?
                    אתה יכול להראות את הקונפיגרציה של השרת אפאצ'י או nginx?

                    📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                    תגובה 1 תגובה אחרונה
                    0
                    • chagoldC מנותק
                      chagoldC מנותק
                      chagold
                      כתב ב נערך לאחרונה על ידי chagold
                      #15

                      זה לוג רק של שגיאות.
                      הוא נוצר באמצעות הקוד הזה -

                      c:\tools\nssm.exe set PHP-FPM AppParameters "-b 127.0.0.1:9000 -d error_log=C:/php/logs/php-fpm.log -d display_errors=1 -d log_errors=1 -d error_reporting=E_ALL"
                      

                      לא הצלחתי לעשות לוג של כל הבקשות

                      # nginx.conf - Combined Configuration
                      
                      worker_processes  1024;
                      
                      error_log  "C:/nginx/logs/error.log";
                      #error_log  logs/error.log  notice;
                      #error_log  logs/error.log  info;
                      
                      events {
                          worker_connections  1024;
                      }
                      
                      http {
                          include       "C:/nginx/conf/mime.types";
                          
                      
                          default_type  application/octet-stream;
                          charset utf-8;
                          log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                                           '$status $body_bytes_sent "$http_referer" '
                                           '"$http_user_agent" "$http_x_forwarded_for"';
                      
                          log_format  debug  '$remote_addr - $remote_user [$time_local] "$request" '
                                         '$status $body_bytes_sent "$http_referer" '
                                         '"$http_user_agent" "$http_x_forwarded_for" '
                                         'rt=$request_time ua="$upstream_addr" '
                                         'us="$upstream_status" ut="$upstream_response_time" '
                                         'ul="$upstream_response_length" '
                                         'cs=$upstream_cache_status';
                      
                      access_log  logs/access.log  debug;
                      
                          access_log  "C:/nginx/logs/access.log"  main;
                      
                          sendfile        on;
                          keepalive_timeout  65;
                      
                          # FastCGI Settings
                          fastcgi_buffers 8 16k;
                          fastcgi_buffer_size 32k;
                          fastcgi_connect_timeout 300;
                          fastcgi_send_timeout 300;
                          fastcgi_read_timeout 300;
                      
                          # Default server (port 80)
                          server {
                              charset utf-8;
                              listen 80;
                              server_name localhost;
                              root C:/xampp/reko;
                              
                              location / {
                                  index index.php index.html index.htm;
                                  try_files $uri $uri/ /index.php?$args;
                                  autoindex on;
                              }
                      
                              error_page   500 502 503 504  /50x.html;
                              location = /50x.html {
                                  root   html;
                              }
                      
                              location ~ \.php$ {
                                  fastcgi_pass 127.0.0.1:9000;
                                  fastcgi_index index.php;
                                  fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                                  include fastcgi_params;
                              }
                          }
                      
                          # Port 200 server (reko)
                          server {
                              listen 200;
                              server_name localhost;
                              root C:/xampp/reko;
                              
                              location / {
                                  index index.php index.html index.htm;
                                  try_files $uri $uri/ /index.php?$args;
                                  autoindex on;
                                  proxy_connect_timeout 10;
                                  proxy_send_timeout 10;
                                  proxy_read_timeout 10;
                              }
                      
                              error_page   500 502 503 504  /50x.html;
                              location = /50x.html {
                                  root   html;
                              }
                      
                              location ~ \.php$ {
                                  fastcgi_pass 127.0.0.1:9000;
                                  fastcgi_index index.php;
                                  fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                                  include fastcgi_params;
                              }
                          }
                      
                      
                      }
                      

                      והקונפיגורציה של php-fpm

                      [global]
                      pid = C:/nginx/php-fpm.pid
                      error_log = C:/php/logs/php-fpm.log
                      
                      [www]
                      listen = 127.0.0.1:9000
                      listen.allowed_clients = 127.0.0.1
                      user = nobody
                      pm = dynamic
                      pm.max_children = 5
                      pm.start_servers = 2
                      pm.min_spare_servers = 1
                      pm.max_spare_servers = 3
                      access.log = C:/php/logs/php-fpm-access.log
                      catch_workers_output = yes
                      
                      תגובה 1 תגובה אחרונה
                      1
                      • chagoldC מנותק
                        chagoldC מנותק
                        chagold
                        כתב ב נערך לאחרונה על ידי
                        #16

                        התקרבתי לפתרון. לא יודע איך לחצות את הגשר.
                        ניסיתי לבדוק אם הPHP יריץ את הפקודה cmd זה כן יעבוד. והתברר שהבקשה עצמה תקינה, (והיא גם מדפיסה את התגובה לקובץ c:\url_response.txt), היא רק לא מחזירה את הפלט לתוכנת הPHP שביקשה אותה.
                        זה הפקודה

                            function createFullSystem() {
                                $urlFile = 'C:\\url_command.txt';
                                $batchFile = 'C:\\url_runner.bat';
                                $outputFile = 'C:\\url_response.txt';
                                
                                $url = "http://g-in.com:200/index.php?" . http_build_query([
                                    'format' => 'json',
                                    'p' => 'chack_token_to_sp',
                                    'Module' => 'sub_projects',
                                    'token_sub_project' => 'kjsadouewio',
                                    'token_user' => 'AIAvo7yAhWqMrQJl271P',
                                    'nick' => 'administrator'
                                ]);
                                
                                file_put_contents($urlFile, $url);
                                
                                $batchContent = "@echo off\n";
                                $batchContent .= "cd C:\\tools\n";
                                $batchContent .= "set /p URL=<" . $urlFile . "\n";
                                // בדיוק אותה פקודה שעובדת ב-CMD
                                $batchContent .= "C:\\Windows\\System32\\curl.exe -v -H \"User-Agent: PHP/cURL\" --connect-timeout 10 -m 10 \"%URL%\" > " . $outputFile . " 2>&1\n";
                                $batchContent .= "exit\n";
                                
                                file_put_contents($batchFile, $batchContent);
                                
                                $descriptorspec = array(
                                    0 => array("pipe", "r"),
                                    1 => array("pipe", "w"),
                                    2 => array("pipe", "w")
                                );
                                
                                $process = proc_open("cmd /c " . $batchFile, $descriptorspec, $pipes);
                                
                                if (is_resource($process)) {
                                    stream_set_blocking($pipes[1], 0);
                                    stream_set_blocking($pipes[2], 0);
                                    
                                    $start = time();
                                    $timeout = 1;
                                    
                                    do {
                                        $status = proc_get_status($process);
                                        if (!$status['running']) {
                                            break;
                                        }
                                        if (time() - $start > $timeout) {
                                            proc_terminate($process);
                                            echo "Process terminated due to timeout\n";
                                            break;
                                        }
                                        sleep(1);
                                    } while (true);
                                    
                                    fclose($pipes[0]);
                                    fclose($pipes[1]);
                                    fclose($pipes[2]);
                                    proc_close($process);
                                }
                                
                                if(file_exists($outputFile)) {
                                    echo "Response from server:\n";
                                    echo file_get_contents($outputFile);
                                }
                            }
                        
                        yossizY תגובה 1 תגובה אחרונה
                        1
                        • yossizY מנותק
                          yossizY מנותק
                          yossiz
                          השיב לchagold ב נערך לאחרונה על ידי yossiz
                          #17

                          @chagold כתב בבקשת cURL לnginx שעובדת מהקונסול אבל לא מתוך PHP:

                          התקרבתי לפתרון

                          אני לא יודע כמה זה מקדם אותנו, כי מה שהסקריפט עושה הוא בדיוק כמו להריץ פקודת curl ידנית. וזה ידענו כבר שעובד.

                          יש משהו מוזר פה

                          נסה לעבוד עם file_get_contents ולבדוק אם זה עובד בשום צורה

                          📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                          תגובה 1 תגובה אחרונה
                          0
                          • yossizY מנותק
                            yossizY מנותק
                            yossiz
                            כתב ב נערך לאחרונה על ידי yossiz
                            #18

                            נראה לי שמצאתי את התשובה!!

                            https://stackoverflow.com/a/13814609/8997905

                            (אני רק לא מבין אם ככה למה זה כן עובד 🤔 )

                            אם זו באמת הבעיה, תחפש מדריך רשמי של PHP איך להקים שרת בסביבת ווינדוס בצורה נכונה והבעיה אמורה להיפתר
                            למשל זה: https://www.php.net/manual/en/install.windows.apache2.php
                            (ותוודא שיש לך גירסאות מעודכנות של הכלים)

                            מישהו כתב פה פתרון לnginx על ווינדוס

                            📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                            תגובה 1 תגובה אחרונה
                            2
                            • chagoldC מנותק
                              chagoldC מנותק
                              chagold
                              כתב ב נערך לאחרונה על ידי chagold
                              #19

                              @yossiz תודה רבה!
                              זנ כנראה לא הבעיה. (והא ראיה שעבד לי הגישה לcmd).
                              אבל לו הייתי יודע על הפוסט בסטאק הייתי מראש מוותר על nginx בלוקאלי. (או מתקין לינוקס בלוקלי?😕 ).
                              עכ"פ חזרתי עכשיו לאפאצי שהיה לי, ונראה אם אני יסתדר בהמשך.

                              תגובה 1 תגובה אחרונה
                              1
                              • Aharon 0A מנותק
                                Aharon 0A מנותק
                                Aharon 0
                                כתב ב נערך לאחרונה על ידי
                                #20

                                תתחיל מזה שתשנה את הפורט מ 200 למעל 1024, וחוץ מזה תבדוק שאתה לא נופל על פורט שמור:
                                https://www.geeksforgeeks.org/50-common-ports-you-should-know/

                                תגובה 1 תגובה אחרונה
                                -1

                                בא תתחבר לדף היומי!
                                • התחברות

                                • אין לך חשבון עדיין? הרשמה

                                • התחברו או הירשמו כדי לחפש.
                                • פוסט ראשון
                                  פוסט אחרון
                                0
                                • דף הבית
                                • קטגוריות
                                • פוסטים אחרונים
                                • משתמשים
                                • חיפוש
                                • חוקי הפורום