آپاچی: تفاوت بین نسخه‌ها

از ویکی فارسی اوبونتو
پرش به: ناوبری، جستجو
(افزودن LAMP)
(افزودن پیوند php)
 
(۳ نسخه‌ٔ میانی ویرایش شده توسط ۲ کاربر نشان داده نشده)
سطر ۱: سطر ۱:
'''آپاچی''' (Apache HTTP Server) یک [[server|کارساز]] آزاد، رایگان و چندسکویی وب می‌باشد.
+
'''آپاچی''' (Apache HTTP Server) یک [[server|کارساز]] آزاد، رایگان و چندسکویی وب است.
  
 
== نصب ==
 
== نصب ==
برای نصب به شکل مستقل می‌توانید از دستور زیر استفاده نماید:
+
برای نصب مستقل می‌توانید از دستور زیر استفاده کنید:
 +
{{bc|
 +
$ sudo apt install apache2
 +
}}
  
<pre lang="bash">$ sudo apt install apache2</pre>
+
برای نصب کارساز وب آپاچی به همراه پایگاه دادهٔ [[MySQL]] و مفسّر [[php|PHP]] می‌توانید از دستور زیر استفاده نمایید:
 
+
{{bc|
برای نصب کارساز وب آپاچی به همراه پایگاه دادهٔ [[MySql]] و مفسّر [[php]] می‌توانید از دستور زیر استفاده نمایید:
+
$ sudo apt install lamp-server^
<pre lang="bash">$ sudo apt install lamp-server^</pre>
+
}}
  
 
LAMP به ترتیب از سرواژگان (Linux, Apache, MySQL, PHP) گرفته شده است.
 
LAMP به ترتیب از سرواژگان (Linux, Apache, MySQL, PHP) گرفته شده است.
سطر ۱۸: سطر ۲۱:
  
 
ابتدا مالک این دایرکتوری را user قرار داده و www-data را به عنوان گروه تنظیم خواهیم کرد.
 
ابتدا مالک این دایرکتوری را user قرار داده و www-data را به عنوان گروه تنظیم خواهیم کرد.
 
+
{{bc|
<pre lang="bash">
 
 
$ sudo chown -R user:www-data /var/www/html
 
$ sudo chown -R user:www-data /var/www/html
</pre>
+
}}
  
 
سپس با دستور زیر اطمینان حاصل می‌کنیم که apache دسترسی لازم برای خواندن تمامی فایل‌ها را دارد. همینطور صاحب فایل‌ها قادر به نوشتن در آن‌ها است.
 
سپس با دستور زیر اطمینان حاصل می‌کنیم که apache دسترسی لازم برای خواندن تمامی فایل‌ها را دارد. همینطور صاحب فایل‌ها قادر به نوشتن در آن‌ها است.
 
+
{{bc|
<pre lang="bash">
 
 
$ sudo find /var/www/html -type f -exec chmod 0644 {} +
 
$ sudo find /var/www/html -type f -exec chmod 0644 {} +
</pre>
+
}}
  
 
در مرحله بعد باید به user و apache مجوز ورود به دایرکتوری‌های مختلف را بدهیم. همینطور کاربر اجازه خواهد داشت تا فایل‌ها و دایرکتوری جدید ایجاد نماید.
 
در مرحله بعد باید به user و apache مجوز ورود به دایرکتوری‌های مختلف را بدهیم. همینطور کاربر اجازه خواهد داشت تا فایل‌ها و دایرکتوری جدید ایجاد نماید.
 
+
{{bc|
<pre lang="bash">
 
 
$ sudo find /var/www/html -type d -exec chmod 0755 {} +
 
$ sudo find /var/www/html -type d -exec chmod 0755 {} +
</pre>
+
}}
  
 
در ادامه با تنظیم SGID قصد داریم تا به صورت پیش‌فرض تمام فایل‌ و دایرکتوری‌هایی که در این شاخه ایجاد می‌شوند را به گروه www-data اختصاص دهیم.
 
در ادامه با تنظیم SGID قصد داریم تا به صورت پیش‌فرض تمام فایل‌ و دایرکتوری‌هایی که در این شاخه ایجاد می‌شوند را به گروه www-data اختصاص دهیم.
 
+
{{bc|
<pre lang="bash">
 
 
$ sudo chmod g+s /var/www/html/
 
$ sudo chmod g+s /var/www/html/
</pre>
+
}}
  
 
حال برای این‌که اسکریپت‌های شما بتوانند (با آپاچی) در شاخه‌های لازم چیزی بنویسند باید دسترسی نوشتن را برای گروه آپاچی در آن شاخه در نظر بگیرید.
 
حال برای این‌که اسکریپت‌های شما بتوانند (با آپاچی) در شاخه‌های لازم چیزی بنویسند باید دسترسی نوشتن را برای گروه آپاچی در آن شاخه در نظر بگیرید.
 +
{{bc|
 +
$ sudo chmod g+w /var/www/html/uploads
 +
}}
  
