This project implements a subset of Epson's ESC/POS protocol for thermal receipt printers. It allows you to generate and print receipts with basic formatting, cutting, and barcodes on a compatible printer.
The library was developed to add drop-in support for receipt printing to any PHP app, including web-based point-of-sale (POS) applications.
This driver is known to work with the following OS/interface combinations:
 | Linux | Mac | Windows |
---|---|---|---|
Ethernet | Yes | Yes | Yes |
USB | Yes | Not tested | Yes |
USB-serial | Yes | Yes | Yes |
Serial | Yes | Yes | Yes |
Parallel | Yes | Not tested | Yes |
SMB shared | Yes | No | Yes |
CUPS hosted | Yes | Yes | No |
Many thermal receipt printers support ESC/POS to some degree. This driver has been known to work with:
- Bixolon SRP-350III
- Citizen CBM1000-II
- EPOS TEP 220M
- Epson TM-T88III
- Epson TM-T88IV
- Epson TM-T70
- Epson TM-T82II
- Epson TM-T20
- Epson TM-T70II
- Epson TM-U220
- Epson FX-890 (requires
feedForm()
to release paper). - Excelvan HOP-E58 (connect through powered hub)
- Okipos 80 Plus III
- P-822D
- P85A-401 (make unknown)
- SEYPOS PRP-300 (Also marketed as TYSSO PRP-300)
- Silicon SP-201 / RP80USE
- Star TSP-650
- Star TUP-592
- Xprinter XP-Q800
- Zijang NT-58H
- Zijang ZJ-5870
- Zijang ZJ-5890T (Marketed as POS 5890T)
If you use any other printer with this code, please let us know so that it can be added to the list.
If you are using composer, then add mike42/escpos-php
as a dependency:
composer require mike42/escpos-php
In this case, you would include composer's auto-loader at the top of your source files:
<?php
require __DIR__ . '/vendor/autoload.php';
If you don't have composer available, then simply download the code and include autoload.php
:
git clone https://github.com/mike42/escpos-php vendor/mike42/escpos-php
<?php
require __DIR__ . '/vendor/mike42/escpos-php/autoload.php');
To make use of this driver, your server (where PHP is installed) must be able to communicate with your printer. Start by generating a simple receipt and sending it to your printer using the command-line.
<?php
/* Call this file 'hello-world.php' */
require __DIR__ . '/vendor/autoload.php';
use Mike42\Escpos\PrintConnectors\FilePrintConnector;
use Mike42\Escpos\Printer;
$connector = new FilePrintConnector("php://stdout");
$printer = new Printer($connector);
$printer -> text("Hello World!\n");
$printer -> cut();
$printer -> close();
Some examples are below for common interfaces.
Communicate with a printer with an Ethernet interface using netcat
:
php hello-world.php | nc 10.x.x.x. 9100
A USB local printer connected with usblp
on Linux has a device file (Includes USB-parallel interfaces):
php hello-world.php > /dev/usb/lp0
A computer installed into the local cups
server is accessed through lp
or lpr
:
php hello-world.php > foo.txt
lpr -o raw -H localhost -P printer foo.txt
A local or networked printer on a Windows computer is mapped in to a file, and generally requires you to share the printer first:
php hello-world.php > foo.txt
net use LPT1 \\server\printer
copy foo.txt LPT1
del foo.txt
```
If you have troubles at this point, then you should consult your OS and printer system documentation to try to find a working print command.
### Using a PrintConnector
To print receipts from PHP, use the most applicable [PrintConnector](https://github.com/mike42/escpos-php/tree/master/src/Mike42/Escpos/PrintConnectors) for your setup. The connector simply provides the plumbing to get data to the printer.
For example, a `NetworkPrintConnector` accepts an IP address and port:
````php
use Mike42\Escpos\PrintConnectors\NetworkPrintConnector;
use Mike42\Escpos\Printer;
$connector = new NetworkPrintConnector("10.x.x.x", 9100);
$printer = new Printer($connector);
try {
// ... Print stuff
} finally {
$printer -> close();
}
While a serial printer might use:
use Mike42\Escpos\PrintConnectors\FilePrintConnector;
use Mike42\Escpos\Printer;
$connector = new FilePrintConnector("/dev/ttyS0");
$printer = new Printer($connector);
For each OS/interface combination that's supported, there are examples in the compatibility section of how a PrintConnector
would be constructed. If you can't get a PrintConnector
to work, then be sure to include the working print command in bug.
Support for commands and code pages varies between printer vendors and models. By default, the driver will accept UTF-8, and output commands that are suitable for Epson TM-series printers.
When trying out a new brand of printer, it's a good idea to use the SimpleCapabilityProfile
, which instructs the driver to avoid the use of advanced features (generally simpler image handling, ASCII-only text).
use Mike42\Escpos\PrintConnectors\FilePrintConnector;
use Mike42\Escpos\CapabilityProfiles\SimpleCapabilityProfile;
$connector = new WindowsPrintConnector("smb://computer/printer");
$printer = new Printer($connector, $profile);
As another example, Star-branded printers use different commands:
use Mike42\Escpos\PrintConnectors\FilePrintConnector;
use Mike42\Escpos\CapabilityProfiles\StarCapabilityProfile;
$connector = new WindowsPrintConnector("smb://computer/printer");
$printer = new Printer($connector, $profile);
Further developing this mechanism is a priority for future releases.
On Linux, your printer device file will be somewhere like /dev/lp0
(parallel), /dev/usb/lp1
(USB), /dev/ttyUSB0
(USB-Serial), /dev/ttyS0
(serial).
On Windows, the device files will be along the lines of LPT1
(parallel) or COM1
(serial). Use the WindowsPrintConnector
to tap into system printing on Windows (eg. Windows USB, SMB or Windows LPT) - this submits print jobs via a queue rather than communicating directly with the printer.
A complete real-world receipt can be found in the code of Auth in ReceiptPrinter.php. It includes justification, boldness, and a barcode.
Other examples are located in the example/ directory.
Construct new print object.
Parameters:
PrintConnector $connector
: The PrintConnector to send data to.AbstractCapabilityProfile $profile
Supported features of this printer. If not set, the DefaultCapabilityProfile will be used, which is suitable for Epson printers.
See example/interface/ for ways to open connections for different platforms and interfaces.
Print a barcode.
Parameters:
string $content
: The information to encode.int $type
: The barcode standard to output. If not specified,Printer::BARCODE_CODE39
will be used.
Currently supported barcode standards are (depending on your printer):
BARCODE_UPCA
BARCODE_UPCE
BARCODE_JAN13
BARCODE_JAN8
BARCODE_CODE39
BARCODE_ITF
BARCODE_CODABAR
Note that some barcode standards can only encode numbers, so attempting to print non-numeric codes with them may result in strange behaviour.
See graphics() below.
Cut the paper.
Parameters:
int $mode
: Cut mode, eitherPrinter::CUT_FULL
orPrinter::CUT_PARTIAL
. If not specified,Printer::CUT_FULL
will be used.int $lines
: Number of lines to feed before cutting. If not specified, 3 will be used.
Print and feed line / Print and feed n lines.
Parameters:
int $lines
: Number of lines to feed
Some printers require a form feed to release the paper. On most printers, this command is only useful in page mode, which is not implemented in this driver.
Print and reverse feed n lines.
Parameters:
int $lines
: number of lines to feed. If not specified, 1 line will be fed.
Print an image to the printer.
Parameters:
EscposImage $img
: The image to print.int $size
: Output size modifier for the image.
Size modifiers are:
IMG_DEFAULT
(leave image at original size)IMG_DOUBLE_WIDTH
IMG_DOUBLE_HEIGHT
A minimal example:
<?php
$img = EscposImage::load("logo.png");
$printer -> graphics($img);
See the example/ folder for detailed examples.
The function bitImage() takes the same parameters, and can be used if your printer doesn't support the newer graphics commands. As an additional fallback, the bitImageColumnFormat()
function is also provided.
Initialize printer. This resets formatting back to the defaults.
Generate a pulse, for opening a cash drawer if one is connected. The default settings (0, 120, 240) should open an Epson drawer.
Parameters:
int $pin
: 0 or 1, for pin 2 or pin 5 kick-out connector respectively.int $on_ms
: pulse ON time, in milliseconds.int $off_ms
: pulse OFF time, in milliseconds.
Print the given data as a QR code on the printer.
string $content
: The content of the code. Numeric data will be more efficiently compacted.int $ec
Error-correction level to use. One ofPrinter::QR_ECLEVEL_L
(default),Printer::QR_ECLEVEL_M
,Printer::QR_ECLEVEL_Q
orPrinter::QR_ECLEVEL_H
. Higher error correction results in a less compact code.int $size
: Pixel size to use. Must be 1-16 (default 3)int $model
: QR code model to use. Must be one ofPrinter::QR_MODEL_1
,Printer::QR_MODEL_2
(default) orPrinter::QR_MICRO
(not supported by all printers).
Select print mode(s).
Parameters:
int $mode
: The mode to use. Default isPrinter::MODE_FONT_A
, with no special formatting. This has a similar effect to runninginitialize()
.
Several MODE_* constants can be OR'd together passed to this function's $mode
argument. The valid modes are:
MODE_FONT_A
MODE_FONT_B
MODE_EMPHASIZED
MODE_DOUBLE_HEIGHT
MODE_DOUBLE_WIDTH
MODE_UNDERLINE
Set barcode height.
Parameters:
int $height
: Height in dots. If not specified, 8 will be used.
Select print color - on printers that support multiple colors.
Parameters:
int $color
: Color to use. Must be eitherPrinter::COLOR_1
(default), orPrinter::COLOR_2
Turn double-strike mode on/off.
Parameters:
boolean $on
: true for double strike, false for no double strike.
Turn emphasized mode on/off.
Parameters:
boolean $on
: true for emphasis, false for no emphasis.
Select font. Most printers have two fonts (Fonts A and B), and some have a third (Font C).
Parameters:
int $font
: The font to use. Must be eitherPrinter::FONT_A
,Printer::FONT_B
, orPrinter::FONT_C
.
Select justification.
Parameters:
int $justification
: One ofPrinter::JUSTIFY_LEFT
,Printer::JUSTIFY_CENTER
, orPrinter::JUSTIFY_RIGHT
.
Set black/white reverse mode on or off. In this mode, text is printed white on a black background.
Parameters:
boolean $on
: True to enable, false to disable.
Set the size of text, as a multiple of the normal size.
Parameters:
int $widthMultiplier
: Multiple of the regular height to use (range 1 - 8).int $heightMultiplier
: Multiple of the regular height to use (range 1 - 8).
Set underline for printed text.
Parameters:
int $underline
: Eithertrue
/false
, or one ofPrinter::UNDERLINE_NONE
,Printer::UNDERLINE_SINGLE
orPrinter::UNDERLINE_DOUBLE
. Defaults toPrinter::UNDERLINE_SINGLE
.
Add text to the buffer. Text should either be followed by a line-break, or feed()
should be called after this.
Parameters:
string $str
: The string to print.
Posts I've written up for people who are learning how to use receipt printers:
- What is ESC/POS, and how do I use it?, which documents the output of test.php.
- Setting up an Epson receipt printer
- Getting a USB receipt printer working on Linux
This code is MIT licensed, and you are encouraged to contribute any modifications back to the project.
For development, it's suggested that you load imagick
, gd
and Xdebug
PHP modules, and install composer
.
The tests are executed on Travis CI over PHP 5.3, 5.4, 5.5, 5.7, 7, and HHVM. Earlier versions of PHP are not supported.
Fetch a copy of this code and load idependencies with composer:
git clone https://github.com/mike42/escpos-php
cd escpos-php/
composer install
Execute unit tests via phpunit
:
php vendor/bin/phpunit --configuration test/phpunit.xml --coverage-text
This project uses the PSR-2 standard, which can be checked via PHP_CodeSniffer:
php vendor/bin/phpcs --standard=psr2 src/ -n
Pull requests and bug reports welcome.