개인용 Ubuntu 컴퓨터의 로컬 호스트에 대한 포트 포워딩은 안전합니까?

릭 로즈

개인적으로 Ubuntu 컴퓨터에 Lamp를 설치 한 후 SMTP 메일을 보내기 위해 웹에 연결해야하는 응용 프로그램을 실행하고 있습니다. 예를 들어, 페이팔은 결제 성공 또는 실패를 알리기 위해 www 주소가 필요합니다 ...

무료 .tk 도메인을 확보하고, 라우터 기본 설정을 변경하고, 컴퓨터 IP로 포트 포워딩하여 문제를 해결했습니다.

안전한가요? 방화벽이있어서 포트 80에 대한 액세스 만 제한합니다. 개인 파일이있는 개인용 컴퓨터입니다 (내 / var / www 폴더 제외).

더 나은 대안이 있습니까?

VMware Workstation에 Ubuntu Server를 설치하고 대신 가상 서버로 포트 포워딩하려고 생각했지만 너무 많은 리소스가 필요할 수 있습니다.

user8290

"실제"웹 서버에 배포 된 것처럼 웹 서버 구성 및 웹 응용 프로그램만큼 안전합니다. 웹 서버가 www-data 사용자로 실행중인 경우 www-data 사용자가 읽을 수없는 것으로 홈 디렉토리 권한을 변경할 수 있습니다.

cd ~
chmod 750 .

자신의 사용자 이름으로 로그인 한 상태에서 실행하십시오. 나머지는 웹 응용 프로그램 자체를 포함하여 많은 정보 없이는 추측 할 수 없습니다. 그러나 적어도이 정도는 홈 디렉토리의 파일이 읽히지 않는다는 것을 알기 때문에 조금 더 안심할 수 있습니다.

DOCUMENT_ROOT (/ var / www /?)에 .htaccess 파일을 만들어 다른 계층을 추가하면 웹 서버에 액세스하는 모든 사람이 먼저 사용자 이름과 암호를 제공해야합니다. 배포시 항상 제거 할 수 있습니다.

Apache를 사용하고 있다고 가정합니다. 추가 한 AuthConfig 지시문이 작동하는지 확인하기 위해 Apache 구성 파일을 편집합니다. 문서 루트를 지정하는 'Directory'지시문 내에서 AllowOverride 문에 AuthConfig가 있는지 확인합니다.

AllowOverride AuthConfig

또는 "모두"를 사용할 수 있습니다.

AllowOverride All

이를 통해 .htaccess 파일에 Apache 지시문을 넣을 수 있습니다. 이제 웹 사이트의 공용 부분 외부에 암호 파일을 만듭니다. 여기서는 초기 사용자 my_username을 사용하여 / usr / local / etc / apache /에 passwords라는 암호 파일을 생성합니다 (-c). 암호를 입력하라는 메시지가 표시됩니다.

sudo mkdir -p /usr/local/etc/apache/
sudo htpasswd -c /usr/local/etc/apache/passwords my_username

그런 다음 문서 루트에 Apache AuthConfig 지시문을 넣으십시오. 문서 루트가 / var / www /이면 자주 사용하는 편집기를 사용하여 새 파일 이름 .htaccess ...를 만듭니다.

sudo vim /var/www/.htaccess

그 파일의 내용 ...

AuthType Basic
AuthName "My Web App"
AuthUserFile /usr/local/etc/apache/passwords
Require user my_username

저장. www-data로 실행하는 경우 소유자 및 권한 변경 :

sudo chown www-data /var/www/.htaccess
sudo chmod 400 /var/www/.htaccess

이제 아무도 사용자 이름과 암호없이 웹 서버를 사용할 수 없으며 웹 서버는 개인 파일을 읽을 수 없습니다. 하지만 PayPal이 사용자에게 다시 리디렉션 될 때이 암호 방법이 어떻게 작동하는지, 어떻게 작동하는지 모르겠습니다.

웹 앱의 PayPal 반환 부분을 개발하는 동안 필요에 따라 .htaccess를 / var / www 디렉터리 안팎으로 이동할 수 있다고 가정합니다.

이 기사는 인터넷에서 수집됩니다. 재 인쇄 할 때 출처를 알려주십시오.

