Posts Tagged ‘pool.com’

在pool.com上back order成功了一个域名

星期六, 12月 13th, 2008

我估计一般的程序判断域名,都不会对LNL类型的非.com/.net/.org进行提示的。因为其他的域名后缀的LNL基本上都是Reg Fee。

昨天看到pool.com上的hotlist,更肯定了我这种想法,因为我前天下的back order的w3c.us的域名榜上无名。

早上起来,手机收到一条短信,信用卡消费了$60。应该就是这个域名到手了。

上网询了一下价格,似乎中国人对.us都没什么好感,有的建议做一个教程站。当然,做站的打算应该是在这个域名无法以合适的价格卖出去为前提的。而且我也没什么时间去做个站。

目前还是先管理一下,等个经济回暖的时间再挂到SEDO之类的地方卖了吧。

有对w3c.us感兴趣的可以发邮件:polo@live.cn

pool.com拍卖的猫腻

星期一, 11月 10th, 2008

我上周在pool.com抢注的域名进入拍卖阶段 曾经进入拍卖的阶段,并且进 行叫过价。然而在拍卖结束之后,我看了一下叫价纪录,发现还是颇有猫腻的:

pool.com拍卖纪录

pool.com拍卖纪录

因为我之前看过Aution Participant List,并没有Error和NameLinker这两个强人,现在想回来,很可能是因为这些最后才叫价的角色是pool.com为了保障本站拍卖的价格底线而对域名的自我回购。

因为目前的域名估价系统,一方面是基于一些不变因素,比如域名长度,字符组成,内在含义等等,另一方面则跟当前该类型的域名的最低成交价格挂钩。当该类型域名最低成交价下跌的时候,他们手头上的大量存货估价也会下跌,所以这相当于一种救市行动。

由于短长度域名是一种稀缺资源(数万个),因此这种救市在资本充足的情况下还是可以进行的。虽然目前经济形势差。。。

pool.com抢注的域名进入拍卖阶段

星期四, 11月 6th, 2008
早上起来,收邮件,发现有两封由pool.com发来的,一封是例行公事的:Hotlist for Thursday, November 06, 2008
另一封是Your Auctions for Wednesday, November 05, 2008。
打开一看,是说前几天的一个域名的backorder有着落了,不过在pool.com上抢注的人多,需要进行拍卖:
不过这个三字母的域名虽然是.net后缀的,但是也足够吸引,所以进入拍卖阶段也是意料中的事了。
点进去一看,过了几个小时,价格已经被叫到$210了:

Total Auctions: 1

Domain Name Current Price My Bids # of Bids Close Date (GMT) Time Left

eie.net 210 USD USD 8 2008-11-08 16:02:00 2d 16h 22m

据说一般价格飙升会在拍卖临近结束前的数个小时内,姑且等那时候再看看。

在pool.com上注册了个帐号,用来backorder某些域名

星期日, 10月 19th, 2008

在上一篇里面,我做了一个更有效查询pending delete domain的页面。由于是pool.com提供的,于是也打算在pool.com上进行backorder domain的事情。

注:backorder domain就是预付款,让网站给你抢注即将删除的域名。

pool.com的注册需要信用卡信息进行付款预授权(pre-authorized),在这个注册页面上我犹豫了半天,搜索了一些关于pool.com注册的事情,经验是:

1.中国信用卡不一定能被接受

2.预授权是60美金,并不是当场扣,而是从额度里面hold住,总额度少了60美金

我有mastercard和visa,由于visa一般用来做外币交易,所以这次也用visa卡了。注册顺利完成,手机就来了短信,说我消费了60美元……于是连忙上去信用卡的网站上查,果然没有交易,而是额度扣了60美元。

于是等激活邮件,激活帐号,然后对心仪的域名进行backorder。

pool.com这类型的网站跟很多域名注册商都有协议,到时候各个域名注册商都去抢注域名,抢到的时候就交给pool.com。由于参与抢注的注册商比较多,所以成功的几率也高了。

