Подтвердить что ты не робот

Невозможно выполнить печать на другом лотке с помощью IPP

Я пытаюсь распечатать документ на втором лотке с IPP (протокол интернет-печати). Я использую эту npm IPP-Library.

Но в любой момент, когда я пытаюсь распечатать документ, на моем принтере появляется сообщение о том, что мне нужно добавить бумагу в первый лоток для бумаги и вывести на консоль команду Printed: successful-ok.

var ipp = require("ipp");
var PDFDocument = require("pdfkit");
var concat = require("concat-stream");

var doc = new PDFDocument;
doc.text("Hello World");

doc.pipe(concat(function (data) {
    var printer = ipp.Printer("MY_URL");

    var file = {
        "operation-attributes-tag": {
            "requesting-user-name": "admin",
            'attributes-charset': 'utf-8',
            'attributes-natural-language': 'de'
        },
        "printer-attributes": {
            "media-col": {
                "media-source": "tray-2"
            },
        },
        data: data
    };
    printer.execute("Print-Job", file, function (err, res) {
        console.log("Printed: " + res.statusCode);
    });
}));

doc.end();

Другой вариант, который я попробовал, следующий (из здесь):

var PDFDocument = require("pdfkit");
let fs = require('fs')
var ipp = require('ipp');
var uri = "http://10.1.205.71";


var msg = new Buffer(
  '0200'+ //Version
  '000201e6d5f2'+
  '01'+ //Operation attributes tag (your information in the Operation attributes might be different)
    '47'+ //charset tag
    '0012'+ //length
    '617474726962757465732d63686172736574'+ //attributes-charset
    '0005'+ //length
    '7574662d38'+ //utf-8
    '48'+ //natural language tag
    '001b'+ //length
    '617474726962757465732d6e61747572616c2d6c616e6775616765'+//attributes-natural-language
    '0002'+//length
    '656e'+ //en
    '45'+ // URI tag
    '000b'+ //length
    '7072696e7465722d757269'+ //printer-uri
    '0012'+//length
    '687474703a2f2f31302e312e3230352e3731'+//http://10.1.205.71
    '49'+ //mimeMediaType tag
    '000f'+ //length
    '646f63756d656e742d666f726d6174'+ //document format
    '000f'+ //length
    '6170706c69636174696f6e2f706466'+ //application/pdf
  '02'+ //job attributes tag
    '34'+ //begin collection
      '0009'+ //length
      '6d656469612d636f6c'+ //media-col
      '0000'+ //value length
      '4a'+ //collection entry
      '0000'+ //name length
      '000c'+ //value length
      '6d656469612d736f75726365'+ //media-source
      '44'+ // collection entry
      '0000'+ //name length
      '0006'+ //value length
      '747261792d32'+ //tray-2
    '37'+ //end of collection
    '00000000'+ //name length and value length
  '03', 'hex');

var doc = new PDFDocument;
doc.text("Hello World");

var buffers = [];
doc.on('data', buffers.push.bind(buffers));
doc.on('end', function(){
  var buf = Buffer.concat(buffers);
  var catBuf = Buffer.concat([msg, buf]);
  ipp.request(uri, catBuf, function(err, res){
    if(err){
      return console.log(err);
    }
    console.log(JSON.stringify(res,null,2));
  });
});
doc.end();

Но тогда я получил это сообщение об ошибке:

{ 
Error
    at new IppResponseError (/Users/alex/dev/print/printing/node_modules/ipp/lib/request.js:72:17)
    at ClientRequest.<anonymous> (/Users/alex/dev/print/printing/node_modules/ipp/lib/request.js:40:8)
    at Object.onceWrapper (events.js:293:19)
    at emitOne (events.js:96:13)
    at ClientRequest.emit (events.js:191:7)
    at HTTPParser.parserOnIncomingClient [as onIncoming] (_http_client.js:522:21)
    at HTTPParser.parserOnHeadersComplete (_http_common.js:99:23)
    at Socket.socketOnData (_http_client.js:411:20)
    at emitOne (events.js:96:13)
    at Socket.emit (events.js:191:7)
  name: 'IppResponseError',
  statusCode: 400,
  message: 'Received unexpected response status 400 from the printer',
  stack: 'Error\n    at new IppResponseError (/Users/alex/dev/print/printing/node_modules/ipp/lib/request.js:72:17)\n    at ClientRequest.<anonymous> (/Users/alex/dev/print/printing/node_modules/ipp/lib/request.js:40:8)\n    at Object.onceWrapper (events.js:293:19)\n    at emitOne (events.js:96:13)\n    at ClientRequest.emit (events.js:191:7)\n    at HTTPParser.parserOnIncomingClient [as onIncoming] (_http_client.js:522:21)\n    at HTTPParser.parserOnHeadersComplete (_http_common.js:99:23)\n    at Socket.socketOnData (_http_client.js:411:20)\n    at emitOne (events.js:96:13)\n    at Socket.emit (events.js:191:7)' }
400 'response'

Мой принтер не поддерживает IPP, но я поделился им на своем Macbook, который предоставляет IPP-услугу для всех общих принтеров. Если я использую первый лоток для бумаги и там есть бумага, все хорошо, но для моего проекта также нужно печатать на других лотках.

Список атрибутов, возвращенный из списка Get-Printer-Attributes, среди других лотков второй бумаги поддерживается media-source, но только работает первый лоток.

Есть ли у кого-нибудь идея, как успешно печатать на другом лотке?

Обновление: Я также попробовал другой принтер, но я получил ту же ошибку.

Обновление 22.06.17: Оно все еще запутано и не имеет понятия, как это исправить.

4b9b3361

Ответ 1

Похоже, что этот запрос на перенос может решить проблему, с которой вы столкнулись. Пока автор ipp не смирится с запросом на перенос, вы можете обновить свой пакет npm, чтобы указать на этот патч, выполнив в каталоге проекта следующее:

npm i --save [email protected]:jaymcaliley/ipp

Ответ 2

Ответ на запрос, который вы отправляете, содержит код состояния 400 для запроса, который был выдан принтеру.

Это можно увидеть здесь в строке 30.

Это может быть вызвано конфигурацией брандмауэра или неправильной настройкой сети.

Вам нужно правильно указать URL-адрес принтера, как в этом примере, и проверить, действительно ли этот URL-адрес, и принтер отвечает на него:

  var printer = ipp.Printer("http://NPI977E4E.local.:631/ipp/printer");