Go to file
2022-12-18 16:32:19 +08:00
.history save 2022-12-15 18:09:24 +08:00
vendor 完成了CNAME+A记录类型 2022-12-18 16:32:19 +08:00
.gitignore Saving 2022-12-15 21:22:16 +08:00
composer.json save 2022-12-15 18:09:24 +08:00
composer.lock save 2022-12-15 18:09:24 +08:00
Dns.php first commit 2022-12-16 20:36:45 +08:00
php-ipv6.php first commit 2022-12-16 20:36:45 +08:00
readme.md commit 2022-12-16 20:45:47 +08:00
start.php 完成了CNAME+A记录类型 2022-12-18 16:32:19 +08:00
test.php 完成了CNAME+A记录类型 2022-12-18 16:32:19 +08:00

Workerman-DNS

Workerman的DNS协议实现了简单的DNS协议解析和响应通过本协议支持您可以利用Workerman实现基于PHP的Dns服务器

目前支持以下DNS类型

  • A
  • AAAA
  • CNAME
  • SOA
  • PTR
  • MX
  • TXT

本仓库内vendor文件夹为Workerman

您可以删除,直接将本仓库根目录下的 Dns.php 放置到您的Workerman项目中的 /vendor/workerman/workerman/Protocols 目录下


使用方式:

详见start.php 文件

注意使用53端口需要root权限

1.监听端口

<?php
use Workerman\Worker;
use Workerman\Connection\TcpConnection;
use Workerman\Protocols\Http\Request;
require_once __DIR__ . '/php-ipv6.php'; #IPv6支持
require_once __DIR__ . '/vendor/autoload.php';

$worker = new Worker('Dns://0.0.0.0:53');
$worker->transport = 'udp';


2.获取查询内容

$worker->onMessage = function($connection, $data){
$data=json_decode($data);
$type=$data->type; #查询类型
$name=$data->name; #查询内容(一般是域名PTR时为倒序IP)
$rip=$connection->getRemoteIp(); #客户端IP

#输出信息
echo "\n Type:$type \n Domain: $name\n Client IP: $rip \n";

}

3.响应A记录

$worker->onMessage = function($connection, $data){

$send['type']='A';
$send['detail'][1]='119.29.29.29';  #第一条记录
$send['detail'][2]='8.8.8.8';	    #第二条记录
$send['ttl']=30;



#id和query一般情况下直接返回输出即可
$send['id']=$data->id;
$send['query']=$data->query;



$send=json_encode($send);
$connection->send($send);


};
Worker::runAll();

4.响应其他记录

见start.php 内有所有记录类型的响应方式

5.说明

您应当通过获取query的 $name通过查询数据库等方式返回数据对于不存在的记录应当返回SOA记录

您需要的时候可以通过 dns_get_record()向上级DNS递归查找并缓存

这一系列操作本协议不提供您可以自行通过Redis等并利用workerman实现

不建议作为根域名的NS服务器使用。

已知问题

本协议最早写于鄙人刚学习php的阶段现在翻出来无疑是屎山一坨代码写的和xxs一样性能不敢测试还请各位大佬包容

目前已知问题是:

域名不存在时可能出现BUG