由于时差的关系,一个域名虽然说是某一天删除,然而到底是哪个时间,要看具体注册的时区而定。所以18号掉下来的域名,一般要到19号凌晨3、4点才能抢注。

做了一个deleting domain的查询页面

星期五, 10月 17th, 2008

查询表格位于:

http://www.pjoke.com/tools/domain/deletingdomain.html

这个待删除的域名数据来自pool.comPending Delete List页面。页面上有下载链接http://www.pool.com/Downloads/PoolDeletingDomainsList.zip

是一个zip文件。这个文件是每日更新的,所以要做的事情是:

  1. 下载这个zip文件
  2. 解压这个zip文件
  3. 读文件中的数据,存储到数据库中
  4. 做数据库的查询页面
  5. 将上述1~3的程序设置成cron,每日定时运行

包含123步的php文件:

第一步,下载:

copy(”http://pool.com/Downloads/PoolDeletingDomainsList.zip”, “pool.zip”);

第二步,解压,这里使用faisun提供的程序里面的unzip类,稍作改动:

class zip
{
var $total_files = 0;
var $total_folders = 0;

function Extract ( $zn, $to, $index = Array(-1) )
{
$ok = 0; $zip = @fopen($zn,’rb’);
if(!$zip) return(-1);
$cdir = $this->ReadCentralDir($zip,$zn);
$pos_entry = $cdir['offset'];

if(!is_array($index)){ $index = array($index); }
for($i=0; $index[$i];$i++){
if(intval($index[$i])!=$index[$i]||$index[$i]>$cdir['entries'])
return(-1);
}
for ($i=0; $i<$cdir['entries']; $i++)
{
@fseek($zip, $pos_entry);
$header = $this->ReadCentralFileHeaders($zip);
$header['index'] = $i; $pos_entry = ftell($zip);
@rewind($zip); fseek($zip, $header['offset']);
if(in_array(”-1″,$index)||in_array($i,$index))
$stat[$header['filename']]=$this->ExtractFile($header, $to, $zip);
}
fclose($zip);
return $stat;
}

function ReadFileHeader($zip)
{
$binary_data = fread($zip, 30);
$data = unpack(’vchk/vid/vversion/vflag/vcompression/vmtime/vmdate/Vcrc/Vcompressed_size/Vsize/vfilename_len/vextra_len’, $binary_data);

$header['filename'] = fread($zip, $data['filename_len']);
if ($data['extra_len'] != 0) {
$header['extra'] = fread($zip, $data['extra_len']);
} else { $header['extra'] = ”; }

$header['compression'] = $data['compression'];$header['size'] = $data['size'];
$header['compressed_size'] = $data['compressed_size'];
$header['crc'] = $data['crc']; $header['flag'] = $data['flag'];
$header['mdate'] = $data['mdate'];$header['mtime'] = $data['mtime'];

if ($header['mdate'] && $header['mtime']){
$hour=($header['mtime']&0xF800)>>11;$minute=($header['mtime']&0×07E0)>>5;
$seconde=($header['mtime']&0×001F)*2;$year=(($header['mdate']&0xFE00)>>9)+1980;
$month=($header['mdate']&0×01E0)>>5;$day=$header['mdate']&0×001F;
$header['mtime'] = mktime($hour, $minute, $seconde, $month, $day, $year);
}else{$header['mtime'] = time();}

$header['stored_filename'] = $header['filename'];
$header['status'] = “ok”;
return $header;
}

function ReadCentralFileHeaders($zip){
$binary_data = fread($zip, 46);
$header = unpack(’vchkid/vid/vversion/vversion_extracted/vflag/vcompression/vmtime/vmdate/Vcrc/Vcompressed_size/Vsize/vfilename_len/vextra_len/vcomment_len/vdisk/vinternal/Vexternal/Voffset’, $binary_data);

if ($header['filename_len'] != 0)
$header['filename'] = fread($zip,$header['filename_len']);
else $header['filename'] = ”;

if ($header['extra_len'] != 0)
$header['extra'] = fread($zip, $header['extra_len']);
else $header['extra'] = ”;

if ($header['comment_len'] != 0)
$header['comment'] = fread($zip, $header['comment_len']);
else $header['comment'] = ”;

if ($header['mdate'] && $header['mtime'])
{
$hour = ($header['mtime'] & 0xF800) >> 11;
$minute = ($header['mtime'] & 0×07E0) >> 5;
$seconde = ($header['mtime'] & 0×001F)*2;
$year = (($header['mdate'] & 0xFE00) >> 9) + 1980;
$month = ($header['mdate'] & 0×01E0) >> 5;
$day = $header['mdate'] & 0×001F;
$header['mtime'] = mktime($hour, $minute, $seconde, $month, $day, $year);
} else {
$header['mtime'] = time();
}
$header['stored_filename'] = $header['filename'];
$header['status'] = ‘ok’;
if (substr($header['filename'], -1) == ‘/’)
$header['external'] = 0×41FF0010;
return $header;
}

function ReadCentralDir($zip,$zip_name){
$size = filesize($zip_name);

if ($size < 277) $maximum_size = $size;
else $maximum_size=277;

@fseek($zip, $size-$maximum_size);
$pos = ftell($zip); $bytes = 0×00000000;

while ($pos < $size){
$byte = @fread($zip, 1); $bytes=($bytes << 8) | ord($byte);
if ($bytes == 0×504b0506 or $bytes == 0×2e706870504b0506){ $pos++;break;} $pos++;
}

$fdata=fread($zip,18);

$data=@unpack(’vdisk/vdisk_start/vdisk_entries/ventries/Vsize/Voffset/vcomment_size’,$fdata);

if ($data['comment_size'] != 0) $centd['comment'] = fread($zip, $data['comment_size']);
else $centd['comment'] = ”;
$centd['entries'] = $data['entries'];
$centd['disk_entries'] = $data['disk_entries'];
$centd['offset'] = $data['offset'];$centd['disk_start'] = $data['disk_start'];
$centd['size'] = $data['size']; $centd['disk'] = $data['disk'];
return $centd;
}

function ExtractFile($header,$to,$zip){
$header = $this->readfileheader($zip);

if(substr($to,-1)!=”/”) $to.=”/”;
if($to==’./’) $to = ”;
$pth = explode(”/”,$to.$header['filename']);
$mydir = ”;
for($i=0;$i<count($pth)-1;$i++){
if(!$pth[$i]) continue;
$mydir .= $pth[$i].”/”;
if((!is_dir($mydir) && @mkdir($mydir,0777)) || (($mydir==$to.$header['filename'] || ($mydir==$to && $this->total_folders==0)) && is_dir($mydir)) ){
@chmod($mydir,0777);
$this->total_folders ++;
echo “<input name=’dfile[]‘ type=’checkbox’ value=’$mydir’ checked> <a href=’$mydir’ target=’_blank’>Dir: $mydir</a><br>”;
}
}

if(strrchr($header['filename'],’/')==’/') return;

if (!($header['external']==0×41FF0010)&&!($header['external']==16)){
if ($header['compression']==0){
$fp = @fopen($to.$header['filename'], ‘wb’);
if(!$fp) return(-1);
$size = $header['compressed_size'];

while ($size != 0){
$read_size = ($size < 2048 ? $size : 2048);
$buffer = fread($zip, $read_size);
$binary_data = pack(’a’.$read_size, $buffer);
@fwrite($fp, $binary_data, $read_size);
$size -= $read_size;
}
fclose($fp);
touch($to.$header['filename'], $header['mtime']);
}else{
$fp = @fopen($to.$header['filename'].’.gz’,'wb’);
if(!$fp) return(-1);
$binary_data = pack(’va1a1Va1a1′, 0×8b1f, Chr($header['compression']),
Chr(0×00), time(), Chr(0×00), Chr(3));

fwrite($fp, $binary_data, 10);
$size = $header['compressed_size'];

while ($size != 0){
$read_size = ($size < 1024 ? $size : 1024);
$buffer = fread($zip, $read_size);
$binary_data = pack(’a’.$read_size, $buffer);
@fwrite($fp, $binary_data, $read_size);
$size -= $read_size;
}

$binary_data = pack(’VV’, $header['crc'], $header['size']);
fwrite($fp, $binary_data,8); fclose($fp);

$gzp = @gzopen($to.$header['filename'].’.gz’,'rb’) or die(”Cette archive est compress閑”);
if(!$gzp) return(-2);
$fp = @fopen($to.$header['filename'],’wb’);
if(!$fp) return(-1);
$size = $header['size'];

while ($size != 0){
$read_size = ($size < 2048 ? $size : 2048);
$buffer = gzread($gzp, $read_size);
$binary_data = pack(’a’.$read_size, $buffer);
@fwrite($fp, $binary_data, $read_size);
$size -= $read_size;
}
fclose($fp); gzclose($gzp);

touch($to.$header['filename'], $header['mtime']);
@unlink($to.$header['filename'].’.gz’);

}
}

$this->total_files ++;
echo “<input name=’dfile[]‘ type=’checkbox’ value=’$to$header[filename]‘ checked> <a href=’$to$header[filename]‘ target=’_blank’>File: $to$header[filename]</a><br>”;

return true;
}

// end class
}

$z = new Zip;
$result=$z->Extract(”pool.zip”,”./pool/”); //解压到./pool/目录下

第三步,读解开的文件,并插入到数据库中:

$filename = “./pool/PoolDeletingDomainsList.txt”;

if (!file_exists($filename)) exit;

$fp = fopen($filename, “r”);

if ($fp) {
$jkdb->query(”truncate pooldrop”);//$jkdb是一个数据库操作类的实例
$i = 0;
$tmpstr = “”;
while ($buffer = fgets($fp, 256)) {
$res = tproceed($buffer);
if ($i % 100 != 0) $tmpstr .= “,”;
$tmpstr .= $res;
$i = $i + 1;
if ($i % 100 == 0) { //每100行的数据,执行一次数据库插入,表名为pooldrop, name是域名,type是域名后缀,date是删除日期
$sqlstr = “insert into pooldrop (`name`, `type`, `date`) values “.$tmpstr;
$jkdb->query($sqlstr);
$tmpstr = “”;
}
}
if ($i % 100 != 0) {
$sqlstr = “insert into pooldrop (`name`, `type`, `date`) values “.$tmpstr;
$jkdb->query($sqlstr);
}
echo $i.” records”;
fclose($fp);
}

function tproceed($buf) {
$pat = ‘/(.*)\.([a-z]{2,4})\,([0-9]{2})\/([0-9]{2})\/([0-9]{4})\,([a-zA-Z]*)/i’;//提取每行的相关数据
preg_match_all($pat, $buf, $m);

return “(’”.$m[1][0].”‘,’”.$m[2][0].”‘,’”.$m[5][0].$m[3][0].$m[4][0].”‘)”;
}

太晚了,明天再写数据库查询部分。之所以要自己把数据抓下来再查询,是因为pool.com所提供的查询页面限制条件实在太少。

第四,简单做了个查询页面:

http://www.pjoke.com/tools/domain/deletingdomain.html

功能:

1.指定查询的域名后缀

2.指定域名中是否包含连接符“-”

3.指定域名中是否包含数字0-9

4.指定域名的最大长度和最小长度

5.指定域名中是否包含关键词,且关键词的位置分别在开头/结尾/任意位置

第五,在godaddy的cron里面将这个php设置成每天运行一次。
到此,基本上完成了。