침해가 발생한 경우 연락 주시기 바랍니다[email protected] 삭제

에서 수정
0

몇 마디 만하겠습니다

0리뷰
로그인참여 후 검토

관련 기사

분류에서Dev

원격 컴퓨터에 대한 연결을 내 로컬 컴퓨터의 포트로 라우팅하는 방법

분류에서Dev

"로컬 포트 포워딩"과 "동적 포트 포워딩"의 차이점은 무엇입니까?

분류에서Dev

로컬 시스템의 원격 호스트에 대한 포트 전달

분류에서Dev

로컬 시스템의 원격 호스트에 대한 포트 전달

분류에서Dev

로컬 네트워크의 한 컴퓨터와 다른 컴퓨터의 GUI에서 비즈니스 로직을 실행하는 방법은 무엇입니까?

분류에서Dev

로컬 네트워크를 통해 컴퓨터 B에서 컴퓨터 A에 연결할 때 컴퓨터 A의 CPU는 언제 사용됩니까?

분류에서Dev

iptables를 사용하여 두 개의 인터페이스로 포트 포워딩을 수행하는 방법은 무엇입니까?

분류에서Dev

동일한 네트워크에있는 두 컴퓨터 간의 통신을 위해 포트 포워딩이 필요합니까?

분류에서Dev

내 컴퓨터에 대한 로컬 호스트 이름 추가

분류에서Dev

Ubuntu 컴퓨터에서 포트 번호 8080에서 호스트 이름을 인식하는 방법은 무엇입니까?

분류에서Dev

라우터에서 포트 포워딩을 설정하지 않고 * 인터넷에서 로컬 웹 서버를 표시하는 방법은 무엇입니까?

분류에서Dev

로컬 호스트의 Tomcat v7.0 서버에 필요한 포트 80이 이미 사용 중입니다.

분류에서Dev

한 컴퓨터에서 다른 컴퓨터로 이동 한 게스트 VM의 네트워크 연결을 수정하는 방법은 무엇입니까?

분류에서Dev

로컬 네트워크 전용 루트 액세스에 대한 SSH 서버의 좋은 구성입니까?

분류에서Dev

더 넓은 호스트 OS LAN의 다른 컴퓨터에서 로컬 Virtual Box 서버를 사용할 수 있도록합니다.

분류에서Dev

더 넓은 호스트 OS LAN의 다른 컴퓨터에서 로컬 Virtual Box 서버를 사용할 수 있도록합니다.

분류에서Dev

로컬 네트워크의 다른 컴퓨터에서 스크립트를 통해 데비안 컴퓨터를 재부팅합니다.

분류에서Dev

플래시 드라이브를 사용하는 네트워크가없는 두 개의 로컬 호스트 컴퓨터에서 MySQL 데이터베이스를 어떻게 공유 / 사용합니까?

분류에서Dev

여러 컴퓨터로 포트 포워딩

분류에서Dev

한 호스트에서 다른 호스트로 포트를 포워딩하면서 소스 IP를 유지하지만 작은 문제가 있습니다.

분류에서Dev

iptables는 두 개의 인터페이스를 사용하여 공용 네트워크를 사설 네트워크로 포워딩합니다.

분류에서Dev

VPN으로 끝나는 두 개의 무선 네트워크에 대한 액세스 포인트를 설정하는 방법은 무엇입니까?

분류에서Dev

VPN으로 끝나는 두 개의 무선 네트워크에 대한 액세스 포인트를 설정하는 방법은 무엇입니까?

분류에서Dev

불완전한 객체 유형에 대한 스마트 포인터로 클래스를 안전하게 파괴하는 방법은 무엇입니까?

분류에서Dev

ASPX 로그인 컨트롤은 내 컴퓨터를 제외한 모든 사람의 컴퓨터에서 작동합니다.

분류에서Dev

내 웹 서버 컴퓨터로의 포트 포워드는 방문자 IP를 내 공용 IP로 포착합니다.

분류에서Dev

64 비트 버전의 Ubuntu에 대한 컴퓨터 요구 사항

분류에서Dev

라우터에 포트 포워딩을 설정하지 않고 컴퓨터가 인터넷에서 파일을 다운로드하는 방법은 무엇입니까?