<pre lang="bash">
 
$ sudo chmod g+w /var/www/html/uploads
 
</pre>
 
  
 
از این پس آپاچی می‌تواند در دایرکتوری uploads بدون مشکل فایل‌های لازم را ایجاد نماید.
 
از این پس آپاچی می‌تواند در دایرکتوری uploads بدون مشکل فایل‌های لازم را ایجاد نماید.
سطر ۵۲: سطر ۵۱:
  
 
صاحب و گروه فایل‌های ایجاد شده کاربر آپاچی یا www-data خواهد بود. برای این‌که بتوانید این فایل‌ها را مدیریت، حذف و... کنید، سطوح دسترسی پیشفرض این شاخه را برای گروه www-data به شکل زیر تغییر دهید.
 
صاحب و گروه فایل‌های ایجاد شده کاربر آپاچی یا www-data خواهد بود. برای این‌که بتوانید این فایل‌ها را مدیریت، حذف و... کنید، سطوح دسترسی پیشفرض این شاخه را برای گروه www-data به شکل زیر تغییر دهید.
 
+
{{bc|
 
 
<pre lang="bash">
 
 
$ setfacl -d -m group:www-data:rwx  /var/www/html/uploads
 
$ setfacl -d -m group:www-data:rwx  /var/www/html/uploads
</pre>
+
}}
  
 
سپس کاربر خودتان را به این گروه اضافه نمایید:
 
سپس کاربر خودتان را به این گروه اضافه نمایید:
 
+
{{bc|
<pre lang="bash">
 
 
$ sudo gpasswd -a www-data user
 
$ sudo gpasswd -a www-data user
</pre>
+
}}
  
 
[[رده:کارساز وب]]
 
[[رده:کارساز وب]]

نسخهٔ کنونی تا ‏۱۰ خرداد ۱۴۰۳، ساعت ۱۶:۵۳

آپاچی (Apache HTTP Server) یک کارساز آزاد، رایگان و چندسکویی وب است.

نصب

برای نصب مستقل می‌توانید از دستور زیر استفاده کنید:

$ sudo apt install apache2

برای نصب کارساز وب آپاچی به همراه پایگاه دادهٔ MySQL و مفسّر PHP می‌توانید از دستور زیر استفاده نمایید:

$ sudo apt install lamp-server^

LAMP به ترتیب از سرواژگان (Linux, Apache, MySQL, PHP) گرفته شده است.

تنظیم سطح دسترسی var/www/html/

در ادامه یک روش ابتدایی پیشنهادی برای تنظیم سطح دسترسی به شاخه var/www/html/ آورده شده است.

فرض می‌کنیم کاربری با نام کاربری user باید توانایی نگارش در این شاخه را داشته و apache قادر به اجرا و در صورت نیاز ایجاد فایل‌های لازم باشد.

ابتدا مالک این دایرکتوری را user قرار داده و www-data را به عنوان گروه تنظیم خواهیم کرد.

$ sudo chown -R user:www-data /var/www/html

سپس با دستور زیر اطمینان حاصل می‌کنیم که apache دسترسی لازم برای خواندن تمامی فایل‌ها را دارد. همینطور صاحب فایل‌ها قادر به نوشتن در آن‌ها است.

$ sudo find /var/www/html -type f -exec chmod 0644 {} +

در مرحله بعد باید به user و apache مجوز ورود به دایرکتوری‌های مختلف را بدهیم. همینطور کاربر اجازه خواهد داشت تا فایل‌ها و دایرکتوری جدید ایجاد نماید.

$ sudo find /var/www/html -type d -exec chmod 0755 {} +

در ادامه با تنظیم SGID قصد داریم تا به صورت پیش‌فرض تمام فایل‌ و دایرکتوری‌هایی که در این شاخه ایجاد می‌شوند را به گروه www-data اختصاص دهیم.

$ sudo chmod g+s /var/www/html/

حال برای این‌که اسکریپت‌های شما بتوانند (با آپاچی) در شاخه‌های لازم چیزی بنویسند باید دسترسی نوشتن را برای گروه آپاچی در آن شاخه در نظر بگیرید.

$ sudo chmod g+w /var/www/html/uploads


از این پس آپاچی می‌تواند در دایرکتوری uploads بدون مشکل فایل‌های لازم را ایجاد نماید.

اسکریپت‌های شما باید umask لازم را جهت کاربری صحیح در این شاخه تنظیم نمایند.

صاحب و گروه فایل‌های ایجاد شده کاربر آپاچی یا www-data خواهد بود. برای این‌که بتوانید این فایل‌ها را مدیریت، حذف و... کنید، سطوح دسترسی پیشفرض این شاخه را برای گروه www-data به شکل زیر تغییر دهید.

$ setfacl -d -m group:www-data:rwx  /var/www/html/uploads

سپس کاربر خودتان را به این گروه اضافه نمایید:

$ sudo gpasswd -a www-data user