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

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

新規登録して質問してみよう
ただいま回答率
85.37%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

Q&A

1回答

1517閲覧

C#でWIN10のフォルダ権限についてアクティブディレクトリユーザーの権限も取得したい

kazuya_

総合スコア82

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

0グッド

0クリップ

投稿2020/06/03 01:24

下記のコードで rule.IdentityReference as NTAccount がNULLになる時、
rule.IdentityReferenceには{S-1-5-21-1191241095-3308675732-1852311544-1000}が入っています。
これはアクティブディレクトリユーザーに変換できるデータが入ってきているのでしょうか?
また、GetAccessRulesでなく別の方法を取らないとだめでしょうか?

foreach (FileSystemAccessRule rule in security.GetAccessRules(true, true, typeof(NTAccount)))
{
if (rule.IdentityReference as NTAccount != null)
{
ace = rule.AccessControlType
+ "\t" + (rule.IdentityReference as NTAccount).Value
+ "\t" + rule.FileSystemRights.ToString()
+ "\t" + rule.IsInherited.ToString()
+ "\t" + rule.InheritanceFlags.ToString()
+ "\t" + rule.PropagationFlags.ToString();

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

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

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

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

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

guest

回答1

0

その{S-1-5-21-xxxxx-1000}というのは、「セキュリティ識別子」や「セキュリティID」、「SID」などと呼ばれるもので、その文字列であればアクティブディレクトリのユーザーまたはグループを示しています。

手元に環境がないため詳しくご説明できず恐縮ですが、その文字列については「SID文字列」などの条件で、また変換については「SID文字列 名前 変換」などの条件でググっていただければ、情報が見つかるかと思います。

投稿2020/06/03 15:22

編集2020/06/03 15:24
segavvy

総合スコア1034

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

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

kazuya_

2020/06/04 07:06

ありがとうございます。 下記のように、ContextType.Domainにして、全ドメイン検索にてSIDを入れて検索しても 出てきません。他のサーバーのユーザー(jimxxx\xxxxx)のようです。この場合 変換可能なのでしょうか? var searchContext = new PrincipalContext(ContextType.Domain); var adUser = UserPrincipal.FindByIdentity(searchContext, IdentityType.Sid, sid);
segavvy

2020/06/04 15:07

PrincipalContextを生成する際にドメイン名の指定が必要かもしれません。また、ADドメインではなく他のサーバーのローカルユーザなのであれば、ContextType. Machineでコンピュータ名などの指定が必要かもしれません。 これ以上は私も記憶があいまいで試す環境もないため、うまくいかない場合は、他の識者の方の回答をお待ちください……
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問