분류에서Dev

컴퓨터의 IP 주소와 로컬 호스트의 차이점은 무엇입니까?

Related 관련 기사

  1. 1

    원격 컴퓨터에 대한 연결을 내 로컬 컴퓨터의 포트로 라우팅하는 방법

  2. 2

    "로컬 포트 포워딩"과 "동적 포트 포워딩"의 차이점은 무엇입니까?

  3. 3

    로컬 시스템의 원격 호스트에 대한 포트 전달

  4. 4

    로컬 시스템의 원격 호스트에 대한 포트 전달

  5. 5

    로컬 네트워크의 한 컴퓨터와 다른 컴퓨터의 GUI에서 비즈니스 로직을 실행하는 방법은 무엇입니까?

  6. 6

    로컬 네트워크를 통해 컴퓨터 B에서 컴퓨터 A에 연결할 때 컴퓨터 A의 CPU는 언제 사용됩니까?

  7. 7

    iptables를 사용하여 두 개의 인터페이스로 포트 포워딩을 수행하는 방법은 무엇입니까?

  8. 8

    동일한 네트워크에있는 두 컴퓨터 간의 통신을 위해 포트 포워딩이 필요합니까?

  9. 9

    내 컴퓨터에 대한 로컬 호스트 이름 추가

  10. 10

    Ubuntu 컴퓨터에서 포트 번호 8080에서 호스트 이름을 인식하는 방법은 무엇입니까?

  11. 11

    라우터에서 포트 포워딩을 설정하지 않고 * 인터넷에서 로컬 웹 서버를 표시하는 방법은 무엇입니까?

  12. 12

    로컬 호스트의 Tomcat v7.0 서버에 필요한 포트 80이 이미 사용 중입니다.

  13. 13

    한 컴퓨터에서 다른 컴퓨터로 이동 한 게스트 VM의 네트워크 연결을 수정하는 방법은 무엇입니까?

  14. 14

    로컬 네트워크 전용 루트 액세스에 대한 SSH 서버의 좋은 구성입니까?

  15. 15

    더 넓은 호스트 OS LAN의 다른 컴퓨터에서 로컬 Virtual Box 서버를 사용할 수 있도록합니다.

  16. 16

    더 넓은 호스트 OS LAN의 다른 컴퓨터에서 로컬 Virtual Box 서버를 사용할 수 있도록합니다.

  17. 17

    로컬 네트워크의 다른 컴퓨터에서 스크립트를 통해 데비안 컴퓨터를 재부팅합니다.

  18. 18

    플래시 드라이브를 사용하는 네트워크가없는 두 개의 로컬 호스트 컴퓨터에서 MySQL 데이터베이스를 어떻게 공유 / 사용합니까?

  19. 19

    여러 컴퓨터로 포트 포워딩

  20. 20

    한 호스트에서 다른 호스트로 포트를 포워딩하면서 소스 IP를 유지하지만 작은 문제가 있습니다.

  21. 21

    iptables는 두 개의 인터페이스를 사용하여 공용 네트워크를 사설 네트워크로 포워딩합니다.

  22. 22

    VPN으로 끝나는 두 개의 무선 네트워크에 대한 액세스 포인트를 설정하는 방법은 무엇입니까?

  23. 23

    VPN으로 끝나는 두 개의 무선 네트워크에 대한 액세스 포인트를 설정하는 방법은 무엇입니까?

  24. 24

    불완전한 객체 유형에 대한 스마트 포인터로 클래스를 안전하게 파괴하는 방법은 무엇입니까?

  25. 25

    ASPX 로그인 컨트롤은 내 컴퓨터를 제외한 모든 사람의 컴퓨터에서 작동합니다.

  26. 26

    내 웹 서버 컴퓨터로의 포트 포워드는 방문자 IP를 내 공용 IP로 포착합니다.

  27. 27

    64 비트 버전의 Ubuntu에 대한 컴퓨터 요구 사항

  28. 28

    라우터에 포트 포워딩을 설정하지 않고 컴퓨터가 인터넷에서 파일을 다운로드하는 방법은 무엇입니까?

  29. 29

    컴퓨터의 IP 주소와 로컬 호스트의 차이점은 무엇입니까?

뜨겁다태그

보관