AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 399741
Accepted
artaxerxe
artaxerxe
Asked: 2012-06-19 04:46:31 +0800 CST2012-06-19 04:46:31 +0800 CST 2012-06-19 04:46:31 +0800 CST

限制 FreeRADIUS 客户端使用相同的用户和密码从不同的 LAN 访问服务

  • 772

我已经FreeRADIUS安装在我的服务器上,并且还有两个 LAN(或可能更多)由该服务器管理。假设 LAN A:192.168.1.0和 LAN B: 192.168.2.0。我正在与数据库FreeRADIUS结合使用。postgres在我的radcheck表中,我插入了以下行:

userbane='myuser', attribute='Password', op=':=', value='mypass'.

现在我想让从我的 FreeRADIUS 请求服务的客户端只有在属于 LAN B 的一部分时才能使用此用户名和密码对自己进行身份验证。

问题:任何人都可以建议我如何完成这项工作吗?

我试图在radcheck一行中添加更多:username='myuser', attribute='NAS-IP-Address', op=':=', value='192.168.2.1',但没有成功。

任何帮助,将不胜感激。

radius freeradius2
  • 2 2 个回答
  • 6085 Views

2 个回答

  • Voted
  1. Best Answer
    mgorven
    2012-06-19T09:13:22+08:002012-06-19T09:13:22+08:00

    我以前没有使用过数据库后端,但是使用用户文件规则看起来像这样:

    myuser  Cleartext-Password := "mypass", NAS-IP-Address == "192.168.2.1"
    

    基于此,我认为您需要表中的两个条目radcheck:

    usernane='myuser', attribute='Password', op=':=', value='mypass'
    username='myuser', attribute='NAS-IP-Address', op='==', value='192.168.2.1'
    
    • 3
  2. vinch100
    2013-08-12T23:58:44+08:002013-08-12T23:58:44+08:00

    使用 SQL 数据库,我通过以下方式解决了这个问题:

    1)添加特殊行(site_id)

    ALTER TABLE radcheck ADD site_id VARCHAR(30) NOT NULL default '0.0.0.0' AFTER value;
    

    2) 修改/etc/freeradius/sql/mysql/dialup.conf 如下

    authorize_check_query = "SELECT id, username, attribute, value, op, site_id, valid_from, valid_until \
      FROM ${authcheck_table} \
      WHERE username = '%{SQL-User-Name}' AND site_id='%{NAS-Identifier}' \
      ORDER BY id"
    

    在我的例子中,我使用了 NAS-Id,但是将 %{NAS-Identifier} 替换为 %{NAS-IP-Address} 并且可以选择将 site_id 替换为 site_ip 将使用 IP 地址来解决问题

    • 1

相关问题

  • 损坏的 802.1x Windows Server 2008 R2

  • 在 Ubuntu 上为 WPA2 设置 RADIUS + LDAP

  • WPA2 Enterprise - 验证身份

  • 我在哪里可以找到思科 2106 与杜松钢带半径组合的 RADIUS 配置示例?

  • 设置 RADIUS 服务器以供 VPN 设备使用

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve