python - php가 쉘 명령을 호출합니다: exec('java -jar a.jar')가 실행되지 않습니다.
PHP의 exec
함수를 사용하여 shell
을 실행합니다. 많은 명령을 실행할 수 있지만 자바 프로그램을 실행하는 데 문제가 있습니다.
[testshell.php]는 다음과 같습니다.
<code><?php $str="java -jar a.jar"; exec($str,$output,$retnruVal); print_r($output); ?></code>
java 파일도 매우 간단합니다. helloworld를 출력해서 파일에 쓰는 테스트 파일입니다.
그리고 php
를 이용하여 이 파일을 다음과 같이 직접 실행해 보았는데 문제없이 성공합니다.
<code>$ php testshell.php</code>
그런데 이 php 파일을 브라우저에서 실행해도 아무런 반응이 없습니다.
처음에는 쓰기 권한 문제인 줄 알았으나 또 다른 python
테스트를 작성했습니다.
<code>file("output.txt").write("测试\n")</code>
그런 다음 testshell.php는 다음과 같이 변경됩니다.
<code>$str="python a.py"; exec($str,$output,$retnruVal); print_r($output);</code>
이것도 성공했는데 어디가 문제인지 모르겠습니다. 조언 부탁드립니다.
첨부된 프로그램은 a.java입니다:
<code>import java.io.File; import java.io.InputStreamReader; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileInputStream; import java.io.FileWriter; public class a{ public static void main (String[] args) { try{ File writename = new File("output.txt"); // 相对路径,如果没有则要建立一个新的output。txt文件 writename.createNewFile(); // 创建新文件 BufferedWriter out = new BufferedWriter(new FileWriter(writename)); out.write("我会写入文件啦\r\n"); // \r\n即为换行 out.flush(); // 把缓存区内容压入文件 out.close(); // 最后记得关闭文件 }catch(Exception e){ e.printStackTrace(); } } }</code>
은 a.java
을 변경하고 출력을 추가했는데, 이는 System.out.println
을 실행할 수는 있지만 후속 코드를 실행할 수 없다는 뜻입니다. 권한 문제는 아닌 것 같습니다.
<code>public static void main (String[] args) { try{ String a = "hello"; System.out.println(a); File writename = new File("output.txt"); // 相对路径,如果没有则要建立一个新的output。txt文件 writename.createNewFile(); // 创建新文件 BufferedWriter out = new BufferedWriter(new FileWriter(writename)); out.write("我会写入文件啦\r\n"); // \r\n即为换行 out.flush(); // 把缓存区内容压入文件 out.close(); // 最后记得关闭文件 }catch(Exception e){ e.printStackTrace(); } }</code>
답글 내용:
PHP의 exec
함수를 사용하여 shell
을 실행합니다. 많은 명령을 실행할 수 있지만 자바 프로그램을 실행하는 데 문제가 있습니다.
[testshell.php]는 다음과 같습니다.
<code><?php $str="java -jar a.jar"; exec($str,$output,$retnruVal); print_r($output); ?></code>
java 파일도 매우 간단합니다. helloworld를 출력해서 파일에 쓰는 테스트 파일입니다.
그리고 php
를 이용하여 이 파일을 다음과 같이 직접 실행해 보았는데 문제없이 성공합니다.
<code>$ php testshell.php</code>
그런데 이 php 파일을 브라우저에서 실행해도 아무런 반응이 없습니다.
처음에는 쓰기 권한 문제인 줄 알았으나 또 다른 python
테스트를 작성했습니다.
<code>file("output.txt").write("测试\n")</code>
그런 다음 testshell.php는 다음과 같이 변경됩니다.
<code>$str="python a.py"; exec($str,$output,$retnruVal); print_r($output);</code>
이것도 성공했는데 어디가 문제인지 모르겠습니다. 조언 부탁드립니다.
첨부된 프로그램은 a.java입니다:
<code>import java.io.File; import java.io.InputStreamReader; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileInputStream; import java.io.FileWriter; public class a{ public static void main (String[] args) { try{ File writename = new File("output.txt"); // 相对路径,如果没有则要建立一个新的output。txt文件 writename.createNewFile(); // 创建新文件 BufferedWriter out = new BufferedWriter(new FileWriter(writename)); out.write("我会写入文件啦\r\n"); // \r\n即为换行 out.flush(); // 把缓存区内容压入文件 out.close(); // 最后记得关闭文件 }catch(Exception e){ e.printStackTrace(); } } }</code>
은 a.java
을 변경하고 출력을 추가했는데, 이는 System.out.println
을 실행할 수는 있지만 후속 코드를 실행할 수 없다는 뜻입니다. 권한 문제는 아닌 것 같습니다.
<code>public static void main (String[] args) { try{ String a = "hello"; System.out.println(a); File writename = new File("output.txt"); // 相对路径,如果没有则要建立一个新的output。txt文件 writename.createNewFile(); // 创建新文件 BufferedWriter out = new BufferedWriter(new FileWriter(writename)); out.write("我会写入文件啦\r\n"); // \r\n即为换行 out.flush(); // 把缓存区内容压入文件 out.close(); // 最后记得关闭文件 }catch(Exception e){ e.printStackTrace(); } }</code>
구체적인 반환 정보가 있는지는 모르겠지만, 제 추측으로는 파일 경로와 관련이 있는 것 같습니다.
Java의 환경변수가 맞나요? Java 전체 경로로 실행해 보세요.
권한 문제가 해결되었습니다. www-data는 파일 쓰기 권한이 없는 기본 사용자입니다. . . 속았다

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











MySQL에는 무료 커뮤니티 버전과 유료 엔터프라이즈 버전이 있습니다. 커뮤니티 버전은 무료로 사용 및 수정할 수 있지만 지원은 제한되어 있으며 안정성이 낮은 응용 프로그램에 적합하며 기술 기능이 강합니다. Enterprise Edition은 안정적이고 신뢰할 수있는 고성능 데이터베이스가 필요하고 지원 비용을 기꺼이 지불하는 응용 프로그램에 대한 포괄적 인 상업적 지원을 제공합니다. 버전을 선택할 때 고려 된 요소에는 응용 프로그램 중요도, 예산 책정 및 기술 기술이 포함됩니다. 완벽한 옵션은없고 가장 적합한 옵션 만 있으므로 특정 상황에 따라 신중하게 선택해야합니다.

MySQL은 기본 데이터 저장 및 관리를위한 네트워크 연결없이 실행할 수 있습니다. 그러나 다른 시스템과의 상호 작용, 원격 액세스 또는 복제 및 클러스터링과 같은 고급 기능을 사용하려면 네트워크 연결이 필요합니다. 또한 보안 측정 (예 : 방화벽), 성능 최적화 (올바른 네트워크 연결 선택) 및 데이터 백업은 인터넷에 연결하는 데 중요합니다.

MySQL 데이터베이스 성능 최적화 안내서 리소스 집약적 응용 프로그램에서 MySQL 데이터베이스는 중요한 역할을 수행하며 대규모 트랜잭션 관리를 담당합니다. 그러나 응용 프로그램 규모가 확장됨에 따라 데이터베이스 성능 병목 현상은 종종 제약이됩니다. 이 기사는 일련의 효과적인 MySQL 성능 최적화 전략을 탐색하여 응용 프로그램이 고 부하에서 효율적이고 반응이 유지되도록합니다. 실제 사례를 결합하여 인덱싱, 쿼리 최적화, 데이터베이스 설계 및 캐싱과 같은 심층적 인 주요 기술을 설명합니다. 1. 데이터베이스 아키텍처 설계 및 최적화 된 데이터베이스 아키텍처는 MySQL 성능 최적화의 초석입니다. 몇 가지 핵심 원칙은 다음과 같습니다. 올바른 데이터 유형을 선택하고 요구 사항을 충족하는 가장 작은 데이터 유형을 선택하면 저장 공간을 절약 할 수있을뿐만 아니라 데이터 처리 속도를 향상시킬 수 있습니다.

해시 값으로 저장되기 때문에 MongoDB 비밀번호를 Navicat을 통해 직접 보는 것은 불가능합니다. 분실 된 비밀번호 검색 방법 : 1. 비밀번호 재설정; 2. 구성 파일 확인 (해시 값이 포함될 수 있음); 3. 코드를 점검하십시오 (암호 하드 코드 메일).

생산 환경의 경우 성능, 신뢰성, 보안 및 확장 성을 포함한 이유로 서버는 일반적으로 MySQL을 실행해야합니다. 서버에는 일반적으로보다 강력한 하드웨어, 중복 구성 및 엄격한 보안 조치가 있습니다. 소규모 저하 애플리케이션의 경우 MySQL이 로컬 컴퓨터에서 실행할 수 있지만 자원 소비, 보안 위험 및 유지 보수 비용은 신중하게 고려되어야합니다. 신뢰성과 보안을 높이려면 MySQL을 클라우드 또는 기타 서버에 배포해야합니다. 적절한 서버 구성을 선택하려면 응용 프로그램 부하 및 데이터 볼륨을 기반으로 평가가 필요합니다.

HADIDB : 가볍고 높은 수준의 확장 가능한 Python 데이터베이스 HadIDB (HADIDB)는 파이썬으로 작성된 경량 데이터베이스이며 확장 수준이 높습니다. PIP 설치를 사용하여 HADIDB 설치 : PIPINSTALLHADIDB 사용자 관리 사용자 만들기 사용자 : createUser () 메소드를 작성하여 새 사용자를 만듭니다. Authentication () 메소드는 사용자의 신원을 인증합니다. Fromhadidb.operationimportuseruser_obj = user ( "admin", "admin") user_obj.

MySQL 데이터베이스에 이미지를 저장하는 것은 가능하지만 모범 사례는 아닙니다. MySQL은 이미지를 저장할 때 Blob 유형을 사용하지만 데이터베이스 볼륨 부기, 쿼리 속도 및 복잡한 백업을 유발할 수 있습니다. 더 나은 솔루션은 파일 시스템에 이미지를 저장하고 데이터베이스에 이미지 경로 만 저장하여 쿼리 성능 및 데이터베이스 볼륨을 최적화하는 것입니다.

아니요, MySQL은 SQL Server에 직접 연결할 수 없습니다. 그러나 다음 방법을 사용하여 데이터 상호 작용을 구현할 수 있습니다. 미들웨어 사용 : MySQL에서 중간 형식으로 데이터를 내보낸 다음 미들웨어를 통해 SQL Server로 가져옵니다. 데이터베이스 링커 사용 : 비즈니스 도구는 본질적으로 미들웨어를 통해 여전히 구현되는보다 우호적 인 인터페이스와 고급 기능을 제공합니다.
