本發(fā)明涉及計算機軟件領域,更具體而言,涉及一種軟件授權方法,尤其涉及一種適用于產(chǎn)線程序的授權方法。
背景技術:
隨著計算機技術的發(fā)展,計算機軟件的種類越來越多,功能也越來越強大。軟件開發(fā)商為了保護自己開發(fā)的軟件只有在被授權的前提下才能正常使用,通常會采用單機驗證、硬件綁定或網(wǎng)絡激活的方式進行授權。
具體而言,單機驗證是指在第一次使用時要求輸入正確的用戶密碼,用戶密碼與用戶名相關,用戶只要保留好已購買的用戶名和用戶密碼,就可以無限制使用軟件。硬件綁定是指在第一次使用時,軟件會根據(jù)用戶機器計算出一個硬件識別碼,軟件開發(fā)商根據(jù)這個硬件識別碼產(chǎn)生注冊序列號,用戶只有輸入與本機硬件識別碼相匹配的注冊序列號,才能正常使用軟件。網(wǎng)絡激活是指軟件在第一次使用時必須計算機聯(lián)網(wǎng)或電話激活,才能完成整個軟件的注冊與激活流程。
上述三種方式適用于對軟件的每一份拷貝都能做到授權保護,確保用戶在沒有得到授權的情況下,就算用戶拿到了軟件拷貝,都無法正常使用軟件。但是,某些軟件(如產(chǎn)線程序)是隨操作系統(tǒng)母盤一起分發(fā)的,要求做到一次激活,任意多個拷貝無限制運行。比如,產(chǎn)線程序的授權問題應該是在母盤制作階段,而不是在對產(chǎn)線上的每一臺計算機進行檢測之時,因為產(chǎn)線流程最重要的因素就是效率,如果每個測試人員在啟動產(chǎn)線程序時,都必須輸入用戶名和用戶密碼以激活測試程序的話,無疑會大大降低生產(chǎn)效率。因此,產(chǎn)線程序的授權既要保護軟件開發(fā)商的軟件版權,又不能影響產(chǎn)線程序的生產(chǎn)效率。
然而,現(xiàn)有的軟件授權方法還不能一次性解決多個軟件拷貝的軟件授權問題,從而導致某些軟件(如產(chǎn)線程序)的生產(chǎn)效率低下。
因此,如何在保護軟件開發(fā)商的軟件版權的前提下,提高某些軟件(如產(chǎn)線程序)的生產(chǎn)效率,也成為本領域技術人員亟需解決的技術問題。
技術實現(xiàn)要素:
鑒于此,本發(fā)明提出了一種軟件授權方法,以在保護軟件開發(fā)商的軟件版權的前提下,提高某些軟件(如產(chǎn)線程序)的生產(chǎn)效率。
本發(fā)明提出的一種軟件授權方法,包括如下步驟:
S10:在軟件首次使用時通過密碼激活,并在所述軟件激活成功后生成許可證文件,所述許可證文件記錄了所述軟件的有效期限或剩余的有效天數(shù);
S20:在有效期限內(nèi)或剩余的有效天數(shù)大于0時,激活成功后的所述軟件的所有拷貝免激活即可啟動且正常運行;在有效期限外或剩余的有效天數(shù)等于0時,所述軟件需再次激活。
優(yōu)選地,所述密碼為動態(tài)密碼,所述動態(tài)密碼的生成與激活時間相關。
優(yōu)選地,在步驟S10中,在所述軟件激活成功后生成的許可證文件中,所述軟件的有效期限為從激活成功之日起10-30天或有效天數(shù)為10-30天。
優(yōu)選地,在步驟S10中,在所述軟件激活成功后生成的許可證文件中寫入基準時間及有效天數(shù),并根據(jù)基準時間和有效天數(shù)確定剩余的有效天數(shù);或,在所述軟件激活成功后生成的許可證文件中直接寫入有效期限的開始時間和結束時間。
優(yōu)選地,步驟S20包括步驟:
S21:激活成功后的所述軟件啟動時,檢測是否存在許可證文件;
S22:當存在許可證文件時,打開許可證文件并檢查啟動時間是否在有效期限內(nèi)或剩余的有效天數(shù)是否大于0;
S23:當啟動時間位于有效期限內(nèi)或剩余的有效天數(shù)大于0時,打開軟件。
優(yōu)選地,當不存在許可證文件時,進入激活程序;當啟動時間位于有效期限外或剩余的有效天數(shù)等于0時,進入步驟S24:刪除許可證文件,并進入步驟S21。
優(yōu)選地,所述激活程序包括如下步驟:
S25:輸入密碼激活,密碼驗證成功后進入步驟S26,否則退出軟件;
S26:檢查系統(tǒng)時間是否位于預定范圍內(nèi),若是進入步驟S27,否則退出軟件;
S27:創(chuàng)建許可證文件,并將文件屬性更改為可讀寫;
S28:打開創(chuàng)建的許可證文件并開始寫入基準時間,寫入成功后進入步驟S29,否則提示寫入錯誤并退出軟件;
S29:關閉許可證文件。
優(yōu)選地,所述激活程序包括如下步驟:
S25:輸入密碼激活,密碼驗證成功后進入步驟S26,否則退出軟件;
S26:檢查系統(tǒng)時間是否位于預定范圍內(nèi),若是進入步驟S27,否則退出軟件;
S27:創(chuàng)建許可證文件,并將文件屬性更改為可讀寫;
S28:打開創(chuàng)建的許可證文件并開始寫入有效期限的開始時間和結束時間,寫入成功后進入步驟S29,否則提示寫入錯誤并退出軟件;
S29:關閉許可證文件。
優(yōu)選地,對許可證文件的文件名、保存位置和文件內(nèi)容均進行加密。
優(yōu)選地,所述軟件為產(chǎn)線程序。
本發(fā)明的提出的一種軟件授權方法,在軟件首次使用時通過密碼激活,并在軟件激活成功后生成許可證文件,許可證文件記錄了軟件的有效期限或剩余的有效天數(shù);在有效期限內(nèi)或剩余的有效天數(shù)大于0時,激活成功后的軟件的所有拷貝免激活即可啟動且正常運行;在有效期限外或剩余的有效天數(shù)等于0時,軟件需再次激活。通過該技術方案,可以在母盤制作階段通過密碼延續(xù)軟件的使用期限,在軟件測試階段通過許可證文件限制軟件的有效期限或有效天數(shù),既實現(xiàn)了對軟件的授權保護,又不會影響軟件的生產(chǎn)效率。該方法在一般性軟件授權保護的基礎上,尤其適應了產(chǎn)線測試流程的生產(chǎn)特點,做到了一次激活之后,只要在有效期之內(nèi),就可以實現(xiàn)任意拷貝的免激活運行;有效期過期之后,也只需要再次激活,就又能創(chuàng)建新的有效期。
在優(yōu)選的技術方案中,動態(tài)密碼算法采用與激活時間相關的復雜科學計算方法,既保證了密碼的復雜度,又提高了軟件激活人員的可操作性。同時,通過對許可證文件的文件名、保存位置和文件內(nèi)容進行加密,保證了許可證的安全。
附圖說明
圖1為本發(fā)明的一種軟件授權方法的示意圖;
圖2為本發(fā)明的一種軟件授權方法中軟件拷貝的打開流程示意圖;
圖3為本發(fā)明的第一種軟件授權方法中軟件拷貝的激活流程示意圖;
圖4為本發(fā)明的第二種軟件授權方法中軟件拷貝的激活流程示意圖。
具體實施方式
為了能夠更清楚地理解本發(fā)明的上述目的、特征和優(yōu)點,下面結合附圖和具體實施方式對本發(fā)明進行進一步的詳細描述。需要說明的是,在不沖突的情況下,本申請的實施例及實施例中的特征可以相互組合。
如背景技術部分所言,某些軟件,具體以產(chǎn)線程序為例,其授權保護既要保護軟件開發(fā)商的軟件版權,又不能影響產(chǎn)線流程的生產(chǎn)效率,產(chǎn)線程序是隨操作系統(tǒng)母盤一起分發(fā)的,因此必須在母盤制作階段解決產(chǎn)線程序的授權保護問題,在產(chǎn)線程序的使用階段只對產(chǎn)線程序的有效性進行檢驗。本發(fā)明的構思即基于此,并最終實現(xiàn)了在母盤制作階段通過動態(tài)密碼延續(xù)產(chǎn)線程序的使用期限,在產(chǎn)線測試階段通過許可證文件限制產(chǎn)線程序的使用期限。
參考圖1所示,本發(fā)明提出的一種軟件授權方法,包括如下步驟:
S10:在軟件首次使用時通過密碼激活,并在軟件激活成功后生成許可證文件,許可證文件記錄了軟件的有效期限或剩余的有效天數(shù);
S20:在有效期限內(nèi)或剩余的有效天數(shù)大于0時,激活成功后的軟件的所有拷貝免激活即可啟動且正常運行;在有效期限外或剩余的有效天數(shù)等于0時,軟件需再次激活。
上述方案中,步驟S10中的有效期限即軟件可以被啟動且正常運行的開始日期與結束日期之間的時間區(qū)間,有效天數(shù)即軟件可以被啟動且正常運行的天數(shù),剩余的有效天數(shù)即軟件剩余可以被啟動且正常運行的天數(shù)。
上述方案中,在軟件首次使用時通過密碼激活,并在軟件激活成功后生成許可證文件,許可證文件記錄了軟件的有效期限或剩余的有效天數(shù)。一旦激活,軟件(如產(chǎn)線程序)的任意多個拷貝都可以隨操作系統(tǒng)一起分發(fā),每個拷貝設置有默認有效期限或有效天數(shù),如有效天數(shù)20天(從激活之日算起),在有效期限內(nèi)或剩余的有效天數(shù)大于0時,所有的軟件拷貝皆不再需要激活即可啟動且正常運行,在有效期限外或剩余的有效天數(shù)等于0時,軟件需再次激活才能夠正常使用。通過該技術方案,可以在母盤制作階段通過密碼延續(xù)軟件的使用期限,在軟件測試階段通過許可證文件限制軟件的有效期限或有效天數(shù),既實現(xiàn)了對軟件的授權保護,又不會影響軟件的生產(chǎn)效率。該方法尤其適用于產(chǎn)線程序的授權保護,即,該方案中軟件為具體的產(chǎn)線程序。
上述方案中,“通過密碼激活”的密碼,可以為固定密碼或動態(tài)密碼,優(yōu)選采用動態(tài)密碼,且動態(tài)密碼的生成與激活時間相關,通過采用與激活時間相關的動態(tài)方式生成,可以由軟件開發(fā)商駐廠代表掌握密碼生成算法,并實施激活。需要說明的是,動態(tài)密碼本質(zhì)上是一種對稱密鑰算法,雖然各種成熟的動態(tài)密鑰算法已經(jīng)較好地解決了安全性問題,但是考慮到實際生產(chǎn)活動中是由軟件開發(fā)商駐廠代表負責軟件激活程序,因此在考慮到安全性的同時還要兼顧密碼生成算法的便利性。本發(fā)明優(yōu)選采用了一種與激活時間相關的復雜科學計算方法,生成一個長度可調(diào)(即復雜度可調(diào))的字符串序列作為當前時間段(具體到當前小時)的動態(tài)密碼。
在動態(tài)密碼輸入正確之后,會自動生成一個許可證文件,該許可證文件記錄了軟件的有效期限或剩余的有效天數(shù)。此時,軟件已經(jīng)可以隨操作系統(tǒng)母盤進行分發(fā)了,程序在啟動時,只要檢測到許可證的存在,且在有效期限內(nèi)或剩余的有效天數(shù)大于0,就可以正常運行;否則就會要求用戶重新激活程序。這樣就保證了在有效期之內(nèi),產(chǎn)線測試人員不再需要重復進行軟件激活流程,流程大幅簡化。
上述方案中,有效期限或有效天數(shù)可以根據(jù)需要設置,或按照預定的規(guī)則設置,具體的,在步驟S10中,在軟件激活成功后生成的許可證文件中,軟件的有效期限為從激活成功之日起10-30天或有效天數(shù)為10-30天,如15天、20天、25天等。
為便于確定有效期限或有效天數(shù),在步驟S10中,在軟件激活成功后生成的許可證文件中寫入基準時間及有效天數(shù),并根據(jù)基準時間和有效天數(shù)確定剩余的有效天數(shù);或,在軟件激活成功后生成的許可證文件中直接寫入有效期限的開始時間和結束時間。
上述的軟件授權方法,為正確判斷激活成功后的軟件的所有拷貝是可以運行或需要激活,參考圖2所示,步驟S20優(yōu)選包括如下步驟:
S21:激活成功后的軟件啟動時,檢測是否存在許可證文件;
S22:當存在許可證文件時,打開許可證文件并檢查啟動時間是否在有效期限內(nèi)或剩余的有效天數(shù)是否大于0;
S23:當啟動時間位于有效期限內(nèi)或剩余的有效天數(shù)大于0時,打開軟件。
同時,當不存在許可證文件時,進入激活程序;當啟動時間位于有效期限外或剩余的有效天數(shù)等于0時,進入步驟S24:刪除許可證文件,并進入步驟S21。。
通過上述流程,可以正確判斷激活成功后的軟件是直接運行還是需要激活以后在運行,保證軟件安全的同時,提高了生產(chǎn)效率。
參見圖3,圖3為本發(fā)明的第一種軟件授權方法中軟件拷貝的激活流程示意圖。
上述的軟件授權方法,激活程序可以有多種方式,在一種具體的方式中,激活程序包括如下步驟:
S25:輸入密碼激活,密碼驗證成功后進入步驟S26,否則退出軟件;
S26:檢查系統(tǒng)時間是否位于預定范圍內(nèi)(如2016年1月1日至2017年12月31日之間,此時間可根據(jù)情況具體設置),若是進入步驟S27,否則退出軟件;
S27:創(chuàng)建許可證文件,并將文件屬性更改為可讀寫;
S28:打開創(chuàng)建的許可證文件并開始寫入基準時間,寫入成功后進入步驟S29,否則提示寫入錯誤并退出軟件;
S29:關閉許可證文件。
參見圖4,圖4為本發(fā)明的第二種軟件授權方法中軟件拷貝的激活流程示意圖。
在另一種具體的方式中,激活程序包括如下步驟:
S25:輸入密碼激活,密碼驗證成功后進入步驟S26,否則退出軟件;
S26:檢查系統(tǒng)時間是否位于預定范圍內(nèi)(如2016年1月1日至2017年12月31日之間,此時間可根據(jù)情況具體設置),若是進入步驟S27,否則退出軟件;
S27:創(chuàng)建許可證文件,并將文件屬性更改為可讀寫;
S28:打開創(chuàng)建的許可證文件并開始寫入有效期限的開始時間和結束時間,寫入成功后進入步驟S29,否則提示寫入錯誤并退出軟件;
S29:關閉許可證文件。
通過上述流程,可以采用不同的方式對軟件進行再次激活,并產(chǎn)生許可證文件,操作簡單,同時,再次激活后的軟件同樣兼顧了軟件的安全和效率。
為保證許可證文件的安全,上述軟件授權方法中,優(yōu)選地,對許可證文件的文件名、保存位置和文件內(nèi)容均進行加密。
本發(fā)明的軟件授權方法,通過密碼(如動態(tài)密碼)和許可證文件,通過對軟件的一次授權,就可以實現(xiàn)對任意多個軟件拷貝的授權。現(xiàn)有技術無論其加密算法如何,要么只能實現(xiàn)對單一軟件拷貝的授權保護,每個軟件拷貝都需要單獨激活;要么就會出現(xiàn)單個密碼可以激活多個軟件拷貝,而導致的侵權現(xiàn)象。本發(fā)明通過動態(tài)密碼創(chuàng)建軟件有效期,通過許可證檢查軟件有效期,這樣既實現(xiàn)了對軟件的授權保護,又不會導致對每個軟件拷貝的重復激活,兼顧了安全和效率。
本發(fā)明的軟件授權方法,在一般性軟件授權保護的基礎上,尤其適應了產(chǎn)線測試流程的生產(chǎn)特點,做到了一次激活之后,只要在有效期之內(nèi),就可以實現(xiàn)任意拷貝的免激活運行;有效期過期之后,也只需要再次激活,就又能創(chuàng)建新的有效期。
綜上所述,本發(fā)明的軟件授權方法具有如下優(yōu)點:
(1)通過動態(tài)密碼創(chuàng)建軟件有效期限或有效天數(shù),通過許可證文件檢查軟件的有效期限或有效天數(shù),這樣授權與驗證相分離,既實現(xiàn)了對軟件的授權保護,又不會影響生產(chǎn)效率,達到了安全與效率的統(tǒng)一。
(2)動態(tài)密碼算法采用與激活時間相關的復雜科學計算方法,既保證了密碼的復雜度,又提高了軟件激活人員的可操作性。
(3)通過對許可證文件的文件名、保存位置和文件內(nèi)容進行加密,保證了許可證的安全。
以上僅為本發(fā)明的優(yōu)選實施例而已,并不用于限制本發(fā)明,對于本領域的技術人員來說,本發(fā)明可以有各種更改和變化。凡在本發(fā)明的精神和原則之內(nèi),所作的任何修改、等同替換、改進等,均應包含在本發(fā)明的保護范圍之內(nèi)。