ホームページ バックエンド開発 C#.Net チュートリアル asp.net での Access データベースのダウンロードを防止する

asp.net での Access データベースのダウンロードを防止する

Nov 25, 2016 am 09:49 AM
asp.net

Access データベースのダウンロードを防ぐ方法は非常に古いトピックであり、インターネット上で多くの議論が行われています。ここでは、ASP.NET で Access データベースがダウンロードされないようにするいくつかの方法を紹介します。

ここでは、Access データベース名が test.mdb であると仮定します。

1. データベースを WEB ディレクトリの外に配置します

Web サイトのディレクトリが D:www の場合、データベースをフォルダー D:data に配置し、Web サイト プログラムのデータベース接続文字列アドレスを次のように変更します。 :datatest.mdb」を追加すると、データベースを正常に呼び出すことができますが、Web サイトのディレクトリにないためダウンロードできません。

データベース接続文字列が web.config で構成されていると仮定します。例:

 <connectionStrings>
        <add name="Access" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;data source=d:\data\test.mdb" providerName="System.Data.OleDb" />
    </connectionStrings>
ログイン後にコピー

2. データベースを App_Data システム フォルダーに配置します。

.Net2.0 以降は、Access、SQL Server Express、XML を格納するために使用できます。およびその他のデータ ファイル。データベース ファイルを App_Data フォルダーに配置する利点は、データベース ファイルがダウンロードされないようにすることができることです。接続文字列データベースのファイルの場所については、DataDirectory キーを使用してその物理パスを表すことができるため、接続文字列を取得するときに Server.MapPath() 変換を使用する必要がなくなりました。

データベース接続文字列が web.config で構成されていると仮定します。例:

 <connectionStrings>
        <add name="Access" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;data source=|DataDirectory|test.mdb" providerName="System.Data.OleDb" />
    </connectionStrings>
ログイン後にコピー

|DataDirectory| は app_data フォルダーを表します。

3. データベース ファイルの名前を変更します

Access の名前を変更します *.asax: ASP.NET の処理メカニズムのため、デフォルトでは、そのような要求は直接拒否されます。このアイデアに従って、Access の名前を *.config、*.vb、*.cs などに変更することもできます。

4. IIS を構成し、.mdb ファイル タイプ マッピングを追加します。

.mdb 拡張子マッピングを追加する この方法は、IIS 設定を変更することで実現します。たったの2ステップ。

1. .mdb ファイル タイプを ASP.NET ISAPI にマップするように IIS を構成します。

Windows 2003 を例として、「スタート」→「ファイル名を指定して実行」→「inetmgr」と入力し、Enter キーを押して「インターネット サービス マネージャー」を開きます。 Webサイトを右クリック→「プロパティ」をクリックすると、このサイトのプロパティダイアログボックスが表示されます。 「ホームディレクトリ」タブをクリックし、「設定」ボタンをクリックすると、「アプリケーション設定」ダイアログボックスが表示されます。 [追加] をクリックしてマッピングを追加するダイアログ ボックスが表示され、実行可能ファイル「C:WINDOWS Microsoft.NET Framework v2.0.50727 aspnet_isapi.dll」を入力します。拡張子「.mdb」を入力します。以下の図に示すように

asp.net での Access データベースのダウンロードを防止する

2. asp.net の web.config ファイルを構成し、.mdb ファイル タイプを HttpForbiddenHandler HTTP ハンドラーにマップします。

asp.net アプリケーションの .mdb ファイル タイプを HttpForbiddenHandler HTTP ハンドルにマップできるようにします。この手順を実行するには、次の構成を Web.config ファイルに追加する必要があります

 <httpHandlers>
            <add verb="*" path="*.mdb" type="System.Web.HttpForbiddenHandler" />
   </httpHandlers>
ログイン後にコピー

5. ACCESS のダウンロード防止フィールドを追加します

この方法の原理は、データベースの拡張子を .aspx 形式に変更することです。このファイルが入力されると、IIS サーバーはそのファイルを aspx プログラムとして実行します。以前に ACCESS データベースに「" タグは実行できるため、「スクリプト終了タグがありません」という 500 エラーが表示され、その他は ACCESS データベースをダウンロードできなくなります。データベースのテキスト フィールドまたはメモ フィールドに「

1. まずテーブルを作成し、SQL コマンド ウィンドウに次の内容を入力します。「create table [notdown]([notdown] oleobject)」

次に、[実行] をクリックします。ツールバーにあるように、フィールド名「notdown」、フィールド タイプ「OLE オブジェクト」を持つ「notdown」テーブルが現在のデータベースに作成されます。 図1に示すように

asp.net での Access データベースのダウンロードを防止する

2. SQLクエリウィンドウの内容を次のコマンドに変更します:「insert into [notdown](notdown)values(0x3C25)」

この文は「に挿入」を意味します。 [notdown](notdown) 値 (0x3C25)"

