3天前,荆老师给了我一台打印机,让我完成省赛代码打印系统的测试。

打印机型号为 HP P1007,算是一台比较老的打印了。

本文记录了从打印机驱动安装到代码打印WEB部署的全过程

1. 安装打印机驱动

HP在linux端没有提供官方的打印机驱动,还好,在HP Linux Imaging and Printing找到了第三方驱动。

刚开始我选择手动安装,然而驱动似乎是正确安装了,但是打印机就是不工作。

后来采取的策略是先配置必要环境,再使用自动安装的脚本,具体记录如下:

必要的文件

通过如下网站进行下载:

https://sourceforge.net/projects/hplip/files/hplip/

http://www.openprinting.org/download/printdriver/auxfiles/HP/plugins/

这里我选择了最新版本 hplip-3.16.5,不过还是推荐 hplip-3.16.3

最终我们得到以下4个文件,一个安装脚本,一个插件,以及两个asc文件:

hplip-3.16.5.run
hplip-3.16.5-plugin.run
hplip-3.16.5.run.asc
hplip-3.16.5-plugin.run.asc

安装依赖

我的系统是 Ubuntu14.04 x64, 其他版本参考 这里

运行如下命令,完成依赖的安装:

sudo apt-get install --assume-yes avahi-utils libcups2 cups libcups2-dev cups-bsd cups-client libcupsimage2-dev libdbus-1-dev build-essential ghostscript openssl libjpeg-dev libsnmp-dev snmp-mibs-downloader libtool libusb-1.0.0-dev wget policykit-1 policykit-1-gnome python3-dbus python3-gi python3-dev python3-notify2 python3-imaging python3-pyqt4 gtk2-engines-pixbuf python3-dbus.mainloop.qt python3-reportlab python3-lxml libsane libsane-dev sane-utils xsane

sudo apt-get install python-dev

运行脚本

sudo chmod +x hplip-3.16.5.run
./hplip-3.16.5.run

会出现各种提示,顺着安装程序一路走下去,即可安装成功。

2. 配置Nginx+PHP+mysql环境

提升权限

sudo su

安装apt源管理工具、添加nginx和php的安装源

apt-get install python-software-properties
add-apt-repository ppa:nginx/stable
add-apt-repository ppa:ondrej/php5
apt-get update

安装mysql

apt-get install mysql-server

安装php及对mysql的支持

apt-get install php5 php5-fpm php5-mysql php-apc

安装php功能模块

apt-get install php-pear php5-dev php5-curl php5-gd php5-intl php5-imagick php5-imap php5-mcrypt php5-memcache php5-ming php5-ps php5-pspell php5-recode php5-snmp php5-sqlite php5-tidy php5-xmlrpc php5-xsl

安装nginx

apt-get install nginx

配置php

vim /etc/php5/fpm/php.ini

找到:cgi.fix_pathinfo=1

改为:cgi.fix_pathinfo=0

配置nginx

创建一个 /www 目录设置为 755 权限

mkdir /www
chmod 755 /www
vim /etc/nginx/sites-enabled/default

找到:root /usr/share/nginx/html;

改为:root /www;

找到:index index.html index.htm;

改为:index index.php index.html index.htm;

找到:location ~ .php$ { * } 区块,修改为:

 location ~ \.php$ {
try_files $uri =404;
include snippets/fastcgi-php.conf;
#
# # With php5-cgi alone:
# fastcgi_pass 127.0.0.1:9000;
# # With php5-fpm:
fastcgi_pass unix:/var/run/php5-fpm.sock;
}

解决php-fpm与nginx的小bug

vim /etc/nginx/fastcgi_params

在最后一行添加:

fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

解决nginx不能运行的问题

vim /etc/nginx/snippets/fastcgi-php.conf
删除 ``try_files`` 所在的行

重启各项服务

service php5-fpm reload
service nginx reload

测试

vim /www/index.php

输入 <?php echo phpinfo(); ?> 并保存。

