您的位置:首页 > 其它

365小票打印机打印接口开发文档

2016-04-26 17:08 363 查看

API开发文档

接口1:打印内容

参数说明
deviceNo打印机编号
key密钥
printContent打印内容
times固定传1
调用方式:HTTP POST
URL:http://open.printcenter.cn:8080/addOrder
返回结果:JSON字符串

----------S1小票机返回的结果有如下几种:----------
{"responseCode":0,"msg":"订单添加成功,打印完成","orderindex":"xxxxxxxxxxxxxxxxxx"}
{"responseCode":1,"msg":"订单添加成功,正在打印中","orderindex":"xxxxxxxxxxxxxxxxxx"}
{"responseCode":2,"msg":"订单添加成功,但是打印机缺纸,无法打印","orderindex":"xxxxxxxxxxxxxxxxxx"}
{"responseCode":3,"msg":"订单添加成功,但是打印机不在线","orderindex":"xxxxxxxxxxxxxxxxxx"}
----------以上情况无须再次发送订单;下面的情况需要进行错误处理----------
{"responseCode":10,"msg":"内部服务器错误;"}
{"responseCode":11,"msg":"参数不正确;"}
{"responseCode":12,"msg":"打印机未添加到服务器;"}
{"responseCode":13,"msg":"未添加为订单服务器;"}
{"responseCode":14,"msg":"订单服务器和打印机不在同一个组;"}
{"responseCode":15,"msg":"订单已经存在,不能再次打印;"}

----------USB小票机返回的结果有如下几种:----------
{"responseCode":0,"msg":"已加入打印队列"}
{"responseCode":2,"msg":"服务器处理订单失败"}

接口2:查询订单是否打印成功

参数说明
deviceNo打印机编号
key密钥
orderindex订单索引(orderindex,该值由接口一返回)
调用方式:HTTP POST
URL:http://open.printcenter.cn:8080/queryOrder
返回结果:JSON字符串

----------S1小票机返回的结果有如下几种:----------
{"responseCode":0,"msg":"打印成功"}
{"responseCode":1,"msg":"正在打印中"}
{"responseCode":2,"msg":"打印机缺纸"}
{"responseCode":3,"msg":"打印机下线"}
{"responseCode":16,"msg":"订单不存在"}

接口3:查询打印机的状态

参数说明
deviceNo打印机编号
key打印密钥
调用方式:HTTP POST
URL:http://open.printcenter.cn:8080/queryPrinterStatus
返回结果:JSON字符串

----------S1小票机返回的结果有如下几种:----------
{"responseCode":1,"msg":"打印机正常在线"}
{"responseCode":2,"msg":"打印机缺纸"}
{"responseCode":3,"msg":"打印机下线"}

代码示例

<?php
header("Content-Type: text/html;charset=utf-8");
$DEVICE_NO = '123458615';
$key = '72264';
$content = "^N1^F1\n";
$content .= "^B2 测试打印\n";
$content .= "名称      单价  数量 金额\n";
$content .= "--------------------------------\n";
$content .= "饭       1.0    1   1.0\n";
$content .= "炒饭      10.0   10  10.0\n";
$content .= "蛋炒饭     10.0   10  100.0\n";
$content .= "鸡蛋炒饭    100.0  1   100.0\n";
$content .= "番茄蛋炒饭   1000.0 1   100.0\n";
$content .= "西红柿蛋炒饭  1000.0 1   100.0\n";
$content .= "西红柿鸡蛋炒饭 100.0  10  100.0\n";
$content .= "备注:加辣\n";
$content .= "--------------------------------\n";
$content .= "^H2合计:xx.0元\n";
$content .= "^H2送货地点:广州市南沙区xx路xx号\n";
$content .= "^H2联系电话:13888888888888\n";
$content .= "^H2订餐时间:2014-08-08 08:08:08\n";
$qrlength=chr(strlen('http://www.dzist.com'));
$content .= "^Q".$qrlength."http://www.dzist.com\n";
$result = sendSelfFormatOrderInfo($DEVICE_NO, $key, 1,$content);
var_dump($result);
function sendSelfFormatOrderInfo($device_no,$key,$times,$orderInfo){ // $times打印次数
$selfMessage = array(
'deviceNo'=>$device_no,
'printContent'=>$orderInfo,
'key'=>$key,
'times'=>$times
);
$url = "http://open.printcenter.cn:8080/addOrder";
$options = array(
'http' => array(
'header' => "Content-type: application/x-www-form-urlencoded ",
'method'  => 'POST',
'content' => http_build_query($selfMessage),
),
);
$context  = stream_context_create($options);
$result = file_get_contents($url, false, $context);

return $result;
}

?>


打印机基本指令

S1小票机2.0以上版本适用

一、字体放大

命令^Nn:
该命令位于所有数据前面,用于控制打印张数,可以不加,不加默认打一张。

