質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
bash

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

3回答

230閲覧

「一般ユーザーに特定の管理者コマンドを実行できる権限を設定」する方法

cansaku

総合スコア6

bash

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2017/09/13 01:27

Linuxで、一般ユーザーが見られないディレクトリに管理者コマンドが格納されているが、そのようなコマンドでも、「一般ユーザーにも実行できる権限が設定されていれば」絶対パスで指定することで実行できます

「1週間でLPICの基礎が学べる本」という本に書いてあった内容ですが、「一般ユーザーに特定の管理者コマンドを実行できる権限を設定」する方法があるのでしょうか。

その権限設定については書籍で説明されておらず、方法があればご教示お願いします。

書籍では、例としてifconfigコマンドが挙げられています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

一般ユーザーが見られないディレクトリに管理者コマンドが格納されているが

その状況では不可能です。ファイルにいくら権限をかけたところで、ディレクトリの閲覧権限すらない状況ではプログラムの実行以前に、見つけることもできません。

ただし、(ファイル自体は一般ユーザーにも見える前提で)あるプログラムを実行したときだけ特殊な権限を使えるようにする方法はあります。ファイルにsetuidというフラグを立てることで、プログラムの実行権限がそのファイルに付されたユーザーと同じになる、という仕組みです。

$ ls -l `which passwd` -rwsr-xr-x. 1 root root 30768 11月 24 01:30 2015 /usr/bin/passwd

passwdコマンドは、/etc/passwd/etc/shadowを書き換える以上、一般ユーザーの権限では実行できません。なので、ファイルの所有者をrootとして、setuidをかける(4文字目のsがその意味です)ことで、可能としています。

なお、自分の手元の環境では、ifconfig/sbinにあって、setuidもしていないただのプログラムでした。

投稿2017/09/13 01:36

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

Linuxで、一般ユーザーが見られないディレクトリに管理者コマンドが格納されているが、そのようなコマンドでも、「一般ユーザーにも実行できる権限が設定されていれば」絶対パスで指定することで実行できます

表現が間違っていますね。「絶対パスで指定することで」からすると、前段は、
「一般ユーザーのPATHにデフォルトで入っていないディレクトリに~」
の間違いでしょう。ただOSによってはsbinもデフォルトでPATHに入っています。

「一般ユーザーに特定の管理者コマンドを実行できる権限を設定」する方法があるのでしょうか。

sudoの事かと思いましたが、ifconfigが例として挙がっているのであれば、単にファイルの実行権限の話です。

Bash

1$ ls -l /sbin/ifconfig 2-rwxr-xr-x 1 root root 70024 Mar 22 08:51 /sbin/ifconfig*

-rwxr-xr-xの一番右のxが「誰でも実行できる」という権限設定です。
設定方法としては、chmod o+x ファイル名です。

挙げられた文章を見た限りでは、あまり出来の良い本じゃない気がします。
別途、数社から出ている定番の分厚い教科書を買って、不明点は都度調べるのが良いと思います。

投稿2017/09/13 02:41

編集2017/09/13 02:42
otn

総合スコア84499

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

sudoを併用すればイケルと思います
ただし実行コマンドをホワイトリストなどで管理するなどしないと
セキュリティ上問題です

投稿2017/09/13 01:32

yambejp

総合スコア114769

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問