本文实例讲述了PHP云打印类。分享给大家供大家参考,具体如下:
一个项目需求要几百台电脑都有打印功能,本来是想用网络打印机的,后来发现没有网络打印机,就自己动手写一个打印类算了。
类实现想法是:先把要打印的数据都收集起来,在用js调用window打印函数。目前就使用于IE。
类提供打印排队功能。(PS,说白了就是一条一条读取数据)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
class Wprint{ //收集打印代码 private $data = array (); //处理打印代码 private $handle ; public function __construct() { header( "Content-type:text/html;charsetutf-8" ); $this ->link(); //链接数据库 $this ->collect( $_POST [ "username" ], $_POST [ "content" ], $_POST [ "ip" ]); $this ->handle(); } //链接数据库 private function link() { $link = mysql_connect( 'localhost' , 'root' , '123456' ); mysql_select_db( 'shen' , $link ); mysql_query( 'SET NAMES utf8' ); } //收集打印代码 private function collect( $username , $content , $ip ) { $code [ "username" ] = $username ; $code [ "content" ] = $this ->check( $content ); $code [ "ip" ] = $ip ; $code [ "state" ] = 0; $code [ "priority" ] = 0; array_push ( $this ->data, $code ); //数据节点入栈 } //处理打印代码入库 private function handle() { foreach ( $this ->data as $value ) { $sql = "insert into print (username,content,ip,state,priority) values( '{$value["username"]}' , '{$value["content"]}' , '{$value["ip"]}' , '{$value["state"]}' , '{$value["priority"]}' )"; $query = mysql_query( $sql ); if ( $query ) { $id = mysql_insert_id(); //获取最近insert操作得到的ID echo "数据收集成功,正在排队打印,排队ID为" . $id ; $this ->num( $id ); } else { echo "数据收集失败,请3秒后再一次提交" ; } } } //检查传人数据是否为空 private function check( $string ) { if ( strlen ( $string ) == 0 || $string == " " ) { echo "数据收集失败,打印内容为空" ; exit ; } else { return $string ; } } //获取打印排队人数 private function num( $id ) { $sql = "select id from print where state=0 and id<" . $id . " order by id asc" ; $query = mysql_query( $sql ); $num = mysql_num_rows( $query ); echo ",您前面还有" . $num . "个人在排队" ; } //打印数据 public function Yprint() { $sql = "select id,content from print where state=0 order by id asc limit 1" ; $query = mysql_query( $sql ); $row = mysql_fetch_array( $query ); if (! empty ( $row [ "content" ])) { echo "<script tyle=\"text/javascript\"> window. print (); </script>"; $id = $row [ "id" ]; $sql = "update print set state=1 where id=" . $id ; mysql_query( $sql ); echo "打印处理完成" ; } else { echo $row [ "content" ]; } } } |
思想很简单,收集数据再一个一个处理。 这样就不仅解决了网络打印的问题,还避免了网络打印打印过程排队的问题。
希望本文所述对大家PHP程序设计有所帮助。