生產(chǎn)制造追溯系統(tǒng)之再說(shuō)條碼打印
前言
在之前的博客中我介紹了如何實(shí)現(xiàn)生產(chǎn)現(xiàn)場(chǎng)的條碼打印,我們的生活中到處都是條碼,一維碼、二維碼隨處可見,更別說(shuō)一家從事生產(chǎn)制造加工的工廠了,而條碼種類繁多、離線打印等情況就直接導(dǎo)致了條碼管控上的難度,甚至?xí)霈F(xiàn)較為嚴(yán)重的品質(zhì)事件,上一個(gè)版本中我是通過(guò)Web應(yīng)用程序調(diào)用 WinForm 中的函數(shù)進(jìn)行打印,WinForm中嵌套了 WebBrowser 來(lái)瀏覽網(wǎng)頁(yè),通過(guò)這幾年的實(shí)際運(yùn)用,這個(gè)方法基本能夠滿足大部分需求,但還是美中不足,由于 WebBrowser 所示用的瀏覽器內(nèi)核比較低,導(dǎo)致很多樣式無(wú)法兼容,盡管網(wǎng)絡(luò)上有一些方法去改變這個(gè)問(wèn)題(比如webkit,cef,修改注冊(cè)表等等),但總是或多或少有一些問(wèn)題。
新的方案,告別 WinForm & WebBrowser
我們本次以生產(chǎn)線 卡通包裝 工位為例,進(jìn)行描述:
通常情況下,操作員會(huì)掃描多個(gè)彩盒條碼,這個(gè)掃描的數(shù)量一個(gè)到多個(gè)不等,每一個(gè)彩盒上面都有一個(gè)唯一的條形碼或二維碼,當(dāng)彩盒掃描完成以后需要結(jié)束裝箱,此時(shí)系統(tǒng)應(yīng)該直接將對(duì)應(yīng)的卡通標(biāo)貼打印出來(lái),操作員從打印機(jī)上撕下卡通標(biāo)貼并貼于卡通箱,在此之前我們需要提前將卡通標(biāo)貼的打印模板制作出來(lái)并上傳至系統(tǒng)中,操作界面如下,支持同一個(gè)產(chǎn)品打印多張標(biāo)貼:
此時(shí),我們需要編寫一個(gè) Api 來(lái)獲取服務(wù)器上面的模板文件以及需要打印出來(lái)的數(shù)據(jù)列表,關(guān)鍵代碼如下:
string ServerUrl = XmlHelper.GetXmlReader(path, "Config", "Server"); string Api = XmlHelper.GetXmlReader(path, "Config", "Api"); //通過(guò) API 獲取模板文件******************************************************************* string _Btw_Url = Api + "?action=get_carton_label&carton_sn=" + _carton_sn; HttpHelper http_btw = new HttpHelper(); //創(chuàng)建Httphelper參數(shù)對(duì)象 HttpItem item_btw = new HttpItem() { URL = _Btw_Url,//URL必需項(xiàng) 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()); //通過(guò) API 獲取模板文件*******************************************************************
WebClient web = new WebClient(); string _Api_Url = Api + "?action=get_carton_print_list&carton_sn=" + _carton_sn; HttpHelper http_data_list = new HttpHelper(); //創(chuàng)建Httphelper參數(shù)對(duì)象 HttpItem item_data_list = new HttpItem() { URL = _Api_Url,//URL必需項(xiàng) 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 編寫完成之后我們進(jìn)行發(fā)布,發(fā)布到本地指定一個(gè)文件夾留作備用,現(xiàn)在我們還差一步,那就是如何通過(guò)網(wǎng)頁(yè)在客戶端本地打???大家都知道我們的網(wǎng)站是部署在服務(wù)器而非客戶端本地的,但是打印的條碼必須出現(xiàn)在客戶端本地的打印機(jī),此時(shí)你可以考慮通過(guò)網(wǎng)絡(luò)共享打印機(jī)的辦法來(lái)實(shí)現(xiàn),但是這種方法非常不穩(wěn)定,一些安全方面的設(shè)置就足以讓你內(nèi)流滿面,因此我們可以考慮使用CassiniDev 來(lái)實(shí)現(xiàn),大致思路如下:
- 新建一個(gè)批處理或者其它類型的程序。
- 在項(xiàng)目中引用CassiniDev 文件至。
- 在本地new一個(gè)服務(wù)實(shí)例并啟動(dòng)。
通過(guò)如下代碼即可啟動(dòng)該服務(wù):
new Server(9001, "/", System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Service"), System.Net.IPAddress.Parse("127.0.0.1"), "", 0, false, false);
在包裝之前我們將該服務(wù)啟動(dòng)起來(lái),我做了一個(gè)簡(jiǎn)單的界面,如下圖所示:
此時(shí),我們需要用到上一步發(fā)布的 Api,將發(fā)布的 Api 文件拷貝至Service目錄,這個(gè)Service目錄在這個(gè)批處理程序的根目錄下面,至此所有的前期工作已經(jīng)做完了,現(xiàn)在只需要調(diào)用本地這個(gè)Api 即可。我們選擇 MO-00002 這個(gè)工單進(jìn)行演示:
下面開始掃描條碼進(jìn)行包裝,該產(chǎn)品的包裝容量為每一個(gè)卡通箱需要包裝 4 個(gè)彩盒。
系統(tǒng)提示打印命令發(fā)送成功的時(shí)候,我們的打印機(jī)已經(jīng)自動(dòng)將標(biāo)貼打印出來(lái)了,如下圖所示:
結(jié)論
相對(duì)之前的 WebBrowser,目前這種方式可以更好的兼容樣式表,比如H5,再就是同一套系統(tǒng)不用分為網(wǎng)頁(yè)端與客戶端,盡管打開的是同一個(gè)網(wǎng)站;維護(hù)起來(lái)也要更加方便。
以上所述是小編給大家介紹的生產(chǎn)制造追溯系統(tǒng)之再說(shuō)條碼打印,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Javascript正則控制文本框只能輸入整數(shù)或浮點(diǎn)數(shù)
這篇文章主要介紹Javascript正則如何控制文本框只能輸入整數(shù)或浮點(diǎn)數(shù),需要的朋友可以參考下2014-09-09JavaScript定時(shí)器setTimeout()和setInterval()詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript定時(shí)器setTimeout()和setInterval()的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08舉例講解JavaScript substring()的使用方法
這篇文章主要通過(guò)舉例的方法講解了javaScript substring()的用法,substring() 方法用于提取字符串中介于兩個(gè)指定下標(biāo)之間的字符,感興趣的小伙伴們可以參考一下2015-11-11JS request函數(shù) 用來(lái)獲取url參數(shù)
項(xiàng)目中經(jīng)常會(huì)遇到這種問(wèn)題 下面代碼解決問(wèn)題!2010-05-05Bootstrap項(xiàng)目實(shí)戰(zhàn)之首頁(yè)內(nèi)容介紹(全)
本文分為兩部分介紹Bootstrap首頁(yè)內(nèi)容介紹的實(shí)現(xiàn)代碼,感興趣的小伙伴們可以參考一下2016-04-04Javascript之旅 對(duì)象的原型鏈之由來(lái)
本人是Javascript菜鳥,下面是前幾天學(xué)習(xí)Javascript的旅程心得,希望對(duì)和我一樣的入門者有點(diǎn)用,也希望高手批評(píng)指正。2010-08-08uniapp基礎(chǔ)篇之上傳圖片的實(shí)戰(zhàn)步驟
應(yīng)用uni-app開發(fā)跨平臺(tái)App項(xiàng)目時(shí),上傳圖片、文檔等資源功能需求十分常見,下面這篇文章主要給大家介紹了關(guān)于uniapp基礎(chǔ)篇之上傳圖片的相關(guān)資料,需要的朋友可以參考下2022-12-12詳解JS鼠標(biāo)事件中clientX/screenX/offsetX/pageX屬性的區(qū)別
在熟悉業(yè)務(wù)中播放器功能的時(shí)候,發(fā)現(xiàn)時(shí)間軸上綁定了點(diǎn)擊和拖動(dòng)事件,頻繁遇到了類似pageX之類的事件屬性,所以本文就來(lái)和大家詳細(xì)聊聊clientX/screenX/offsetX/pageX等屬性的區(qū)別吧2024-03-03