例如:

^N5

打印机打印测试

Print order data

****************

表示打印 5 张相同订单。

命令^Hn
该命令位于每行数据首位,用于控制此行字体纵向放大 n 倍,可以不加,不加默认不放大。

例如:

^H2 放大 2 倍

此时“放大 2 倍”这几个字会纵向放大 2 倍,效果见下图。

注意:正常大小的字体,每行最多可以打 16 个汉字或 32 个英文或数字,如果每行超过最大字数限制,会出现多出的字覆盖这行最开始的字,导致看起来乱码,所以使用该命令请确保字数在每行最大字数内,如果超过,请手动回车换行。

命令^Wn
该命令位于每行数据首位,用于控制此行字体横向放大 n 倍,可以不加,不加默认不放大。

例如:

^W2 放大 2 倍

此时“放大 2 倍”这几个字会横向放大 2 倍,效果见下图。

注意:正常大小的字体,每行最多可以打 16 个汉字或 32 个英文或数字,由于^Wn 命令会横向放大 n 倍,如果每行超过(最大字数/n)限制,会出现多出的字覆盖这行最开始的字,导致看起来乱码,所以使用该命令请确保字数在每行字数在(最大字数/n)内,如果超过,请手动回车换行。如^W4 测试打印机放大,共 7 个汉字,放大后会占用 28 个汉字的位置,已经超过每行最多 16 个汉字。

命令^Bn
该命令位于每行数据首位,用于控制此行字体横向纵向同时放大 n 倍,可以不加,不加默认不放大。

例如:

^B2 放大 2 倍

此时“放大 2 倍”这几个字会横向纵向同时放大 2 倍,效果见下图。

注意:正常大小的字体,每行最多可以打 16 个汉字或 32 个英文或数字,由于^Bn 命令会横向纵向同时放大 n 倍,如果每行超过(最大字数/n)限制,会出现多出的字覆盖这行最开始的字,导致看起来乱码,所以使用该命令请确保字数在每行字数在(最大字数/n)内,如果超过,请手动回车换行。如 ^B3 测试打印机放大,共 7 个汉字,放大后会占用 21 个汉字的位置,已经超过每行最多 16 个汉字。

效果图:



命令^Qn
该命令位于需要打印的宣传关注二维码链接首位,用于将链接自动转换成二维码,达到宣传关注的目的。n 的值为二维码链接的字符长度,用 ASCII 编码表示。此命令,可以不加,不加默认不打。

例如:

^Q +http://weixin.qq.com/r/2Eg2LkzEKRFWrQhN9123

此时 http://weixin.qq.com/r/2Eg2LkzEKRFWrQhN9123 的长度为 43,对应 ASCII 值是’+’,计算机可以自动计算长度,这里为了描述清晰,查出 43 对应的 ASCII 字符。此链接经过转换后的二维码效果见下图。



注意:此二维码最多支持 49 个字符,请不要加入中文。打印机会自动更具字符多少转换成大小不一样的二维码,智能打印在打印纸中间。使用最为广泛的就是微信公众号的关注二维码。

命令^Pn
该命令位于需要打印的动态支付二维码链接首位,用于将链接自动转换成二维码,达到支付宝等支付的目的(支付成功后,此二维码失效,即:扫描第二次不起作用)。n 的值为二维码链接的长度,用 ASCII 编码表示。此命令,可以不加,不加默认不打。

例如:

^P(https://qr.alipay.com/pmr1bs2a1i1udbumf7

此时“https://qr.alipay.com/pmr1bs2a1i1udbumf7”的长度为 40,对应 ASCII 值是’(’,计算机可以自动计算长度,这里为了描述清晰,查出 40 对应的 ASCII 字符。此链接经过转换后的支付二维码效果见下图。



注意:此动态支付二维码最多支持 49 个字符,请不要加入中文。打印机会自动更具字符多少转换成大小不一样的二维码,智能打印在打印纸中间。使用最为广泛的就是外卖或用餐结束后,结账时无需再使用现金或者刷卡浪费时间,直接使用支付宝扫描,输入密码支付完成即可,效率将非常高。

命令^On
该命令位于需要打印的动态条码(一维码)链接首位,用于将链接自动转换成扫描枪扫描的一维码,达到迅速录入的目的。n 的值为一维码的长度,用

ASCII 编码表示。此命令,可以不加,不加默认不打。

例如:

^P test12345

此时“test12345”的长度为 9,对应 ASCII 值是’ ’(水平制表符),计算机可以自动计算长度,这里为了描述清晰,查出 9 对应的 ASCII 字符。此条码转换后的效果见下图。



注意:此动态条码最多支持 13 个字符,请不要加入中文。打印机会自动更具字符多少转换成大小不一样的条码,智能打印在打印纸中间。使用最为广泛的就是物流、仓库和超市等地方,达到迅速录入或查找等应用。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: