|
Jim, I am not certain I understand, so please forgive me.
Are you including the single quotes around the command string? The example you showed does not appear to have them:
<snip>
$cmdString = "catsplf -j {$jobNumber}/{$userName}/{$jobName}
{$spoolName} {$spoolNumber}";
</snip>
I would think you needed something like this:
$cmdString = "\'catsplf -j {$jobNumber}/{$userName}/{$jobName}
{$spoolName} {$spoolNumber}\'";
Paul
-----Original Message-----
From:web400-bounces@xxxxxxxxxxxx [mailto:web400-bounces@xxxxxxxxxxxx] On Behalf Of Jim Oberholtzer
Sent: Wednesday, June 05, 2013 7:53 AM
To: Web Enabling the IBM i (AS/400 and iSeries)
Subject: Re: [WEB400] Error on QSH call that I can't figure out
The single quote wind up being needed since the "-j" and the "/"
characters are part of the command string. Dang I thought you were on to something.
Jim Oberholtzer
Chief Technical Architect
Agile Technology Architects
On 6/4/13 6:16 PM, Jim Oberholtzer wrote:
>Excellent question, I'll check that out! That might explain the null
>response. The part that has us a bit confused is on the development
>box this code works, in the production deployment it does not work.
>
>I will go back and check the quotes to be sure.
>
>An earlier suggestion that I check plugsize did not pan out to be the
>problem.
>
>Jim Oberholtzer
>Chief Technical Architect
>Agile Technology Architects
>
>On 6/4/13 4:13 PM, Paul Therrien wrote:
>-->> >*This message was transferred with a trial version of CommuniGate(r)
>> >Pro* Do the single quotes need to surround the $cmdString?
>> >It doesn't appear that the $cmdString value has the single quotes embedded in it.
>> >
>> >
>> >Paul
>> >
>> >-----Original Message-----
>> >From:web400-bounces@xxxxxxxxxxxx >> >[mailto:web400-bounces@xxxxxxxxxxxx] On Behalf Of Jim Oberholtzer
>> >Sent: Tuesday, June 04, 2013 2:55 PM
>> >To: Web Enabling the AS400 / iSeries
>> >Subject: [WEB400] Error on QSH call that I can't figure out
>> >
>> >Folks: In the following code (PHP), we are attempting to pull in a spool file into the variable $result so we can format it and put it up on a web page. If we run the command via the PHP code we get a null in $result. If we run the command ( signed on as the same user ) from the command line it works.
>> >
>> >QSH CMD('catsplf -j 026555/KATTANASIO/H512D QPJOBLOG 2')
>> >
>> >I checked to see if the user profile had *SPLCTL and it does.
>> >
>> >Any Idea what might be going on?
>> >
>> >
>> >function i5_spool_get_data($spoolName, $jobName, $userName, $jobNumber, $spoolNumber, $fileName = '', $connection = null) {
>> > if (!$connection = verifyConnection($connection)) {
>> > return false;
>> > }
>> >
>> > if (!is_numeric($spoolNumber)) {
>> > // could be *NEXT or other misguided parameter. Use a '1' for compatibility.
>> > $connection->logThis("Spool file number value '$spoolNumber' is unsupported. Please supply a number. The value '1' will be used.");
>> > $spoolNumber = 1;
>> > }
>> >
>> > $cmdString = "catsplf -j {$jobNumber}/{$userName}/{$jobName}
>> >{$spoolName} {$spoolNumber}";
>> >**********************
>> >call making the trouble below!
>> >************************
>> > //full command will look like "QSH CMD('catsplf -j {$jobNumber}/{$userName}/{$jobName} {$spoolName} {$spoolNumber}')";
>> > $result = $connection->qshellCommand($cmdString);
>> >
>> > // if no error, we expect an array.
>> > if (is_array($result)) {
>> > // consolidate into a string with 0D0A separators
>> > $resultString = trim(implode("\r\n", $result));
>> >
>> > // if fileName provided, try to write data to the IFS file (return true if successful or false).
>> > // otherwise simply return the string.
>> > if ($fileName) {
>> >
>> > $bytesWritten = file_put_contents($fileName, $resultString);
>> > if ($bytesWritten) {
>> > // good! Wrote OK
>> > return true;
>> > } else {
>> > // bad! Could not write file. Old toolkit used CPF9898 so let's also use it.
>> > i5CpfError('CPF9898', "Could not write to file '$fileName'.");
>> > return false;
>> > } //(if bytesWritten)
>> >
>> >
>> > } else {
>> > // no IFS filename provided. Return string to caller.
>> > return $resultString;
>> > } //(if $fileName)
>> >
>> > } else {
>> > // not an array. Probably a "false."
>> > // Report the error.
>> > $errMsg = $connection->getErrorMsg();
>> > if (empty($errMsg)) {
>> > $errMsg = 'Could not read spooled file. Check user permissions or see error code for details.';
>> > }
>> > i5CpfError($connection->getErrorCode(), $errMsg);
>> > return false;
>> > } //(if is_array)
>> >
>> >
>> >} //(i5_spool_get_data)
>> >
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.