Active Directoryドメインのログインしているユーザが、そのログインユーザ情報で、プロキシの認証も行いたい場合、NTLM認証を使用することができます。
NTML認証では、認証する側と認証される側の間でチャレンジ、レスポンスによりパスワードのハッシュを送信します。認証される側のレスポンスのハッシュ値と認証する側が保持しているパスワードのハッシュ値が一致すれば、認証成功となります。
この記事では、FortigateをExplicit Proxyとして動作させ、ドメイン参加しているユーザがNTLM認証により、インターネットへ接続する動作を確認します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/E8F787BB-2A2F-4C3A-931B-139BC35E2883.png)
Fortigateのプロキシ認証は以下の記事もあわせて参考にしてください。
>> 参考記事 : プロキシ認証(Explicit Proxy+ローカルユーザによるBasic認証)FortiOS6.2.4また、インターネットへのローカルブレークアウト(クラウドプロキシ)やSWG(Secure Web Gateway)を併用する場合は、以下の記事もあわせて参考にしてください。
>> 参考記事 : クラウドプロキシ(Explicit Proxy+ローカルブレークアウト)FortiOS6.2.4Active Directoryの準備
ホスト名:ad-1、ドメイン:hirotanoblog.localとしてドメインコントローラを準備します。
また、ドメインユーザ ntlm-user01 にてログオンのうえ、IEのプロキシ設定をFortigateのport2である10.0.1.99:8080とし、NTLM認証も有効化しているものとします。
DNSサーバの設定
まず、FortigateのDNSサーバをADサーバに設定します。また、ローカルドメイン名として、ADドメインを設定します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/79D845E1-4855-4943-966E-E4274FDE0D66.png)
FortigateからADサーバ(ad-1)の名前解決&疎通ができることを確認します。
FortiGate # execute ping ad-1 PING ad-1.hirotanoblog.local (10.0.1.25): 56 data bytes 64 bytes from 10.0.1.25: icmp_seq=0 ttl=128 time=0.4 ms 64 bytes from 10.0.1.25: icmp_seq=1 ttl=128 time=0.4 ms 64 bytes from 10.0.1.25: icmp_seq=2 ttl=128 time=0.5 ms 64 bytes from 10.0.1.25: icmp_seq=3 ttl=128 time=0.4 ms 64 bytes from 10.0.1.25: icmp_seq=4 ttl=128 time=0.4 ms --- ad-1.hirotanoblog.local ping statistics --- 5 packets transmitted, 5 packets received, 0% packet loss round-trip min/avg/max = 0.4/0.4/0.5 ms FortiGate #
LDAPサーバの設定
ユーザ&認証 >> LDAPサーバを選択し、新規作成をクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/7932EF9A-2EC3-4659-82EC-76D06D591422.png)
LDAPサーバの編集 画面が表示されます。ADサーバを登録します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/E6BEED22-12D6-424F-B822-DE8C18837E4B.png)
- 名前:ad-1 と設定
- サーバIP/名前 : ADサーバのIPアドレスである10.0.1.25を設定
- バインドタイプ:レジュラー を選択
- ユーザ名・パスワード:Active Directoryにアクセスできるユーザ。今回は、administratorとそのパスワードを設定
上記まで入力して識別名のブラウズをクリックします。LDAPのツリーが表示されるので、cn=users,dc=hirotanoblog,dc=local を選択します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/987C3E5A-45CD-4028-941F-12B061848F3E.png)
下記のように、識別名が登録されます。
接続をテストをクリックし、接続ステータスが成功になることを確認してください。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/41F47641-73F7-46FF-A65C-AD56B94FC43D.png)
ユーザクレデンシャルをテストをクリックし、ユーザの認証が可能か確認します。
ADサーバには今回、ntlm-user01をいうユーザを登録しています。 ユーザ名、パスワードを入力後、テストをクリックし、接続ステータス、ユーザクレデンシャルともに成功であることを確認します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/ACE48C45-E168-4B29-8416-685EBC36BA86.png)
Explicit プロキシの設定
ネットワーク >> Explicit プロキシ へ移動し、プロキシ機能を有効にします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/9F3A31FA-E397-4F9F-B802-DFDD3429FE01.png)
- Explicit Web プロキシ:有効にします。
- リッスンするインタフェース: port2を選択
- HTTPポート:任意の値。今回は8080とします。
認証ルールの設定
認証方式
ポリシー&オブジェクト >> 認証ルール へ移動し、新規作成より認証方式を選択します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/6A8E674B-21C9-470E-8E8D-5BEDC8ADEA04.png)
新規認証方式の画面が表示されます。
名前を任意の名前(今回はNTLM)とし、方式として、NTLMを選択します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/33237302-D4DD-4C72-9E2C-8410E00CE09A.png)
選択後、ドメインコントローラなどの設定画面が表示されます。 ドメインコントローラの設定項目を選択し、新規作成をクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/B5283EB3-944A-451C-B6FC-22F8E26423FC.png)
ドメインコントローラを設定します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/4C5BDD09-0623-4D5C-9404-FCF7B43FEB09.png)
- 名前:ad-1と設定
- IPアドレス : ADサーバのIPアドレスである10.0.1.25を設定
- LDAPサーバ:リストより、ad-1を選択
- ドメイン名:hirotanoblog.local を設定
OKをクリックすると、ドメインコントローラが登録されるので、OKをクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/97025F2A-1926-4CBD-B2B0-E2D17D69C192-1.png)
OKをクリックすると、以下のようなリストが表示されます。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/39E35825-93CD-4DAF-BE76-4390FB0E0BAC.png)
認証ルール
ポリシー&オブジェクト >> 認証ルール へ移動し、新規作成より認証ルールを選択します。
新しいルールの追加 が表示されます。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/330CACBC-BC2E-4759-9DF3-B166B4E94A75-1.png)
- 名前:任意。今回は、NTLM-Ruleとします。
- 送信元アドレス:all を選択
- 認証方式:有効にし、先に設定したNTLMを選択。
OKをクリックすると、以下のとおり表示されます。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/B8CB4DED-3DEF-4820-9DE3-A7DF7E699F4F-1.png)
ユーザ設定
ユーザ&認証 >> ユーザグループへ移動し、新規作成をクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/93FFD96E-DF9D-4242-9850-9577960BB39E.png)
新規ユーザグループを設定する画面が表示されます。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/78566911-D5EE-486B-812A-AC2345A7425F.png)
- 名前:任意の名前。今回は、NTLM-User-Groupとします。
- タイプ:ファイアウォールを選択
リモートグループで追加をクリックすると、グループ一致の追加 が表示されます。 リモートサーバでad-1を選択し、OKをクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/3006417D-5801-4A3F-9D53-39F11656BFED.png)
リモートサーバのad-1が追加されていることを確認し、OKをクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/7BDE81B9-484C-4326-975B-873A3C8CD185.png)
新しいNTLM-User-Groupが追加されました。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/66386356-AF42-4E49-8C14-57976B0A7AB7-1.png)
プロキシポリシーの設定
ポリシー&オブジェクト >> プロキシポリシー へ移動し、新規作成をクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/E8421883-48F4-49DC-B937-8CDEB3B47FCB.png)
プロキシポリシーを設定します。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/EFC9F01D-FA5D-47BE-8486-2FF28F68277B-1.png)
- 名前:任意の名前。今回は、NTLM-Proxyとします。
- プロキシタイプ:Explicit Webを選択
- 発信インタフェース:インターネット接続向けであるport1を選択
- 送信元:送信元アドレスは制限せずにallとし、送信元ユーザとして、NTLM-User-Groupを選択
- 宛先:allを選択
- サービス:webproxyを選択
動作確認
ドメインユーザ ntlm-user01でログインし、ブラウザ(IE)を開くと、インターネットサイトへアクセスできることが確認できます。
ユーザは特にユーザ情報などを入力する必要はありません。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/0C34E1EA-34FB-4387-BF38-33541B1F8296-1-1024x590.png)
ユーザ認証ログを確認するため、ログ&レポート >> イベント からユーザイベントをクリックします。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/0D5B3579-E266-4E5E-94A0-69D2AEB24120.png)
ユーザ ntlm-user01の認証が成功していることが確認できます。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/A0848554-6C2D-46F5-B2B2-229017D0BFAB.png)
ログ&レポート >> 転送トラフィック よりトラフィックログを確認すると、プロキシポリシーNTLM-Proxyで、ntlm-user01がインターネットへアクセスしていることが確認できます。
![](https://hirotanoblog.com/wp-content/uploads/2021/04/00AFF6E4-9333-4372-97E1-BB45B460A31A.png)
ユーザの認証状況は diagnose wad user list で確認できます。
FortiGate # diagnose wad user list ID: 1, VDOM: root, IPv4: 10.0.1.51 user name : ntlm-user01 worker : 3 duration : 880 auth_type : IP auth_method : NTLM pol_id : 2 g_id : 2 user_based : 0 expire : no LAN: bytes_in=608236 bytes_out=7890660 WAN: bytes_in=7901810 bytes_out=558730
コメント