前言 在之前的博客中我介紹瞭如何實現生產現場的條碼列印,我們的生活中到處都是條碼,一維碼、二維碼隨處可見,更別說一家從事生產製造加工的工廠了,而條碼種類繁多、離線列印等情況就直接導致了條碼管控上的難度,甚至會出現較為嚴重的品質事件,上一個版本中我是通過Web應用程式調用 WinForm 中的函數進行 ...
前言
在之前的博客中我介紹瞭如何實現生產現場的條碼列印,我們的生活中到處都是條碼,一維碼、二維碼隨處可見,更別說一家從事生產製造加工的工廠了,而條碼種類繁多、離線列印等情況就直接導致了條碼管控上的難度,甚至會出現較為嚴重的品質事件,上一個版本中我是通過Web應用程式調用 WinForm 中的函數進行列印,WinForm中嵌套了 WebBrowser 來瀏覽網頁,通過這幾年的實際運用,這個方法基本能夠滿足大部分需求,但還是美中不足,由於 WebBrowser 所示用的瀏覽器內核比較低,導致很多樣式無法相容,儘管網路上有一些方法去改變這個問題(比如webkit,cef,修改註冊表等等),但總是或多或少有一些問題。
新的方案,告別 WinForm & WebBrowser
我們本次以生產線 卡通包裝 工位為例,進行描述:
通常情況下,操作員會掃描多個彩盒條碼,這個掃描的數量一個到多個不等,每一個彩盒上面都有一個唯一的條形碼或二維碼,當彩盒掃描完成以後需要結束裝箱,此時系統應該直接將對應的卡通標貼列印出來,操作員從印表機上撕下卡通標貼並貼於卡通箱,在此之前我們需要提前將卡通標貼的列印模板製作出來並上傳至系統中,操作界面如下,支持同一個產品列印多張標貼:
此時,我們需要編寫一個 Api 來獲取伺服器上面的模板文件以及需要列印出來的數據列表,關鍵代碼如下:
string ServerUrl = XmlHelper.GetXmlReader(path, "Config", "Server"); string Api = XmlHelper.GetXmlReader(path, "Config", "Api"); //通過 API 獲取模板文件******************************************************************* string _Btw_Url = Api + "?action=get_carton_label&carton_sn=" + _carton_sn; HttpHelper http_btw = new HttpHelper(); //創建Httphelper參數對象 HttpItem item_btw = new HttpItem() { URL = _Btw_Url,//URL必需項 ContentType = "application/json", }; HttpResult req_result_btw = http_btw.GetHtml(item_btw); string btw_str = req_result_btw.Html; JObject obj_btw = (JObject)JsonConvert.DeserializeObject(btw_str); DataTable dt = Library.JsonLib.ToDataTable(obj_btw["msg"].ToString()); //通過 API 獲取模板文件*******************************************************************
WebClient web = new WebClient(); string _Api_Url = Api + "?action=get_carton_print_list&carton_sn=" + _carton_sn; HttpHelper http_data_list = new HttpHelper(); //創建Httphelper參數對象 HttpItem item_data_list = new HttpItem() { URL = _Api_Url,//URL必需項 ContentType = "application/json", }; HttpResult req_result_data_list = http_data_list.GetHtml(item_data_list); string print_str = req_result_data_list.Html; JObject obj = (JObject)JsonConvert.DeserializeObject(print_str); string _Key = obj["msg"]["key"].ToString(); string _Value = obj["msg"]["value"].ToString(); string splitKey = "*"; string[] keys = _Key.Split(splitKey.ToCharArray(), StringSplitOptions.None); string[] values = _Value.Split(splitKey.ToCharArray(), StringSplitOptions.None); for (int i = 0; i < dt.Rows.Count; i++) { _file_url = ServerUrl + "app/cartonlabel/" + dt.Rows[i]["LABEL_FILE"].ToString(); _file_name = System.Guid.NewGuid().ToString() + "_" + dt.Rows[i]["LABEL_FILE"].ToString(); web.DownloadFile(_file_url, _directory + _file_name); _print(); }
Api 編寫完成之後我們進行發佈,發佈到本地指定一個文件夾留作備用,現在我們還差一步,那就是如何通過網頁在客戶端本地列印?大家都知道我們的網站是部署在伺服器而非客戶端本地的,但是列印的條碼必須出現在客戶端本地的印表機,此時你可以考慮通過網路共用印表機的辦法來實現,但是這種方法非常不穩定,一些安全方面的設置就足以讓你內流滿面,因此我們可以考慮使用 CassiniDev 來實現,大致思路如下:
- 新建一個批處理或者其它類型的程式。
- 在項目中引用 CassiniDev 文件至。
- 在本地new一個服務實例並啟動。
通過如下代碼即可啟動該服務:
new Server(9001, "/", System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Service"), System.Net.IPAddress.Parse("127.0.0.1"), "", 0, false, false);
在包裝之前我們將該服務啟動起來,我做了一個簡單的界面,如下圖所示:
此時,我們需要用到上一步發佈的 Api,將發佈的 Api 文件拷貝至Service目錄,這個Service目錄在這個批處理程式的根目錄下麵,至此所有的前期工作已經做完了,現在只需要調用本地這個Api 即可。 我們選擇 MO-00002 這個工單進行演示:
下麵開始掃描條碼進行包裝,該產品的包裝容量為每一個卡通箱需要包裝 4 個彩盒。
系統提示列印命令發送成功的時候,我們的印表機已經自動將標貼列印出來了,如下圖所示:
結論
相對之前的 WebBrowser,目前這種方式可以更好的相容樣式表,比如H5,再就是同一套系統不用分為網頁端與客戶端,儘管打開的是同一個網站;維護起來也要更加方便。