打开你的浏览器访问: http://localhost,若一切正常,将输出php环境信息

3. 部署代码打印程序

将此 代码打印程序 ,复制到 /www 目录下即可。

使用浏览器访问 http://localhost/codeprinter.html 即可。

核心代码如下:

<?php

        $name = $_POST['name'];
$passwd = $_POST['passwd'];
$content = $_POST['content'];
$content = stripslashes($content);
$result = false;
$handle = fopen('namelist', 'r');
while($userinfo = fscanf($handle, "%s %s")){
list($team, $password) = $userinfo;
if($team == $name && $passwd == $password)
$result = true;
}
fclose($handle);
if(!$result){
echo "<script language=javascript>alert('team number or password is wrong!');</script>";
echo "<script language=javascript>history.back();</script>";
}else {
//phpinfo();
$filename = "./code/".$name."-".date('H-i-s');
$fp = fopen($filename, "wb");
$content = date('H-i-s')."\t\t".$name."\n\n".$content;
fwrite($fp, $content);
fclose($fp);
$command = "lpr -o prettyprint ".$filename;
system($command);
echo "<script language=javascript>alert('Your code has been printed successfully, please wait a moment!');</script>";
echo "<script language=javascript>history.back();</script>";
}
?>

最终效果如下:

4. 参考资料

ubuntu14.04安装hp laserjet p1007打印机

基于ubuntu 14搭建nginx+php+mysql环境

php5.3 fastcgi方式 安装以及和nginx整合

codePrinter的更多相关文章

随机推荐

  1. 固定在网页顶部跟随滚动条滑动而滑动的DIV层

    在一个页面放2个悬浮框,悬浮框随页面的上下滚动有上下波动的效果,最终固定在同一位置 体验效果:http://hovertree.com/texiao/jsstudy/1/ 代码如下: <!DOC ...

  2. C# 判断字符串是否是int/double

    using System.Text.RegularExpressions; /// <summary> /// 判断字符串是否是int/double /// </summary> ...

  3. 响应式WEB设计的9项基本原则

    响 应式Web设计对于解决多类型屏幕问题来说是个不错方案,但从印刷的角度来看,其却存在着很多的困难.没有固定的页面尺寸.没有毫米或英寸,没有任何物理 限制,让人感到无从下手.随着建立网站可用的各种小工 ...

  4. JQuery 快速入门

    1.要学习Jquery @首先要在需要的页面引入 <script type="text/javascript" src="jquery.js">&l ...

  5. java移位运算符

    http://www.iteye.com/topic/766461 这篇博客讲的很清楚

  6. MongoDB基础入门003--使用官方驱动操作mongo,C#

    本篇先简单介绍一下,使用官方驱动来操作MongoDB.至于MongoDB原生的增删改查语句,且等以后再慢慢学习. 一.操作MongoDB的驱动主要有两个 1.官方驱动:https://github.c ...

  7. 今天写项目时,突然发现canvas的一些公式不记得了,所以整理了一番,分享给大家。

    Canvas 标签<canvas></canvas> 默认宽300,高150,不用用Css设置宽高 获取方法var ctx = cas.getcontext("2d& ...

  8. [TypeScript] 建立与使用AMD Library

    [TypeScript] 建立与使用AMD Library 前言 使用Visual Studio开发TypeScript项目时,开发人员可以将可重用的程序代码,封装为AMD Library来提供其他开 ...

  9. 2016年4月最佳的20款 jQuery 插件推荐

    这个列表包括20个我们觉得是最有用的免费的 jQuery 插件,它们都是最具创新性和最省时省力的解决方案,很多都是现代化的设计和开发中碰到的问题的处理方案.如果你熟悉下面列出的任何插件,请与我们的读者 ...

  10. IE7浏览器窗口大小改变事件执行多次bug(转)

    var resizeTimer = null; $(window).resize(function() { if (resizeTimer) clearTimeout(resizeTimer); re ...