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

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

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

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

מתוזמן נעוץ נעול הועבר תכנות
20 פוסטים 4 כותבים 769 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • 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
                              • דף הבית
                              • קטגוריות
                              • פוסטים אחרונים
                              • משתמשים
                              • חיפוש
                              • חוקי הפורום