View on
依瑪貓 > chklinks-3.09 > chklinks


Annotate this POD

View/Report Bugs


chklinks - A non-threaded Perl link checker


   chklinks [options] URL1 [URL2 [UR3 ...]]


chklinks is a non-threaded Perl link checker. It helps finding broken links on your website.

chklinks differs from linkchecker in that chklinks is non- threaded. It does not raises many simultaneously connections for its job. It won't run out of the resources and crash your system in a moment. This is certainly more desirable for most webmasters and users.

chklinks follows robots.txt rules. If you disallow robots from your website and experience problems, you need to allow chklinks. Add the following lines to your robots.txt file to allow chklinks:

  User-agent: chklinks

chklinks uses LWP::RobotUA(3) and support the following schemes: http, https, ftp, gopher and file. You can also specify a local file. (To use https, you need to install Crypt::SSLeay(3). This is the requirement of LWP::RobotUA(3).)

chklinks supports cookies.



Check the links on this page and stops.


Recursively check through this website. This is the default.


Only check the links below this directory. This is the default.


Trace back to the parent directories.


Only check the links on this same host.


Check the links to other hosts (without recursion). This is the default.

-e,--exclude path

Exclude this path. Check for their existence but not check the links on them, just like they are on a foreign site. Multiple --exclude are OK.

-i,--include path

Include this path. An opposite of --exclude that cancels its effect. The latter specified has a higher priority.


Display debug messages. Multiple --debug to debug more.


Disable debug messages. An opposite that cancels the effect of --debug.


Display the help message and exit.


Output version information and exit.


The URLs of the websites to check against.


chklinks does not obey Crawl-delay: in robots.txt yet. This is a problem in WWW::RobotRules(3), but not chklinks itself.

If you encounter warnings like this:

    Parsing of undecoded UTF-8 will give garbage when decoding
    entities at /usr/share/perl5/LWP/ line 114.

This is a LWP::Protocol(3) issue when working with HTML::Parser(3) version >= 3.40. See CPAN RT Bug#20274 for a LWP::Protocol(3) patch on this.


chklinks does not support authentication yet. W3C-LinkChecker have support on this. As a workaround, You can use the syntax for Basic Authentication, but this does not work on Digest Authentication. This practice is not encouraged. Your password would be visable to anyone on this system using ps, including hidden intruders. Also what you type in your shell will be saved to your shell history file.

mailto: URLs should be supported by checking the validity of its DNS/MX record. Bastian Kleineidam's linkchecker(1) have support on this.

Local file checking has only been tested on Unix and MSWin32. More platforms should be tested, especially VMS and Mac.


chklinks is hosted on SourceForge, CPAN and Tavern IMACAT's. For the latest infomation, see , , or .

chklinks has a user discussion mailing list hosted at SourceForge: . It is a mailman mailing list. For infomation on how to join or leave, see: . Alternatively, you can send a mail to: with the subject help for a list of available commands.


LWP::UserAgent(3), LWP::RobotUA(3), WWW::RobotRules(3), URI(3), HTML::LinkExtor(3), Bastian Kleineidam's linkchecker(1), W3C-LinkChecker checklink(1).


imacat <>.


Copyright (c) 2003-2007 imacat.

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see

syntax highlighting: