私はこれについて非常に混乱しており、texts/docs/SOの質問のどれも私にとって問題を解明していません。asp.net user permissions
私のasp.net MVCアプリケーションが、サーバー上のフォルダにXML文書を保存できるようにします。しかし、私は例外が発生しています...
Access to the path 'D:\blah\blah\folder\xml_data.xml' is denied.
私のアプリケーションは、書き込み権限を持たないユーザーアカウントで実行されていることを理解しています。
私は前にこの問題があったと思うし、私の解決策は私のウェブホストに連絡して、私のサイトのアクセス許可を与えるように頼んでいた。
しかし、独自のカスタムロールセットを作成して、それに対応する権限を設定したいのですが?これらはIISに追加する必要がありますか?リストを作成してウェブホストに渡す必要がありますか?そのようなリストはどのように見えるでしょうか?私が理解しているように、web.configでロールとアクセス許可を設定することはできませんが、それは正しいのですか?
私は、ロールとその権限を設定して、アプリケーションのデフォルトロールをどのように設定するのか、そしてアプリケーションが実行されているロールをプログラム的にどのように変更するのですか?
ps。私はasp.netメンバーシップを使用したくない。これを自分で設定する方法を知りたい。
を参照してください提案いただきありがとうございますが、私はasp.netメンバーシップなしでこれを行う方法を知るために、具体的に尋ねました。プリンシパル、アイデンティティ、役割をプログラムに設定できることはわかっています。カスタムロールと権限を作成する方法を知る必要があります。私はそれらを定義し、ホストにそれらを設定するよう依頼する必要がありますか、または自分自身を設定することはできますか?これは私が興味を持っているすべてのものです。ありがとう。 –
@ FunkyFresh84 - プリンシパル、アイデンティティ、ロールは、プロセスが実行されるWindowsユーザーとは関係ありません(これは、ファイルへのアクセスで説明した問題です)。ホストにそれらのことを知らせる必要はありません。コードとデータベースに完全に定義されています。あなたのIPrincipalオブジェクトとIIDentityオブジェクトはすべてを制御します。ユーザーがファイルにアクセスする必要がある場合、WebプロセスをWindowsが許可するIDとして実行する必要があります。偽装として知られている概念がありますが、ユーザーがサーバーにアカウントを持っている場合にのみ適用されます。 –
@ FunkyFresh84 - IPrincipalとIIDentityがどのように機能するかを完全に理解していない場合(あなたの質問が私にあなたを信じないように導くか、質問に対する答えを知っている)、Membership APIを使用することをお勧めします。私はこれを読むことをお勧めしますhttp://msdn.microsoft.com/en-us/library/ff649100.aspx –