katmore / shrturl
a URL shortener webservice
Requires
- php: >=7.0.1
- ext-pdo: *
- ext-pdo_mysql: *
- ifsnop/mysqldump-php: 2.*
This package is not auto-updated.
Last update: 2024-10-26 20:21:08 UTC
README
a URL shortener webservice
Shrturl is a RESTful web service that behaves similar to enterprise level URL shortening services (such as bit.ly).
-
Latest Version:
-
Documentation
Terminology
- code or short code: the unique portion (token) contained in a short URL that serves as reference to full URL. The typically jibberish looking sequence of alpha numeric characters used in most URL shorteners.
- short url: the full URL that includes the short code (ie: http://example.com/shrt.php?code=abc)
- target url: the full URL that needs to be changed into a short URL
Installation
- extract/copy the shrturl project somewhere
git clone https://github.com/katmore/shrturl.git
cd shrturl
- create autoloader and resolve dependencies using Composer...
composer update
- run the db-install.php script...
php bin/db-install.php
- copy app/config/shrturl/mysql-sample.ini to mysql.ini and edit...
cp app/config/shrturl/mysql-sample.ini app/config/shrturl/mysql.ini vi app/config/shrturl/mysql.ini
- populate the database with initial set of randomly generated short codes...
php bin/make-codes.php 1000
Webservice Usage
-
Redirect to target URL:
https://example.com/shrt.php?code=abc
(where 'abc' is the code returned by "Shorten URL" request)
-
Display short URL, Create if it does not exist
-
POST REQUEST METHOD
https://example.com/shrt.php?target=http://my_really_long_uri
- adding a query var named 'POST' to the query string to will also invoke 'POST' (if using GET REQUEST METHOD)
https://example.com/shrt.php?POST&target=http://my_really_long_uri
- adding a query var named 'POST' to the query string to will also invoke 'POST' (if using GET REQUEST METHOD)
-
add a query var and value for 'url_base' if you want to display a short url with a base
URL other than what is configured in the 'default' section of shrt-config. A value for 'url_base' should correspond with a config var in shrt-config.php
-
POST REQUEST METHOD
https://example.com/shrt.php?target=http://my_really_long_uri&url_base=reallyshort
- would display/create: http://rlysh.rt/abc
- see example in shrt-config-example.php
[https://github.com/katmore/shrturl/blob/master/shrt-config-example.php]
-
-
Change Target URL
- POST REQUEST METHOD
https://example.com/shrt.php?changeTarget=http://a_different_really_long_uri&code=abc
- adding a query var named 'POST' to the query string to will also invoke 'POST' (if using GET REQUEST METHOD)
- POST REQUEST METHOD
-
Shorten Multiple URLs
- POST REQUEST METHOD
- where 'target' is a valid JSON document with the following structure:
{"shrt":{"target":["http://target_url_1","http://target_url_2","http://etc"]}}
- adding a query var named 'POST' to the query string to will also invoke 'POST' (if using GET REQUEST METHOD)
Webservice Deployment Suggestions
-
use 2 different FQDNs (fully qualified domain names) for this service
- FQDN #1 for 'end use' the short code, such as:
- FQDN #2 for API calls to short code service, such as:
-
for example:
- on the 'end use FQDN' (#1)
- install/configure project as described in installation section of this document
- configure a url_base in addition to the 'default'
see url_base section in shrt-config-example.php
- contains example of .htaccess or equivelent configuration for web server
- http://rlysh.rt/abc will work now
- where 'abc' is the short code provided by previous call to short API
- on the 'API FQDN' (#2) use as described in usage section
in API requests to obtain a short code ensure that: provide a url_base parameter in query that corresponds to the 'end use' that is set in your shrt-config-example.php
- on the 'end use FQDN' (#1)
Legal
Copyright
Flat webapp - https://github.com/katmore/flat-webapp
Copyright (c) 2012-2017 Doug Bird. All Rights Reserved.
License
"shrturl" is copyrighted free software.
You can redistribute it and/or modify it under either the terms and conditions of the "The MIT License (MIT)"; or the terms and conditions of the "GPL v3 License".