前言
这是我在这个网站整理的笔记,关注我,接下来还会持续更新。 作者:神的孩子都在歌唱
FreeRADIUS是一个开源的RADIUS(Remote Authentication Dial-In User Service)服务器,用于提供网络认证和授权服务。它是一个高度可定制和可扩展的服务器,广泛用于企业、服务提供商和运营商等环境中。
以下是FreeRADIUS的一些关键特点和功能:
认证和授权:FreeRADIUS支持多种身份验证方法,包括EAP-TLS、EAP-TTLS、PEAP等。它可以与各种网络设备(如交换机、路由器、无线访问点等)集成,为用户提供安全的网络访问。
灵活的配置:FreeRADIUS具有灵活的配置选项,可以根据特定需求进行定制。管理员可以通过编辑配置文件来定义客户端、用户凭据、认证方法等。
日志和审计:FreeRADIUS提供详细的日志记录和审计功能,可用于跟踪用户认证和授权活动。这有助于监控和故障排除网络访问问题。
可扩展性:FreeRADIUS支持插件架构,允许开发人员编写自定义模块来扩展服务器的功能。这使得FreeRADIUS可以集成其他系统和服务,以满足特定需求。
高性能:FreeRADIUS经过优化以提供高性能和可靠性。它可以处理大量的认证请求,并支持负载平衡和故障转移,以确保服务的可用性。
环境
VMware15.5
centos7(radius服务器)
java代码 (radius客户端)
安装
yum install -y freeradius freeradius-utils freeradius-mysql //安装FreeRadius及组件
systemctl start radiusd.service //启动radius服务
systemctl enable radiusd.service //设置radius服务开机自启动
配置
修改允许接入的客户端 vim /etc/raddb/clients.conf
"0.0.0.0/0"表示允许任何IP地址的客户端连接到Radius服务器。
“secret"是用于客户端和Radius服务器之间进行身份验证的共享密码,这里设置为"testing123”。
添加用户
配置 vim /etc/raddb/users
文件头添加 test Cleartext-Password := “123456”
注意要重启radius
radiusd -X #调试模式运行
radtest test 1234567 192.168.1.47 1812 testing123 # 另开启一终端
以下结果就是请求成功了
依赖
<dependency>
<groupId>com.globalreachtechgroupId>
<artifactId>tinyradius-nettyartifactId>
<version>1.5.12version>
dependency>
<dependency>
<groupId>org.tinyradiusgroupId>
<artifactId>tinyradiusartifactId>
<version>1.1.3version>
dependency>
代码
public class test {
public static void main(String[] args) throws Exception {
String host = "192.168.1.47";
String shared = "testing123";
String user = "test";
String pass = "123456";
RadiusClient rc = new RadiusClient(host, shared);
rc.setSocketTimeout(3);
rc.setAuthPort(1812);
AccessRequest accessRequest = new AccessRequest(user, pass);
accessRequest.setAuthProtocol("chap");
try {
RadiusPacket authenticate = rc.authenticate(accessRequest);
if(authenticate.getPacketType() == 2){
System.out.println("radius认证通过!");
} else {
System.out.println("radius认证不通过!");
};
} catch (RadiusException e) {
e.printStackTrace();
}
rc.close();
}
}
作者:神的孩子都在歌唱
本人博客:https://blog.csdn.net/weixin_46654114
转载说明:务必注明来源,附带本人博客连接。