「notdown」フィールドに「0x3C25」のデータを挿入します(「0x3C25」は文字「

実行が完了したら、データベース内の「テーブル」を再度確認すると、追加の「notdown」テーブルがあることがわかります。開くと、フィールドに「長いバイナリ データ」が表示されます。 " 図 3 に示すようにasp.net での Access データベースのダウンロードを防止する

🎜🎜

admin10000.com ダウンロード防止データ テーブルはここで用意されており、直接ダウンロードして独自のデータベースに貼り付けて使用できます。 notdown データ テーブル

ヒント 1: ASP Web サイトであっても ASP.NET Web サイトであっても、Access データベースのサフィックスを .asp および .aspx に直接変更すると、FlashGet などのダウンロード ツールを使用して正しくコピーできます。ダウンロードの影響は妨げられません。
ヒント 2: 5 番目の方法は通常、ASP+ACCESS Web サイトで使用されます。


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C言語でさまざまなシンボルを使用する方法 C言語でさまざまなシンボルを使用する方法 Apr 03, 2025 pm 04:48 PM

c言語のシンボルの使用方法は、算術、割り当て、条件、ロジック、ビット演算子などをカバーします。算術演算子は基本的な数学的操作に使用されます。割り当てと追加、下位、乗算、除算の割り当てには、条件操作に使用されます。ポインター、ファイル終了マーカー、および非数値値。

C文字列におけるcharの役割は何ですか C文字列におけるcharの役割は何ですか Apr 03, 2025 pm 03:15 PM

Cでは、文字列でCharタイプが使用されます。1。単一の文字を保存します。 2。配列を使用して文字列を表し、ヌルターミネーターで終了します。 3。文字列操作関数を介して動作します。 4.キーボードから文字列を読み取りまたは出力します。

C言語で特殊文字を処理する方法 C言語で特殊文字を処理する方法 Apr 03, 2025 pm 03:18 PM

C言語では、以下などのエスケープシーケンスを通じて特殊文字が処理されます。\ nはラインブレークを表します。 \ tはタブ文字を意味します。 ESACEシーケンスまたは文字定数を使用して、Char C = '\ n'などの特殊文字を表します。バックスラッシュは2回逃げる必要があることに注意してください。さまざまなプラットフォームとコンパイラが異なるエスケープシーケンスを持っている場合があります。ドキュメントを参照してください。

マルチスレッドと非同期C#の違い マルチスレッドと非同期C#の違い Apr 03, 2025 pm 02:57 PM

マルチスレッドと非同期の違いは、マルチスレッドが複数のスレッドを同時に実行し、現在のスレッドをブロックせずに非同期に操作を実行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利点は、コンピューティングのパフォーマンスを改善することですが、非同期の利点はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。

C言語のcharとwchar_tの違い C言語のcharとwchar_tの違い Apr 03, 2025 pm 03:09 PM

C言語では、charとwchar_tの主な違いは文字エンコードです。CharはASCIIを使用するか、ASCIIを拡張し、WCHAR_TはUnicodeを使用します。 Charは1〜2バイトを占め、WCHAR_Tは2〜4バイトを占有します。 charは英語のテキストに適しており、wchar_tは多言語テキストに適しています。 CHARは広くサポートされており、WCHAR_TはコンパイラとオペレーティングシステムがUnicodeをサポートするかどうかに依存します。 CHARの文字範囲は限られており、WCHAR_Tの文字範囲が大きく、特別な機能が算術演算に使用されます。

C言語でCharを変換する方法 C言語でCharを変換する方法 Apr 03, 2025 pm 03:21 PM

C言語では、charタイプの変換は、キャスト:キャスト文字を使用することにより、別のタイプに直接変換できます。自動タイプ変換:あるタイプのデータが別のタイプの値に対応できる場合、コンパイラは自動的に変換します。

C言語でchar配列の使用方法 C言語でchar配列の使用方法 Apr 03, 2025 pm 03:24 PM

Char Arrayは文字シーケンスをC言語で保存し、char array_name [size]として宣言されます。アクセス要素はサブスクリプト演算子に渡され、要素は文字列のエンドポイントを表すnullターミネーター「\ 0」で終了します。 C言語は、strlen()、strcpy()、strcat()、strcmp()など、さまざまな文字列操作関数を提供します。

Charとunsigned Charの違いは何ですか Charとunsigned Charの違いは何ですか Apr 03, 2025 pm 03:36 PM

CharおよびUnsigned Charは、文字データを保存する2つのデータ型です。主な違いは、負と正の数に対処する方法です:値範囲:char署名(-128〜127)、および符号なしのchar unsigned(0〜255)。負の数処理:charは負の数を保存でき、符号なしのcharはできません。ビットモード:char最高ビットは、シンボル、符号なしのchar unsignedビットを表します。算術操作:charおよびunsigned charが署名されており、署名されていないタイプがあり、それらの算術操作は異なります。互換性:charおよびunsigned char

See all articles