codePrinter
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的更多相关文章
随机推荐
- lob结构
lob是什么? 从网上查了好多资料没找到,最后还是同事给我找到了. lob他是这样解释的:LOB专门存储大型对象数据的,类型text.image这些数据类型的数据就是存储在LOB页面 LOB_DATA ...
- httpModules与Http模块
httpModules是往当前应用程序添加HttpModule(http模块)的标签.配置节如下 <httpModules> <add name="ModuleName&q ...
- Mybatis框架中实现双向一对多关系映射
学习过Hibernate框架的伙伴们很容易就能简单的配置各种映射关系(Hibernate框架的映射关系在我的blogs中也有详细的讲解),但是在Mybatis框架中我们又如何去实现 一对多的关系映射呢 ...
- IP地址分类
- webapi 中的本地登录
WebApi 身份验证方式 asp.net WebApi 中有三种身份验证方式 个人用户账户.用户可以在网站注册,也可以使用 google, facebook 等外部服务登录. 工作和学校账户.使用活 ...
- JavaWeb之CSS详解
CSS的简介 1.CSS概述及作用 CSS:Cascading Style Sheets)是层叠样式表用来定义网页的显示效果.可以解决html代码对样式定义的重复,提高了后期样式代码的可维护性,并增强 ...
- 自定义JsonResult解决 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用
接上篇的问题,给出我自己的解决方案. 同时推荐要学习MVC的可以参考下<ASP.NET MVC4 框架揭秘>. 首先,要自定义JSonResult,就要明白MVC中 JsonResult的 ...
- 移动端全兼容的flexbox速成班
说起flexbox,都算是件陈年旧事了,它是2009年W3C提出的一种全新的可伸缩的CSS布局方式.依赖flexbox,我们可以更简单,高效的完成可伸缩式页面的布局. 业界与flexbox的相关教程文 ...
- css(二)
本文是一些作者在长期写代码中总结的常用css查询,写在本博客中,方便以后查询. 1. 颜色属性: color HEX(十六进制色:color: #FFFF00 --> 缩写:#FF0) RG ...
- 使用原生JS实现一个风箱式的demo,并封装了一个运动框架
声明,该DEMO依托于某个培训机构中,非常感谢这个培训结构.话不多说,现在开始改demo的制作. 首先,在前端的学习过程中,轮播图是我们一定要学习的,所以为了更加高效的实现各种轮播图,封装了一个运动的 ...